@charset "UTF-8";

/* reset css ------------------------- */
*,*::before,*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
ul,li {
  list-style: none;
}
a {
  text-decoration: none;
  color: inherit;
}
img {
  border: none;
  vertical-align: bottom;
  /* Fluid Image */
  max-width: 100%;
  height: auto;
}

/* 共通CSS ---------------------------- */
html, body{
  position: relative;
  width: 100%;
  overflow-x: hidden;
}
body {
  background-color: rgb(43, 39, 39);
  color: #333;
  /* font-family: 'Noto Serif JP', serif; */
  font-family: 'Shippori Mincho', serif;
  font-weight: 600;
  line-height: 1.0;
}
.container{
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 10px;
}

/* 見出し共通-------------------------- */
section > h2,section > p {
  text-align: center;
  margin: 10px 0 20px;
}
section > h2 {
  margin: 0 auto 30px;
  background-repeat: no-repeat,no-repeat;
  background-position: left,right;
  font-size: 48px;
  font-weight: bold;
}
.menu h2,.course h2,.shop-guide h2,.media h2 {
  width: 19rem;
  background-image: url(../img/subtitle-logo01.svg),url(../img/subtitle-logo02.svg);
}
.drink h2,.shop h2 {
  background-image: url(../img/subtitle-logo03.svg),url(../img/subtitle-logo04.svg);
}
.drink h2 {
  width: 18rem;
}
.shop-guide h2 {
  width: 25rem;
}
.shop h2 {
  width: 34rem;
  margin-bottom: 30px;
}
section > p ,#home .media >p{
  font-size: 28px;
  line-height: 1.5;
}
#home main >section >p {
  padding: 30px 10px;
}
img.subtitle-logo {
  width: 10%;
}

/* Section共通 ------------------------ */
#home section {
  padding: 50px 0 0;
}

/* ====================================
TOPページ
====================================== */
/* Header ---------------------------- */
h1 {
  padding: 3px 0 3px 10px;
  background: linear-gradient(45deg,rgba(0, 0, 0, 0.8),rgba(160, 119, 93, 0.9)),url(../img/washi02.webp) no-repeat center / cover;
  color: #fff;
  font-size: 12px;
  font-weight: bold;
}
#home .header-flex{
  display: flex;
  height: 100vh;
  background: linear-gradient(45deg,rgba(0, 0, 0, 0.85) 10%,rgba(128, 83, 59, 0.8)),url(../img/washi02.webp) no-repeat left center / cover;
}
.logo{
  margin: auto;
  width: 300px;
  box-sizing: border-box;
}
.logo-mark a{
  display: grid;
}
.logo img {
  width: 70%;
  margin: 10px auto 50px;
}
.menu-btn {
  margin: 0 auto;
  width: 85%;
  text-align: center;
  line-height: 1.3;
}
.menu-btn li{
  margin-bottom: 30px;
  font-weight: bold;
}
.menu-btn li span {
  display: block;
  padding-bottom: 10px;
}
.menu-btn .material-symbols-outlined {
  display: block;
}
.menu-btn a{
  margin: 0 auto;
  padding: 10px;
  display: block;
  transition: .3s;
}
li.web {
  background: linear-gradient(-45deg,rgb(255, 196, 0),rgb(255, 60, 0));
  color: #fff;
  font-weight: bold;
  border-radius: 5px;
}
li.web span {
  font-size: 30px;
}
li.web a {
  display: block;
  line-height: 25px;
}
li.web a:hover{
  border-radius: 5px;
  background-color: rgba(255, 255, 255,0.7);
  color: #333;
}
li.telephone span {
  font-size: 24px;
  display: inline;
}
li.telephone a {
  display: block;
  color: #fff;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  transition: .3s;
}
li.telephone a:hover{
  background: linear-gradient(-45deg,rgb(252, 229, 157),rgb(252, 201, 201));
  color: #333;
}
li.line{
  color: #fff;
  text-align: center;
}
li.line p{
  line-height: 1.5;
  font-size: 14px;
}
li.line img {
  width: 30%;
  margin: 15px;
}

/* PC Navigation ---------------------  */
#home .nav-keyVis {
  width: 100%;
}

/* jQueryを使い、fixedクラスが付与された際の設定 */
.pcnav.fixed {
  position: fixed;
  width: 100%;
  z-index: 10000;
  top: 0;
  left: 0;
}
.pcnav ul{
  padding: 12px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(45deg,rgba(0, 0, 0, 0.85) 20%,rgba(128, 83, 59, 0.8)),url(../img/washi02.webp) no-repeat left center / cover;
  font-weight: bold;
  text-shadow: 3px 2px 10px #ccc;
  /* text-align: right; */
  font-size: 17px;
}
.pcnav li{
  /* -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl; */
  writing-mode: vertical-rl;
  padding: 10px 15px;
  display: inline-block;
  text-align: left;
  line-height: 2;
}
.pcnav li.line {
  margin: 0;
  padding: 0;
}
.pcnav li.line img {
  width: 40px;
}
.pcnav a{
  display: block;
  padding: 0 10px;
  color: #fff;
}
.current a{
  color: rgb(255, 73, 18);
}
.pcnav a:hover{
  color: rgb(226, 206, 24);
}

/* 店舗情報へ飛ぶボタン ---------------- */
.shop-btn a {
  display: block;
  padding: 30px 0 10px 30px;
  position: absolute;
  width: 100%;
  top: 75vh;
  right: -50px;
  width: 200px;
  height: 200px;
  border: 3px solid rgb(255, 255, 255);
  border-radius: 50%;
  background: linear-gradient(150deg,rgba(255, 255, 255,0.9) 15%,rgba(250, 94, 32, 0.9) 29% ,rgb(255, 136, 0) 70%,rgb(252, 212, 205) 100%);
  color: #444;
  font-size: 30px;
  line-height: 1.2;
  letter-spacing: 0.07em;
  transition: .3s;
}
.shop-btn .material-symbols-outlined {
  font-size: 40px;
  padding-left: 50px;
}
.shop-btn .shop-btn-text {
  color: #333;
  font-family: 'Noto Serif JP', serif;
  font-size: 20px;
  font-weight: bold;
}

/* SP Navigation --------------------- */
.spnav,.btn{
  display: none;
}

/* 予約、問い合わせボタン　PCのみ右へ固定-- */
#book-right-btn {
  width: 120px;
  height: 200px;
  position: fixed;
  bottom: 300px;
  right: 0;
  font-weight: bold;
  z-index: 10;
}
#book-right-btn .tel a {
  display: block;
  padding: 10px;
  background: linear-gradient(-45deg,rgba(255, 209, 109, 0.8),rgba(226, 109, 50, 0.8)),url(../img/washi02.webp) no-repeat center / cover;
  /* background-color: rgb(219, 194, 126); */
  line-height: 1.3;
  text-align: center;
  border: 3px solid #333;
  border-radius: 5px 0 0 0;
}
#book-right-btn .tel a {
  border-bottom: 0;
  border-right: 0;
}
#book-right-btn .tel .material-symbols-outlined.md-36 {
  display: block;
  color: #333;
}
#book-right-btn .web-net a {
  display: block;
  padding: 5px;
  height: 100px;
  background: linear-gradient(rgba(155, 132, 108, 0.7),rgba(39, 33, 28, 0.8)),url(../img/washi02.webp) no-repeat left center / cover;
  color: #fff;
  border: 3px solid #333;
  border-radius: 0 0 0 5px;
  line-height: 1.3;
  text-align: center;
}
#book-right-btn .web-net a {
  border-top: 0;
  border-right: 0;
}
#book-right-btn .web-net span {
  display: block;
}

/* 予約、問い合わせボタン下部固定 ------- */
#book-list {
  height: 0;
  color: transparent;
  display: none;
}
#book-list a {
  display: block;
  transition: .3s;
}
#book-list a:hover {
  background: rgb(255, 193, 106);
  color: #333;
}
#book-list .material-symbols-outlined {
  color: transparent;
}

/* Key Visual -------------------------  */
#home .keyVis {
 max-width: 100%;
 height: 100vh;
}
#home .keyVis-slider {
  width: 100%;
  height: 100%;
}
#home .keyVis.position {
  position: absolute;
  top: 129px;
  left: 260px;
  width: 100%;
}
#home #no-slider {
  display: none;
}
#home .logo-sp {
  display: none;
}
/* キャッチコピー ----------------------- */
#home .keyVis-slider {
  position: relative;
}
#home .copy>p {
  writing-mode: vertical-rl;
  padding: 10px 15px;
  display: inline-block;
  text-align: left;
  line-height: 1.5;
  position: absolute;
  top: 40vh;
  right: 40vw;
  color: #fff;
  font-weight: bold;
  font-size: 40px;
  text-shadow: 2px 2px 4px #000;
  z-index: 10;
}
#home .copy>p>span {
  color: rgb(255, 102, 0);
  text-shadow: 2px 2px 2px #fff;
}
#home .copy>p.position-c {
  top: 29vh;
  right: 53vw;
}

/* TOPに戻る ---------------------------- */
.top {
  width: 70px;
  height: 70px;
  text-align: center;
  font-weight: bold;
  color: #fff;
  background-color: rgb(39, 32, 32);
  border: 1px solid #fff;
  border-radius: 50%;
  position: fixed;
  bottom: 10px;
  right: 10px;
  cursor: pointer;
  z-index: 100;
}
.top span {
  display: block;
}
.material-symbols-outlined {
  padding: 10px 0 5px;
  color: #fff;
  font-size: 35px;
}

/* Main Content ------------------------- */
/* Introduction  */
#home .intro {
  text-align: right;
  padding: 50px 0;
  background: linear-gradient(135deg,rgba(253, 247, 234, 0.6),rgba(255, 255, 255, 0.9)),url(../img/washi01.webp) no-repeat center / cover;
}
#home .intro .container {
  max-width: 1700px;
  margin: 0 auto;
  padding: 0 10px;
  background: url(../img/intro.png) no-repeat left center / 35% auto;
}
.intro h2 {
  margin: 0;
}
#home .catch-copy {
  margin-left: 30px;
  width: 450px;
}
#home .intro-text {
  /* -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl; */
  writing-mode: vertical-rl;
  padding: 10px 20px;
  line-height: 2;
  display: inline-block;
  text-align: left;
}
.intro h2 {
  /* text非表示 */
  white-space: nowrap;
  text-indent: 100%;
  overflow: hidden;
}
#home .intro-text p {
  margin-left: 30px;
  width: 50%;
  line-height: 1.7;
  font-size: 26px;
  text-shadow: 2px 2px #fff;
}
/* 詳細を見る 店主のこだわり */
.more {
  text-align: center;
  padding-bottom: 50px;
}
.more p {
  width: 500px;
  margin: 0 auto;
  width: 330px;
  font-weight: bold;
  font-size: 24px;
}
.more a {
  display: block;
  padding: 20px;
  border-radius: 5px;
  /* background: linear-gradient(135deg,rgb(240, 236, 225),rgb(247, 205, 22),rgb(255, 74, 2)); */
  background: linear-gradient(135deg,rgba(253, 212, 158, 0.651),rgba(255, 116, 2, 0.76)),url(../img/washi02.webp) no-repeat left center / cover;
  color: #333;
  border: 2px solid rgb(136, 116, 93);
  transition: .4s;
}
.more .material-symbols-outlined {
  color: #333;
  font-size: 18px;
}
.more a:hover {
  background: linear-gradient(135deg,rgba(209, 73, 32, 0.7),rgba(212, 106, 56,0.7),rgba(236, 192, 95, 0.7)),url(../img/washi02.webp) no-repeat left center / cover;
  color: #fff;
}
.more a:hover .material-symbols-outlined {
  color: #fff;
}

/* Menu お品書き------------------------ */
#home .menu {
  background: linear-gradient(-45deg,rgba(192, 179, 164, 0.8),rgba(255, 255, 255, 0.7),rgb(247, 236, 221)),url(../img/washi02.webp) no-repeat center / cover;
  text-align: center;
}
#home .menu .container {
  max-width: 1300px;
}
#home .menu-img {
  width: 100%;
}
#home .recommend > img {
  object-fit: cover;
}
#home .menu .reco {
  width: 10%;
  position: absolute;
  top: 20px;
  left: 0px;
}
#home .menu .container section {
  margin-bottom: 50px;
  padding: 0 30px;
  position: relative;
  display: grid;
  grid-template-columns: repeat(2,1fr);
  grid-template-columns: repeat(2,1fr);
  gap: 30px;
  padding-top: 10px;
  align-items: center;
}
#home .menu .container .recommend .reco-name {
  width: 100%;
  text-align: center;
}
#home .menu .container section:nth-child(2n) > img {
  grid-column: 2/3;
  grid-row: 1/2;
}
#home .menu .container section:nth-child(2n) .text-r {
  grid-column: 1/2;
  grid-row: 1/2;
}
#home .menu .container section > img {
  object-fit: cover;
}
#home .okada-hudemoji-pc {
  width: 55%;
}
#home .menu img,#home .course img {
  margin-bottom: 20px;
}
#home .menu section h3,#home .drink h3,#home .course h3 {
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 20px;
}
#home .menu section h3 {
  font-size: 26px;
  font-weight: normal;
  color: rgb(194, 89, 19);
}
#home .menu section .price,#home .drink .container section .price,#home .course .container section .price,#home .course .container .recommend .price {
  text-align: right;
  font-size: 26px;
  margin-bottom: 10px;
}
#home .menu section p,#home .drink .container section p,#home .course .container section p {
  font-size: 23px;
  text-align: left;
  line-height: 1.7;
}
#home .more-btn {
  display: flex;
  justify-content: center;
}
#home .more-btn .more {
  margin: 0 10px 50px;
}

/* Drink お飲み物 ---------------------- */
#home .drink {
  background: linear-gradient(-45deg,rgba(49, 45, 41, 0.8),rgba(95, 84, 77, 0.8)),url(../img/washi02.webp) no-repeat center / cover;
  text-align: center;
  color: #fff;
}
#home .drink h3 {
  font-size: 32px;
  text-align: left;
}
#home .drink .price {
  margin-bottom: 30px;
}
#home .drink .container section p {
  font-size: 22px;
  line-height: 1.7;
}
#home .drink .container section {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
#home .drink1 {
  margin-bottom: 100px;
}
#home .drink .drink1 img {
  margin: 30px 500px 30px -300px;
  width: 70%;
  z-index: 1;
}
#home .drink .drink2 img {
  margin: 30px 30px 0 668px;
  width: 70%;
  z-index: 1;
}
#home .drink-text {
  position: absolute;
  width: 70%;
  color: #333;
}
#home .dt1 {
  padding: 100px 100px 100px 200px;
  top: 200px;
  left: 500px;
  background: linear-gradient(to right,rgba(184, 134, 102, 0.8),rgba(233, 212, 177, 0.8)),url(../img/washi02.webp) no-repeat center / cover;
}
#home .dt2 {
  padding: 100px 200px 100px 100px;
  top: 200px;
  left: -210px;
  background: linear-gradient(to left,rgba(184, 134, 102, 0.8),rgba(233, 212, 177, 0.8)),url(../img/washi02.webp) no-repeat center / cover;
}
#home .drink .more-btn {
  margin-top: 200px;
}

/* コース ----------------------------- */
#home .course {
  background: linear-gradient(45deg,rgba(192, 179, 164, 0.8),rgba(255, 255, 255, 0.7),rgb(247, 236, 221)),url(../img/washi01.webp) no-repeat left center / cover;
  text-align: center;
  color: #333;
}
#home .course .container {
  max-width: 1680px;
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 30px;
}
#home .course section {
  position: relative;
  margin-bottom: 50px;
}
#home .course .reco {
  width: 20%;
  position: absolute;
  top: 20px;
  left: 40px;
}
#home .course h3 {
  font-size: 36px;
  font-weight: bold;
  line-height: 1.5;
}
#home .course .container section .price {
  font-size: 22px;
}
#home .course .container .recommend .price {
  margin: 10px 0 20px;
  font-size: 22px;
}
#home .course .container section p {
  font-size: 22px;
  line-height: 1.7;
  text-align: justify;
}
#home main >section.course >p {
  padding: 0 10px;
}
#home .course-service,#home .course span {
  color: rgba(255, 83, 30, 0.8);
  font-size: 26px;
  font-weight: bold;
}
#home .course span {
  font-size: 28px;
}
#home .course-sp {
  display: none;
}
#home p.price.price-space {
  padding-bottom: 60px;
}

/* 店内のご案内 ------------------------ */
#home .shop-guide {
  background: linear-gradient(45deg,rgba(170, 134, 102, 0.85) 10%,rgba(105, 92, 85, 0.8)),url(../img/washi02.webp) no-repeat left center / cover;
  color: #000;
  padding-bottom: 50px;
}

/* 右から左へ */
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
#home .slide {
  margin-bottom: 50px;
}
#home .slide-img {
  display: flex;
  overflow: hidden;
}
#home .slide-img-list {
  display: flex;
  list-style: none;
}
#home .list-left{
  animation :infinity-scroll-left 40s infinite linear 0.6s both;
}
#home .slide-img-list >li {
  width: calc(100vw / 4);
}
#home .slide-img-list > li > img{
  width: 100%;
}
#home .container .bxslider {
  height: 200px;
}
#home .floor> img,.floor> img {
  float: left;
  width: 40%;
  height: 40%;
}
#home .floor-text {
  padding: 0 20px;
  width: 50%;
  line-height: 1.5;
  float: right;
}
#home .floor-text h3 {
  font-size: 28px;
}
#home .floor-text p {
  font-size: 18px;
  text-align: left;
}
#home .floor-text p:last-of-type {
  margin-bottom: 0;
}
#home .floor-text .number-person {
  margin-bottom: 20px;
  text-align: right;
  font-size: 24px;
}


/* 掲載情報 -------------------------------- */
#home .media {
  background: linear-gradient(-45deg,rgba(192, 179, 164, 0.8),rgba(255, 255, 255, 0.7),rgb(247, 236, 221)),url(../img/washi02.webp) no-repeat center / cover;
}
#home .media >p {
  margin: 0 auto 30px;
}
#home .media .container {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
#home .media img {
  width: 30%;
  margin-right: 20px;
  margin: 0 auto;
}
#home .media dl,.media p {
  width: 65%;
  line-height: 1.5;
  font-size: 20px;
}
#home .media dt {
  font-weight: bold;
}
#home .media dd {
  margin-bottom: 20px;
}
#home .media .more {
  width: 100%;
  margin: 50px 0;
}
#home .media .more p {
  width: 300px;
}

/* 店舗情報・アクセス ----------------------- */
.shop {
  padding: 50px 0 30px;
  background: linear-gradient(45deg,rgba(0, 0, 0, 0.85) 10%,rgba(128, 83, 59, 0.8)),url(../img/washi02.webp) no-repeat left center / cover;
  color: #fff;
}
.shop-logo {
  width: 10%;
}
.shop-list {
  display: flex;
  justify-content: center;
}
.shop-info dt,.shop-info dd {
  line-height: 1.3;
  font-size: 18px;
}
.shop-info dt {
  float: left;
  color: rgb(253, 149, 108);
  font-weight: bold;
}
.shop-info dd {
  margin: 0 0 10px 110px;
  text-align: left;
  font-weight: normal;
}
.shop-img {
  width: 50%;
  margin-left: 30px;
}
.other-info {
  margin: 30px 0 5px;
  text-align: center;
  font-size: 24px;
  color: rgb(252, 113, 58);
  font-weight: bold;
}
.other-shop p {
  margin: 0 0 40px;
  background: url(../img/other-shop.webp) no-repeat center / cover;
  border: 5px solid rgb(252, 113, 58);
  border-radius: 10px;
  font-size: 28px;
  text-align: center;
}
.other-shop a {
  padding: 80px 0;
  display: block;
  border-radius: 10px;
  transition: .3s;
  background-color: rgba(0 , 0, 0, 0.4);
  color: #fff;
  font-weight: bold;
  text-shadow: 3px 3px 1px #000;
  opacity: 0;
}
.other-shop a:hover {
  opacity: 0.8;
}
.shop .logo {
  background: transparent;
  width: 100%;
  height: 150px;
  margin-bottom: 50px;
}
.shop .logo ul {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.shop .logo li {
  width: 100%;
  margin: 10px 20px;
}
.shop .menu-btn {
  display: flex;
}
.shop .line {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.shop .line img {
  width: 18%;
}
.g-map {
  width: 100%;
  height: 300px;
  margin-bottom: 50px;
}

/* Footer --------------------------- */
footer {
  padding: 30px 0;
  background: linear-gradient(rgba(0, 0, 0, 0.8),rgba(0, 0, 0, 0.9)),url(../img/washi02.webp) no-repeat center / cover;
  color: #fff;
  text-align: center;
}

@media screen and (max-width:1690px) {
  /* KeyVisual */
  #home .keyVis-bg.position-bg {
    right: 240px;
  }
  #home .keyVis.position {
    top: 130px;
    left: 250px;
  }

  /* catch-copy */
  #home .copy>p.position-c {
    top: 21vh;
    right: 56.5vw;
  }

  /* Introduction */
  #home .intro .container {
    padding: 0 10px 200px;
    background: url(../img/intro.png) no-repeat left bottom / 35% auto;
  }

  /* drink */
  #home .drink1 {
    margin-bottom: 150px;
  }
  #home .drink .drink1 img {
    margin: 30px 400px 30px -300px;
    width: 60%;
  }
  #home .drink .drink2 img {
    margin: 30px 0 0 668px;
    width: 60%;
  }
  #home .drink-text {
    width: 65%;
  }
  #home .dt1 {
    padding: 80px 100px 80px 200px;
    top: 200px;
    left: 500px;
  }
  #home .dt2 {
    padding: 80px 200px 80px 100px;
    top: 200px;
    left: -110px;
  }
}

@media screen and (max-width:1480px) {
  /* drink */
  #home .drink1 {
    margin-bottom: 150px;
  }
  #home .drink .price {
    margin-bottom: 30px;
  }
  #home .drink .drink1 img {
    margin: 30px 400px 30px -180px;
    width: 50%;
  }
  #home .drink .drink2 img {
    margin: 30px 150px 0 668px;
    width: 50%;
  }
  #home .drink-text {
    width: 55%;
  }
  #home .drink h3 {
    font-size: 30px;
  }
  #home .drink .container section p {
    font-size: 18.2px;
    line-height: 1.7;
  }
  #home .dt1 {
    padding: 60px 100px 60px 150px;
    top: 200px;
    left: 500px;
  }
  #home .dt2 {
    padding: 60px 150px 60px 100px;
    top: 200px;
    left: 20px;
  }

  /* course ------------- */
  #home .course h3 {
    font-size: 30px;
  }
  #home .course .reco {
    width: 25%;
    top: 0;
    left: 0;
  }
}

@media screen and (max-width:1300px) {
  /* KeyVisual */
  #home .keyVis-bg.position-bg {
    right: 230px;
  }
  #home .keyVis.position {
    top: 130px;
    left: 240px;
  }

  /* キャッチコピー ----------------------- */
#home .copy>p {
  top: 40vh;
  right: 33vw;
}
#home .copy>p.position-c {
  top: 22vh;
  right: 52vw;
}

  /* intro text -------------------- */
  #home .intro .container {
    display: block;
  }
  #home .intro .container {
    background: url(../img/intro.png) no-repeat left bottom / 45% auto;
  }
  #home .catch-copy {
    margin: 0 auto;
    width: 450px;
  }
  #home .intro-text {
    display: block;
    writing-mode: horizontal-tb;
    text-align: center;
  }
  #home .intro-text h2 {
    margin: 0 auto;
  }
  #home .intro-text p {
    margin-left: 0;
    margin-bottom: 30px;
  }
  #home img.catch-copy {
    margin-bottom: 80px;
  }
  #home .intro-text p {
    width: 100%;
  }
  
  /* menu -------------- */
  #home .okada-hudemoji-pc {
    width: 80%;
  }

  /* course ------------- */
  #home .course h3 {
    font-size: 26px;
  }
  #home .course .container section p {
    font-size: 20px;
    line-height: 1.7;
    text-align: justify;
  }

}

@media screen and (max-width:1200px) {
  /* menu */
  #home .menu .reco {
    top: 40px;
    left: 0px;
  }

  /* drink */
  #home .drink1 {
    margin-bottom: 350px;
  }
  #home .drink2 {
    margin-bottom: 450px;
  }
  #home .drink .price {
    margin-bottom: 30px;
  }
  #home .drink .drink1 img {
    margin: -20px 200px 0 -30px;
    width: 60%;
  }
  #home .drink .drink2 img {
    margin: 30px 450px 0 668px;
    width: 60%;
  }
  #home .drink-text {
    width: 55%;
  }
  #home .drink h3 {
    font-size: 30px;
  }
  #home .drink .container section p {
    font-size: 18.2px;
    line-height: 1.7;
  }
  #home .dt1 {
    padding: 100px 60px 50px 60px;
    top: 400px;
    left: 398px;
  }
  #home .dt2 {
    padding: 100px 60px 50px 60px;
    top: 450px;
    left: 120px;
  }

  /* course */
  #home .course .reco {
    width: 30%;
    top: 0;
    left: -15px;
  }
}

@media screen and (max-width:1100px) {
  /* logo */
  .logo {
    display: none;
  }
  .logo-sp {
    display: inline;
    position: absolute;
    top: 15px;
    left: 10px;
    width: 20%;
  }
  .logo-sp>p>a>img {
    filter: drop-shadow(5px 5px 10px #000);
  }
  .logo>p>img{
    filter: drop-shadow(5px 5px 10px #000);
    width: 60%;
    margin: 30px 90px 0 0;
    margin-bottom: 50vh;
  }

  /* 見出し、本文 共通 */
  #home .menu section p{
    font-size: 20px;
    text-align: left;
    line-height: 1.5;
  }
  #home .menu section .price {
    font-size: 22px;
  }
  section > p ,#home .media >p{
    font-size: 22px;
    line-height: 1.5;
  }

  /* PC Navigation */
  .pcnav {
    display: none;
  }
  /* SP Navigation */
  .spnav {
    display: block;
    position: fixed;
    top: 0;
    left: -120%;
    width: 100%;
    height: 100vh;
    background-color: rgba(54, 52, 52,0.85);
    z-index: 100000;
    display: grid;
    transition: .6s;
  }
  .spnav ul {
    margin: auto;
  }
  .spnav li {
    margin-bottom: 0px;
    text-align: center;
    font-weight: bold;
    font-size: 26px;
    line-height: 60px;
  }
  .spnav a {
    display: block;
    color: #fff;
  }
  .spnav a:hover{
    color: rgb(226, 206, 24);
  }
  .spnav .line img {
    width: 5%;
  }
  .current a{
    color: rgb(255, 73, 18);
  }
  .open {
    left: 0;
  }

  /* sp-logo-mark */
  #home .sp-logo-mark {
    display: block;
    position: absolute;
    width: 20%;
    top: 50px;
    left: 10px;
  }
  #home .sp-logo-mark img {
    filter: drop-shadow(0 0 5px #fff);
  }

  /* KeyVisual */
  #home .keyVis-bg.position-bg {
    top: 110px;
    right: -60px;
  }
  #home .keyVis.position {
    top: 0;
    left: 0;
  }
  #home .keyVis-slider .bxslider {
    display: none;
  }
  #home .keyVis-slider .keyVis-bg {
    display: none;
  }
  #home #no-slider {
    display: block;
    position: absolute;
    object-fit: cover;
    width: 100%;
    height: 104vh;
    top: 1px;
  }

  /* Button Menu */
  .btn {
    display: block;
    position: fixed;
    top: 10px;
    right: 0;
    z-index: 1000000;
    width: 90px;
    height: 70px;
    cursor: pointer;
    overflow: hidden;
  }
  .btn p {
    color: #fff;
    text-shadow: 0 0 7px #000;
  }
  .btn span {
    line-height: 50px;
    text-align: center;
    display: block;
    color: #fff;
    font-size: 20px;
    text-align: center;
  }
  .material-symbols-outlined.md-48 {
    border-radius: 5px;
    font-size: 60px;
    text-shadow: 3px 3px 7px rgb(20, 19, 19);
  }
  .show .first-btn{
    display: none;
  }

  /* 予約、問い合わせボタン　PCのみ右へ固定-- */
  #book-right-btn {
    display: none!important;
  }

  /* 予約、問い合わせボタン下部固定 */
  #book-list .material-symbols-outlined {
    color: #fff;
  }
  #book-list {
    display: block;
    position: fixed;
    width: 100%;
    bottom: 0;
    left: 0;
    z-index: 1;
    height: 80px;
    background: linear-gradient(20deg,rgb(255, 123, 0),rgb(207, 54, 7));
    color: #fff;
    z-index: 5;
  }
  #book-list ul {
    display: grid;
    grid-template-columns: 2fr 2fr 1fr;
    align-items: center;
  }
  #book-list li {
    text-align: center;
    height: 80px;
    border-right: 1px solid #fff;
  }
  #book-list li:last-child {
    border-right: 0;
  }
  #book-list a {
    line-height: 80px;
  }
  #book-list .tel a {
    line-height: 40px;
  }
  .material-symbols-outlined.md-36 {
    padding: 0;
    font-size: 16px;
  } 

  /* キャッチコピー ----------------------- */
  #home .copy {
    /* -webkit-writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl; */
    writing-mode: vertical-rl;
    padding: 10px 15px;
    line-height: 2;
    display: inline-block;
    text-align: left;
  }
  #home .copy>p {
    top: 40vh;
    right: 30vw;
    font-size: 35px;
  }
  #home .copy>p.position-c {
    top: 40vh;
    right: 30vw;
  }

  /* TOPに戻る ---------------------------- */
  .top {
    bottom: 100px;
  }

  #home .keyVis-bg {
    width: 20%;
    height: 100vh;
    right: 0;
    background: linear-gradient(to left,rgb(54, 29, 22) 2% ,transparent);
    z-index: 1;
  }
  
  /* menu -------------------------- */
  #home .menu .container {
    display: block;
  }
  #home .menu .reco {
    top: 50px;
    left: 0px;
  }
  #home .reco-name {
    width: 90%;
  }
  #home .okada-hudemoji-pc {
    width: 90%;
  }

  /* drink */
  #home .drink .drink1 img {
    margin: -20px 100px 0 0;
    width: 65%;
  }
  #home .drink .drink2 img {
    margin: 30px 500px 0 550px;
    width: 65%;
  }
  #home .drink-text {
    width: 65%;
  }
  #home .dt1 {
    padding: 100px 60px 50px 60px;
    top: 410px;
    left: 200px;
  }
  #home .dt2 {
    padding: 100px 60px 50px 60px;
    top: 470px;
    left: 130px;
  }

  /* course -------------------------- */
  #home .course img {
    width: 90%;
  }
  #home .course .container p {
    padding: 0 20px;
  }
  #home .course .container {
    display: block;
  }
  #home .course section p {
    margin: 0 auto;
    width: 100%;
  }
  #home .course .reco {
    width: 20%;
    top: 0;
    left: 0;
  }
  #home .course-pc {
    display: none;
  }
  #home .course-sp {
    display: block;
    margin: 0 auto;
  }
  
  /* shop-guide ---------------------- */
  #home .slide-img-list >li {
    width: calc(100vw / 3);
  }
  #home .floor> img,.floor> img {
    float: none;
    width: 70%;
    height: 70%;
    margin: 0 auto 30px;
  }
  #home .floor-text {
    float: none;
    margin: 0 auto;
    text-align: center;
    width: 90%;
  }
  #home .floor-text p {
    margin-bottom: 20px;
  }

  /* media --------------------------- */
  #home .media > p {
    margin: 0 auto 30px;
  }
  #home .media img {
    width: 70%;
    margin: 0 0 20px 0;
  }
  #home .media dl,.media p {
    margin: 0 auto;
    width: 80%;
    line-height: 1.5;
    font-size: 20px;
  }

  /* shop --------------------------- */
  .shop-list {
    display: block;
  }
  .shop-img {
    width: 70%;
    margin: 0 auto;
  }
}

@media screen and (max-width:1000px) {
  /* drink */
  #home .drink1 {
    margin-bottom: 450px;
  }
  #home .drink2 {
    margin-bottom: 550px;
  }
  #home .drink .drink1 img {
    margin: -20px 200px 0 0;
    width: 80%;
  }
  #home .drink .drink2 img {
    margin: 30px 0 0 200px;
    width: 80%;
  }
  #home .drink-text {
    width: 80%;
  }
  #home .dt1 {
    padding: 60px 60px 50px 60px;
    top: 500px;
    left: 220px;
  }
  #home .dt2 {
    padding: 60px 60px 50px 60px;
    top: 540px;
    left: -20px;
  }

}

@media screen and (max-width:767px) {
  /* spanv */
  li.web {
    font-size: 22px;
  }
  li.telephone {
    font-size: 20px;
  }
  .spnav .line img {
    width: 8%;
  }
  
  #home .copy>p{
    font-size: 35px;
  } 

  /* 見出し共通-------------------------- */
  section > h2 {
    font-size: 30px;
  }
  .menu h2,.drink h2,.course h2,.media h2 {
    width: 12rem;
  }
  .shop-guide h2 {
    width: 16rem;
  }
  .shop h2 {
    width: 20rem;
  }
  section > p ,#home .media >p{
    font-size: 22px;
    line-height: 1.5;
  }

  /* Introduction */
  #home .intro .container {
    padding: 0 10px 250px;
    background: url(../img/intro.png) no-repeat center bottom / 50% auto;
  }
  .intro h2 {
    width: 22rem;
  }

  /* drink ---------------------------- */
  #home .drink-text > p {
    font-size: 18px;
    line-height: 1.6;
  }
  #home .drink .container section {
    position: static;
    display: block;
  }
  #home .drink1 {
    padding: 0;
    margin-bottom: 0;
  }
  #home .drink2 {
    margin-bottom: 0;
  }
  #home .drink .drink1 img {
    margin: 0 auto;
    width: 90%;
  }
  #home .drink .drink2 img {
    margin: 0 auto;
    width: 90%;
  }
  #home .drink-text {
    position: static;
    margin: 0 auto;
    width: 90%;
  }
  #home .drink .more-btn {
    margin-top: 50px;
  }

  /* course ------------- */
  #home .course h3 {
    font-size: 30px;
  }
  #home .course .container section p {
    font-size: 22px;
    line-height: 1.5;
  }
  
  /* shop ----------------------------- */
  .shop-img {
    width: 80%;
    margin: 0 auto;
  }
}

@media screen and (max-width:700px) {
  /* menu ----------------------------- */
  #home .menu .reco {
    width: 20%;
    top: 0px;
    left: 20px;
  }
  #home .menu .container section {
    display: block;
  }
  #home .menu-img {
    width: 80%;
  }
  #home .menu .container .reco-name {
    width: 80%;
    text-align: center;
  }
  #home .menu .container .recommend .reco-name {
    width: 80%;
  }
}

@media screen and (max-width:650px) {
  /* spnav */
  .spnav .line img {
    width: 10%;
  }
  li.web {
    font-size: 20px;
  }
  li.web a {
    line-height: 1.5;
  }
  li.web a > span {
    padding-top: 0;
  }
  li.telephone {
    font-size: 18px;
  }
  li.telephone a {
    line-height: 1.5;
  }
  li.telephone span {
    font-size: 20px;
  }

  /* menu-button */
  #home .more-btn {
    display: block;
  }
  #home .more-btn .more {
    margin: 0;
  }

  /* 予約、問い合わせボタン下部固定 */
  .material-symbols-outlined.md-14,.material-symbols-outlined.md-36 {
    padding: 0;
    font-size: 14px;
  }
  #book-list .tel {
    font-size: 14px;
  }

  /* キャッチコピー */
  #home .copy>p {
    top: 35vh;
    right: 35vw;
    font-size: 30px;
  }
  #home .copy>p.position-c {
    top: 30vh;
    right: 35vw;
  }

  /* Introduction */
  #home .intro .container {
    background: url(../img/intro.png) no-repeat center bottom / 60% auto;
  }
  #home .catch-copy {
    width: 300px;
  }
  #home .intro-text p {
    font-size: 18px;
  }

  /* menu ----------------------------- */
  #home .okada-hudemoji-sp {
    width: 50%;
  }

  /* drink --------------------------- */
  #home .drink h3 {
    font-size: 22px;
  }
  #home .drink-text {
    padding: 30px;
  }

  /* Course -------------------------- */
  #home .course-service,#home .course span {
    font-size: 24px;
    font-weight: bold;
  }

  /* shop-guide ---------------------- */
  #home .slide-img-list >li {
    width: calc(100vw / 2);
  }
  #home .floor> img,.floor> img {
    width: 80%;
    height: 80%;
  }

  /* shop ----------------------------- */
  .shop-img {
    width: 90%;
    margin: 0 auto;
  }
}

@media screen and (max-width:450px) {
  /* 見出し共通 */
  section > h2 {
    font-size: 28px;
    font-weight: bold;
  }
  /* 見出し、本文 共通 */
  section > p ,#home .media >p{
    font-size: 17px;
    line-height: 1.5;
  }

  /* Section共通 */
  #home section {
    padding: 20px 0 10px;
  }
  /* 店舗情報へ飛ぶボタン ---------------- */
.shop-btn a {
  padding: 30px 0 10px 20px;
  right: -30px;
  width: 150px;
  height: 150px;
  font-size: 16px;
  line-height: 1.4;
}
.shop-btn .material-symbols-outlined {
  font-size: 30px;
  padding-left: 40px;
}
.shop-btn .shop-btn-text {
  font-size: 16px;
}

  /* spnav */
  .spnav .line img {
    width: 13%;
  }

  /* キャッチコピー */
  #home .copy>p {
    top: 30vh;
    right: 28vw;
    font-size: 30px;
  }
  #home .copy>p.position-c {
    top: 30vh;
    right: 28vw;
  }

  /* Introduction */
  #home .intro {
    padding: 0;
  }
  #home .intro .container {
    padding: 0 10px 300px;
    background: url(../img/intro.png) no-repeat center bottom / 95% auto;
  }
  #home img.catch-copy {
    margin-bottom: 30px;
    width: 230px;
  }
  #home .intro-text p {
    margin-bottom: 20px;
    font-size: 15px;
  }
  .intro .more {
    padding-top: 50px;
  }

  /* menu ----------------------------- */
  #home .menu .reco {
    width: 15%;
    top: 0px;
    left: 20px;
  }
  #home .menu-img {
    width: 100%;
  }
  #home .menu section h3 {
    font-size: 18px;
  }
  #home .menu .container .reco-name {
    width: 100%;
    text-align: center;
  }
  #home .okada-hudemoji-pc {
    width: 98%;
  } 
  #home .menu .container .recommend .reco-name {
    width: 100%;
  }
  #home .menu section .price {
    font-size: 18px;
  }
  #home .menu section p {
    font-size: 15px;
    line-height: 1.5;
  }

  /* drink --------------------------- */
  #home .drink h3 {
    font-size: 20px;
  }
  #home .drink .container section .price {
    font-size: 18px;
    line-height: 1.5;
  }
  #home .drink .container section p {
    font-size: 15px;
  }
  #home .drink-text {
    padding: 15px;
  }

  /* course ------------- */
  #home .course h3 {
    font-size: 24px;
  }
  #home .course .container section p {
    font-size: 17px;
    line-height: 1.5;
  }
  #home .floor-text h3 {
    font-size: 21px;
  }
  #home .floor-text p {
    font-size: 15px;
  }
  #home .floor-text .number-person {
    font-size: 20px;
  }
  #home .course .container section .price {
    font-size: 20px;
  }
  #home .course .container .recommend .price {
    font-size: 20px;
  }
  #home .course-service,#home .course span {
    font-size: 17px;
    font-weight: bold;
  }

  /* 店舗情報・アクセス */
  .shop-info dt {
    float: none;
    text-align: left;
    margin: 10px;
  }
  .shop-info dd {
    margin: 0 0 10px 30px;
    text-align: left;
    font-size: 15px;
  }
}

/* ================================
  店主のこだわり ページ
 ================================== */
/* Header ------------------------- */
#intro .nav-logo,#menu .nav-logo,#course .nav-logo,#media .nav-logo,#coupon .nav-logo {
  width: 100px;
  height: 130px;
}
#intro .nav-logo img,#menu .nav-logo img,#course .nav-logo img,#media .nav-logo img,#coupon .nav-logo img {
  width: 100%;
}

/* PC Navigation ------------------ */
#intro .pcnav,#menu .pcnav,#course .pcnav,#media .pcnav,#coupon .pcnav {
  display: flex;
  justify-content: center;
}
#intro .pcnav ul,#menu .pcnav ul,#course .pcnav ul,#media .pcnav ul,#coupon .pcnav ul {
  width: 100%;
  height: 130px;
}
#intro .pcnav li,#menu .pcnav li,#course .pcnav li,#media .pcnav li,#coupon .pcnav li {
  font-size: 18px;
}
#intro .pcnav .telephone,#intro .pcnav .web,#intro .pcnav .line,
#menu .pcnav .telephone,#menu .pcnav .web,#menu .pcnav .line,
#course .pcnav .telephone,#course .pcnav .web,#course .pcnav .line,
#coupon .pcnav .telephone,#coupon .pcnav .web,#coupon .pcnav .line,
#media .pcnav .telephone,#media .pcnav .web,#media .pcnav .line {
  margin: 6px 0 0;
  writing-mode: horizontal-tb;
  text-align: center;
  line-height: 1;
  font-size: 16px;
}
#intro .pcnav .telephone a,#menu .pcnav .telephone a,#course .pcnav .telephone a,#media .pcnav .telephone a,#coupon .pcnav .telephone a {
  margin: 0 10px 10px;
  padding: 10px 0 7px;
  box-sizing: border-box;
}
#intro .pcnav .telephone span,#menu .pcnav .telephone span,#course .pcnav .telephone span,#media .pcnav .telephone span,#coupon .pcnav .telephone span {
  display: block;
  font-size: 22px;
  margin-top: 20px;
}
#intro .pcnav .web,#menu .pcnav .web,#course .pcnav .web,#media .pcnav .web,#coupon .pcnav .web {
  padding: 0;
  margin: 0;
}
#intro .web a,#menu .web a,#course .web a,#media .web a,#coupon .web a {
  padding: 6px 13px 5px;
  transition: .3s;
}
#intro .web span,#menu .web span,#course .web span,#media .web span,#coupon .web span {
  display: block;
  margin-bottom: 10px;
}
#intro .pcnav .line span,#menu .pcnav .line span,#course .pcnav .line span,#media .pcnav .line span,#coupon .pcnav .line span {
  display: block;
  line-height: 1.4;
}
#intro .pcnav li.line,#menu .pcnav li.line,#course .pcnav li.line,#media .pcnav li.line,#coupon .pcnav li.line {
  padding: 0;
}
#intro .pcnav .line a,#menu .pcnav .line a,#course .pcnav .line a,#media .pcnav .line a,#coupon .pcnav .line a {
  width: 50px;
  margin-right: 20px;
}
#intro .pcnav .line img,#menu .pcnav .line img,#course .pcnav .line img,#media .pcnav .line img,#coupon .pcnav .line img {
  width: 100%;
}
.sp-logo-mark {
  display: none;
}

/* Main Visual -------------------- */

/* 本文,見出し共通 --------------------- */
#intro h2,#menu h2,#course h2,#media h2,#coupon h2{
  margin: 0;
  padding: 200px 0;
  color: #fff;
  text-align: center;
  font-size: 60px;
  font-weight: bold;
  text-shadow: 0 0 10px #000;
}
#intro h2 {
  padding: 220px 0 180px;
  background: linear-gradient(to left,rgba(0, 0, 0, 0.3),rgba(138, 132, 132, 0.5)),url(../img/person11.webp) no-repeat center / cover;
}
#intro h3,#menu h3,#course h3,#media h3,#coupon h3{
  margin: 0 auto 50px;
  padding-bottom: 10px;
  width: 22rem;
  background-image: url(../img/subtitle-logo01.svg),url(../img/subtitle-logo02.svg);
  background-repeat: no-repeat,no-repeat;
  background-position: left,right;
  font-size: 36px;
  line-height: 36px;
  font-weight: bold;
  text-align: center;
}
#intro .h3-greet {
  width: 14rem;
}
#intro .h3-cooking {
  width: 42rem;
}
#intro .h3-shop-open {
  width: 38rem;
}
#intro .h3-jp {
  width: 24rem;
}
#intro main p ,#menu main p,#course main p,#media main p {
  line-height: 1.5;
  margin-bottom: 20px;
  font-size: 23px;
  font-weight: bold;
  text-align: justify;
}

/* Greet ご挨拶 ---------------------- */
#intro .greet, #intro .cooking,#intro .shop-open,#intro .japanese-food{
  padding: 50px 0;
  background: linear-gradient(135deg,rgba(231, 198, 198,0.6),rgba(255, 255, 255, 0.9)),url(../img/washi01.webp) no-repeat center / cover;
  color: rgb(82, 74, 66);
}
#intro .greet {
  padding: 50px 0 10px;
}
#intro .greet .container {
  /* height: 600px; */
  text-align: right;
  display: flex;
  justify-content: center;
  flex-direction: row-reverse;
  flex-wrap: wrap;
}
#intro .greet-text {
  /* -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl; */
  writing-mode: vertical-rl;
  padding: 10px 15px;
  line-height: 1.7;
  display: inline-block;
  text-align: left;
}
#intro .greet-text p {
  font-size: 20px;
  margin-left: 20px;
}
#intro .greet-text span {
  color: rgb(250, 118, 57);
  font-size: 24px;
}
#intro .greet .container img {
  margin-top: 20px;
  width: 350px;
  height: 500px;
  object-fit: cover;
}

/* 型破りで斬新な日本料理との出会い *//* 独立して創作料理店をオープン */ 
#intro .cooking {
  background: linear-gradient(45deg,rgba(166, 184, 158, 0.8),rgba(255, 255, 255, 0.9)),url(../img/washi02.webp) no-repeat center / cover;
  color: rgb(82, 74, 66);
}
#intro .cooking-item,#intro .shop-open-item,#intro .j-food-item {
  margin-bottom: 50px;
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 50px;
  align-items: center;
}
#intro .cooking-text:last-child,#intro .shop-open-text:last-child,#intro .j-food-text:last-child{
  grid-column: 2/3;
  grid-row: 1;
}
#intro .cooking-img:last-child,#intro .shop-open-item:last-child img, #intro .j-food-item:last-child img{
  grid-column: 1/2;
  grid-row: 1;
}
#intro .cooking-img,#intro .shop-open-img{
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  grid-template-rows: repeat(2,1fr);
  gap: 20px;
}
#intro .cooking-img img:first-child,#intro .shop-open-img img:last-child {
  grid-column: 2/4;
  grid-row: 1;
}
#intro .cooking-img img:last-child,#intro .shop-open-img img:first-child {
  grid-column: 1/3;
  grid-row: 2;
}

/* 日本料理への想い -------------------- */
#intro .japanese-food {
  background: linear-gradient(-45deg,rgba(143, 104, 96,0.8),rgba(255, 255, 255, 0.9) ),url(../img/washi02.webp) no-repeat center / cover;
  color: rgb(82, 74, 66);
}
#intro .name {
  text-align: right;
  font-size: 27px;
}

/* Footer ----------------------------- */
#intro .footer .container {
  margin-bottom: 80px;
}
#intro .footer .shop-info {
  text-align: left;
}
#intro .footer {
  padding-bottom: 20px;
}

@media screen and (max-width:1300px) {
  /* Header */
  #intro .nav-logo img,#menu .nav-logo img,#course .nav-logo img,#media .nav-logo img,#coupon .nav-logo img {
    width: 70%;
  }
  /* pcnav */
  #intro .pcnav li,#menu .pcnav li,#course .pcnav li,#media .pcnav li,#coupon .pcnav li {
    padding:  10px 0;
  }
}

@media screen and (max-width:1100px) {
  /* pcnav */
  #intro .pcnav,#menu .pcnav,#course .pcnav,#media .pcnav,#coupon .pcnav {
    display: none;
  }
  #intro .sp-logo-mark,#menu .sp-logo-mark,#course .sp-logo-mark,#media .sp-logo-mark,#coupon .sp-logo-mark {
    display: block;
    position: absolute;
    width: 15%;
    top: 50px;
    left: 10px;
  }
  #home .sp-logo-mark img,#menu .sp-logo-mark img,#course .sp-logo-mark img,#media .sp-logo-mark img,#coupon .sp-logo-mark img {
    filter: drop-shadow(0 0 5px #fff);
  }
  #intro .greet .container {
    text-align: right;
    display: flex;
    justify-content: center;
    flex-direction: row-reverse;
    flex-wrap: wrap;
  }
  #intro h2,#menu h2,#course h2,#media h2,#coupon h2 {
    font-size: 40px;
  }
  #intro .greet-text {
    display: block;
    writing-mode: horizontal-tb;
  }
  #intro .greet-text p {
    margin: 0 0 10px;
    text-align: center;
    line-height: 1.5;
    font-size: 18px;
  }
  #intro .shop-logo,#menu .shop-logo,#course .shop-logo,#media .shop-logo,#coupon .shop-logo {
    width: 15%;
    margin-bottom: 20px;
  }
  
}
@media screen and (max-width:900px) {
  #intro h2,#menu h2,#course h2,#media h2,#coupon h2{
    font-size: 40px;
  }
  #intro .greet, #intro .shop-open{
    padding: 20px 0 80px;
  }
  #intro .cooking-item,#intro .shop-open-item,#intro .j-food-item {
    text-align: center;
    display: block;
  }
  #intro .cooking-item img,#intro .shop-open-item img,#intro .j-food-item img {
    margin: 0 auto;
    width: 80%;
  }

  #intro .name {
    text-align: right;
    font-size: 22px;
  }
  
}

@media screen and (max-width:767px) {
  /* 各見出し共通 */
  #intro h2,#menu h2,#course h2,#media h2,#coupon h2{
    font-size: 45px;
  }
  #intro h3,#menu h3,#course h3,#media h3,#coupon h3 {
    line-height: 28px;
    font-size: 28px;
  }
  #intro .h3-greet {
    width: 11rem;
  }
  #intro .h3-cooking {
    width: 33rem;
  }
  #intro .h3-shop-open {
    width: 30rem;
  }
  #intro .h3-jp {
    width: 20rem;
  }
  #intro main p ,#menu main p,#course main p,#media main p {
    font-size: 16px;
  }
  #intro .shop-logo {
    width: 25%;
    margin-bottom: 20px;
  }
  #intro .name {
    text-align: right;
    font-size: 18px;
  }
  
}

@media screen and (max-width:600px) {
  /* 各見出し共通 */
  #intro h2,#menu h2,#course h2,#media h2,#coupon h2{
    font-size: 40px;
  }
  #intro h3,#menu h3,#course h3,#media h3,#coupon h3 {
    line-height: 24px;
    font-size: 24px;
  }
  #intro .greet-text span {
    font-size: 18px;
  }
  #intro .h3-greet {
    width: 9rem;
  }
  #intro .h3-cooking {
    width: 21rem;
    line-height: 17px;
    font-size: 17px;
  }
  #intro .h3-shop-open {
    width: 22rem;
    line-height: 20px;
    font-size: 20px;
  }
  #intro .h3-jp {
    width: 17rem;
  }
  #intro .greet-text p {
    margin: 0 0 10px;
    line-height: 1.5;
    font-size: 15px;
  }
}

@media screen and (max-width:450px) {
  #intro .h3-greet,#intro .h3-cooking,#intro .h3-jp,#intro .h3-shop-open {
    margin-bottom: 20px;
  }
  #intro .greet,#intro .cooking,#intro .shop-open,#intro .japanese-food {
    padding: 30px 0;
  }
  #intro .greet-text {
    padding: 10px 15px;
  }
  #intro .greet-text p {
    margin: 0 0 10px;
    line-height: 1.5;
    font-size: 15px;
  }
  #intro .greet-text span {
    font-size: 16px;
  }
  #intro .greet .container img {
    width: 200px;
    height: 300px;
  }
}

/* --------------------------------
  お品書き ドリンク ページ
 ---------------------------------- */
 /* Main Visual -------------------- */
#menu h2 {
  background: linear-gradient(to left,rgba(0, 0, 0, 0.1),rgba(0, 0, 0, 0.5)),url(../img/menu01.webp) no-repeat center / cover; 
}
#menu #drink-menu {
  background: linear-gradient(to left,rgba(0, 0, 0, 0.1),rgba(0, 0, 0, 0.5)),url(../img/drink07.webp) no-repeat center bottom / cover; 
}
  
 /* お品書き　背景色 ---------------- */
#menu .menu-bg ,#menu .drink-bg,#course .course-list,#coupon .coupon-list,#media .media-list{
  padding: 100px 0 50px;
  background: linear-gradient(135deg,rgba(241, 219, 193, 0.8),rgba(255, 255, 255, 0.9)),url(../img/washi03.webp) no-repeat center / cover;
  color: rgb(82, 74, 66);
} 
#menu .menu-bg2 {
  padding: 50px 0;
  background: linear-gradient(135deg,rgba(184, 168, 149,0.8),rgba(255, 255, 255, 0.8)),url(../img/washi03.webp) no-repeat center / cover;
  color: rgb(82, 74, 66);
} 

/* 各見出し共通 ---------------------- */
#menu h3 {
  width: 20rem;
}
#menu h4 {
  margin-bottom: 15px;
  padding: 20px 0;
  background-color: #382424;
  color: #fff;
  font-size: 34px;
  text-align: center;
}
#menu h5 {
  font-size: 28px;
  line-height: 1.5;
}
#menu .menu-bg > p {
  font-size: 22px;
  margin-bottom: 30px;
}

/* ナビゲーション -------------------- */
#menu .menu-nav {
  padding: 0 100px;
  margin-bottom: 50px;
}
#menu .menu-nav ul{
  display: grid;
  grid-template-columns: repeat(9,1fr);
  gap: 5px;
}
#menu .menu-nav li {
  text-align: center;
  font-size: 18px;
  line-height: 20px;
}
#menu .menu-nav li span {
  display: block;
}
#menu .menu-nav a {
  display: block;
  padding: 10px 5px;
  border-radius: 0px;
  background-color: rgb(197, 162, 145);
  color: #333;
  transition: .3s;
}
#menu .menu-nav a:hover {
  background-color: #382424;
  color: #fff;
}

/* ナビゲーション fixed -------------- */
#menu .menu-nav-fixed {
  position: fixed;
  width: 100%;
  top: 150px;
  left: 0;
}
#menu .menu-nav-fixed li {
  margin-bottom: 10px;
  height: 50px;
  font-size: 20px;
  font-weight: bold;
  text-align: right;
}
#menu .menu-nav-fixed a {
  margin-left: -120px;
  padding: 0 10px;
  position: absolute;
  width: 270px;
  left: 0;
  display: block;
  background-color: rgb(197, 162, 145);
  color: #333;
  line-height: 50px;
  border: 2px solid #fff;
  border-radius: 0 50px 50px 0;
  transition: .5s;
}
#menu .menu-nav-fixed a:hover {
  margin-left: -50px;
  background-color: #382424;
  color: #fff;
}

/* layout --------------------------- */
#menu .menu .container,#menu .drink-menu .container {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 30px;
  padding: 0 40px;
}
#menu .menu-bg > p {
  text-align: center;
}
#menu .menu-list section {
  padding: 15px 0;
  border-bottom: 1px dotted rgb(82, 74, 66);
}
#menu .menu-list section:last-child {
  border-bottom: 0;
}
#menu .menu-name {
  display: flex;
  justify-content: space-between;
}
#menu .menu-price {
  font-size: 28px;
  text-align: right;
  line-height: 1.5;
}
#menu .vegetable .menu-name{
  display: block;
}
@media screen and (max-width:1530px) {
  #menu .menu-nav-fixed a {
    margin-left: -230px;
  }
  #menu .menu-nav-fixed a:hover {
    margin-left: -120px;
  }
}

@media screen and (max-width:1290px) {
  #menu .menu-nav {
    padding: 0 10px;
  }
}

@media screen and (max-width:1200px) {
  #menu .menu-name {
    display: block;
  }
}

@media screen and (max-width:1100px) {
  #menu .menu-nav-fixed {
    top: 30px;
  }
}

@media screen and (max-width:1050px) {
  #menu .menu-nav ul{
    grid-template-columns: repeat(5,1fr);
  }
}

@media screen and (max-width:900px) {
  /* ナビゲーション -------------------- */
  #menu .menu-nav {
  padding: 0 10px;
  }
}

@media screen and (max-width:800px) {
  #menu .menu .container,#menu .drink-menu .container {
    gap: 40px;
  }
  #menu h4 {
    font-size: 26px;
  }
  #menu h5 {
    font-size: 24px;
  }
  #menu .menu-price {
    font-size: 20px;
  }
  
}
@media screen and (max-width:767px){
  #menu h3 {
    width: 16rem;
  }
}
@media screen and (max-width:650px){
  /* ナビゲーション -------------------- */
  #menu .menu-nav ul{
    grid-template-columns: repeat(3,1fr);
  }
}

@media screen and (max-width:600px) {
  #menu .menu .container,#menu .drink-menu .container {
    display: block;
  }
  #menu .menu-list section {
    margin: 0 auto;
    width: 85%;
  }
  #menu h3 {
    width: 17rem;
    line-height: 30px;
    font-size: 30px;
  }
  #menu h4 {
    cursor: pointer;
  }

  /* ナビゲーション -------------------- */
  #menu .menu-nav li {
    font-size: 14px;
  }
}

/* --------------------------------
  コース ページ
 ---------------------------------- */
#course h2 {
  background: linear-gradient(to left,rgba(0, 0, 0, 0.3),rgba(114, 110, 110, 0.5)),url(../img/hunamori03.webp) no-repeat bottom center / cover; 
}
#course h3 {
  margin: 0 auto 20px;
}
#course h4 {
  /* text非表示 */
  white-space: nowrap;
  text-indent: 100%;
  overflow: hidden;
}
#course .course-item {
  margin-bottom: 30px;
  padding: 20px;
  background: linear-gradient(to top,rgba(112, 91, 77, 0.7),rgba(209, 180, 147, 0.5)),url(../img/washi02.webp) no-repeat bottom center / cover; 
}
#course .course-item img {
  text-align: center;
  margin-bottom: 20px;
}
#course .course-item .sp-tag {
  display: none;
}
#course .course-detail {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 30px;
  align-items: center;
}
#course .course-detail > img {
  margin: 0 auto;
}
#course .course-text {
  padding: 20px;
  background: linear-gradient(135deg,#fff 30%,rgb(211, 168, 111));
}
#course .course-text li {
  padding: 7px;
  border-bottom: 1px dotted rgb(194, 162, 140);
  font-size: 20px;
  font-weight: bold;
}
#course .course-text li:first-child {
  font-size: 24px;
  font-weight: bold;
}
#course .course-text li:last-child {
  border-bottom: 0;
}
#course .course-list .course-intro {
  margin-bottom: 22px;
  text-align: center;
  font-size: 22px;
}

@media screen and (max-width:1280px) {
  #course .course-detail  {
    display: block;
    text-align: center;
  }
  #course .course-detail > img {
    margin: 0 auto 20px;
  }
  #course .course-text li {
    text-align: left;
  }
}

@media screen and (max-width:1100px) {
  #course .course-item {
    max-width: 900px;
    margin: 0 auto 30px;
  }
  #course .course-item .pc-tag {
    display: none;
  }
  #course .course-item .sp-tag {
    display: block;
    margin: 0 auto 20px;
  }
  #course .course-text {
    max-width: 800px;
    margin: 0 auto;
  }
}

@media screen and (max-width:767px) {
  #course .course-list {
    padding: 50px 0 30px;
  }
  #course .course-text li {
    font-size: 16px;
  }
  #course .course-text li:first-child {
    font-size: 22px;
  }
  #course h3 {
    width: 14rem;
  }
  #course .course-list .course-intro {
    margin-bottom: 18px;
    font-size: 18px;
  }
}

@media screen and (max-width:500px) {
  #course .course-text li {
    font-size: 14px;
  }
  #course .course-text li:first-child {
    font-size: 17px;
  }
  #course .course-list .course-intro {
    margin-bottom: 12px;
    font-size: 10px;
  }
}


/* --------------------------------
  掲載情報 ページ
 ---------------------------------- */
#media h2 {
  background: linear-gradient(to left,rgba(0, 0, 0, 0.1),rgba(0, 0, 0, 0.5)),url(../img/shop19.webp) no-repeat center / cover; 
}
#media h3 {
  width: 32rem;
}
#media h4 {
  margin-bottom: 20px;
  padding: 20px 0;
  background: linear-gradient(to left,rgba(250, 103, 35, 0.527),rgba(224, 169, 86, 0.5)),url(../img/washi01.webp) no-repeat center / cover; 
  font-size: 20px;
}
#media .media-list .container {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 20px;
}
#media .media-list img {
  max-height: 300px;
  margin-bottom: 20px;
}
#media .media-item {
  margin: 0 auto 30px;
  max-width: 500px;
  text-align: center;
}
#media .media-text {
  padding: 15px;
  background-color: rgba(235, 223, 188, 0.5);
  border-top: 1px dotted rgb(71, 44, 29);
  border-bottom: 1px dotted rgb(71, 44, 29);
  text-align: left;
}
#media .media-text dl,#media .media-text p {
  line-height: 1.5;
  font-size: 20px;
}
#media .media-text dt {
  font-weight: bold;
}
#media .media-text dd {
  margin: 0 0 20px 20px;
}
#media .media-text p {
  margin: 0;
}

@media screen and (max-width:767px) {
  #media h3 {
    width: 24rem;
  }
  #media .media-list .container {
    display: block;
  }
  #media .media-item {
    margin-bottom: 50px;
  }
}

@media screen and (max-width:600px) {
  #media h3 {
    width: 20rem;
  }
}
/* --------------------------------
  クーポン ページ
 ---------------------------------- */
/* Main Visual -------------------- */
#coupon h2 {
  background: linear-gradient(to left,rgba(0, 0, 0, 0.3),rgba(114, 110, 110, 0.5)),url(../img/drink05.webp) no-repeat center / cover; 
}

/* layout ------------------------ */
#coupon .coupon-list {
  padding: 30px 0 50px;
}
#coupon .coupon-list p {
  font-size: 21px;
  font-weight: bold;;
}
#coupon .coupon-list p span {
  color: rgb(250, 65, 19);
  text-decoration: underline;
  font-size: 24px;
}
#coupon .coupon-list p .span2 {
  color: rgb(10, 13, 173);
  text-decoration: none;
}
#coupon .coupon-list .container li {
  margin-bottom: 30px;
}
#coupon .coupon-list .container li:last-child {
  margin-bottom: 0;
}
#coupon .coupon-item {
  padding: 20px 0 50px;
}
#coupon .coupon-text {
  max-width: 1200px;
  padding: 20px;
  background-color: rgb(255, 241, 202);
  border: 5px solid rgb(238, 146, 103);
}
#coupon .coupon-text li {
  margin-left: 30px;
  list-style: disc;
}

@media screen and (max-width:767px) {
  #coupon h3 {
    width: 16rem;
  }
}

@media screen and (max-width:600px) {
  #coupon h3 {
    width: 14rem;
  }
}

