@charset "UTF-8";

html{scroll-behavior: smooth;}

* {box-sizing: border-box;}

body {font-family: "Noto Serif JP", "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6",serif;
  background-color: #fafaf2;
  font-size: 16px;
}

img{
  width: 100%;
}

a{
  text-decoration: none;
  transition: 0.5s ease;
}

a:hover{
  opacity: 0.5;
}

/* ヘッダー */
/* .header{
  width: 100%;
  height: 100vh;
  background-repeat:no-repeat;
  background-image: url(../image/top-wappameshi.jpg);
  background-size: cover;
} */

.header {
  width: 100%;
  height: 900px;
  background-image: url(../image/top-wappameshi.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-size: cover;
}

.header-title{
  display: flex;
  justify-content: space-between;
  padding: 5px 0 5px;
  background-color: #ffffffca;
  position: sticky;
  top: 0;
  opacity: 0.8;
  z-index: 9999;
}

.title-logo{
  margin: 0px 20px;

}

.title-logo h1{
  font-family: "Noto Serif JP", "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6", serif;
  color: #282828;
  margin: 0.3em 1em;
}

/* ナビゲーション */

.gnav-navi ul {
  display: flex;
  margin: 25px;
}

.gnav-navi ul li a{
  margin: 0 10px;
  color: #333;;
}

/* ごあいさつ */
.title{
  font-family: "Noto Serif JP", "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6", serif;
  font-size: 1.5vw;
  font-style: normal;
  width: 100wh;
  text-align: center;
  margin: 50px auto 80px ;
}

.title-line{
    align-items: center; /* 横線を上下中央 */
    display: flex; /* 文字と横線を横並び */
    justify-content: center; /* 文字を中央寄せ */
  }
  .title-line::before,
  .title-line::after {
    background-color: #3a3a3a; /* 横線の色 */
    content: "";
    height: 1px; /* 横線の高さ */
    width: 70px; /* 横線の長さ */
  }
  .title-line::before {
    margin-right: 20px; /* 文字との余白 */
  }
  .title-line::after {
    margin-left: 20px; /* 文字との余白 */
  }

.greeting{
  background-color: #ffffff;
  padding: 40px 0 100px 0;
}

.greeting-content{
  display: flex;
  justify-content: center;
}

.greeting-image{
  width: 40%;
}

.greeting-coment{
  /* width: 40%; */
  line-height: 1.8;
  margin: 0 0 0 100px;
}

.greeting-coment p{
  font-family: "Noto Serif JP", serif;
  font-size: 1.3vw;
}

span.message{
  font-size: 1.7em;
  line-height: 4.0;
  font-style: bold;
}

/* 吉田屋の名物 */
.specialty{
  padding: 40px 0 0 0;
  margin: 0 0 100px 0;
}

.specialty-detail{
  display: flex;
  justify-content:center;
  margin: 30px 60px;
}

h3{
  font-size: 1.8vw;
  background: linear-gradient(transparent 70%, rgb(255, 255, 141) 30%);
  display: inline-block;
}

.specialty-coment p{
  font-size: 1.4vw;
  line-height: 2.0;
}

.specialty-image{
  width: 50%;
  margin: 10px auto;
}

.specialty-image img{
  border-radius: 20px;
} 

.specialty-coment{
  width: 50%;
  text-align: center;

  padding: 40px;
}



/* メニュー */

.menu-content{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 10px;
}

.menu-image{
  width: 33%;
}

.menu-image p{
  text-align: center;
  margin: 0 auto 20px;
}

.pdf{
  text-align: right;
  margin: 20px;
}

.pdf p{
    text-decoration:underline 1px #333 ;
}

/* 伊彌彦米コンテンツ */

.iyahikomai{
  background-color: #ffffff;
  margin: 100px auto 100px;
  padding: 100px 50px 100px;
  text-align: left;
}

span.iyahikomai{
  font-size: 3vw;
  padding: 0;
  margin: 0 0 0 50px;
}

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

.iyahikomai-text{
  width: 50%;
  font-size: 1.3vw;
  margin: 0 0 0 100px;
  line-height: 2;
}

.iyahikomai-image{
  text-align: center;
}

.iyahikomai img{
  width: 80%;
}

/* お席 */
.seet-content{
  display: flex;
  margin: 0 auto 100px;
}

.seet-content p{
  text-align: center;
  margin: 0 auto;
}


/* アクセス */
.access{
  background-color: #ffffff;
  padding: 50px 0 150px 0;
}

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

.access-text {
  display: flex;
  flex-wrap: wrap;
  font-size: 1.3vw;
}


th{
  text-align: right;
  width: 130px;
  padding: 10px;
}

th,td{
  height: 50px;
}

.access-map{
  width: 40%;
}


/* footer */
footer{
  display: flex;
  padding: 10px 0 10px 50px;
  background-color: #c2c2c2b5;
  text-align: center;
}

.footer-logo h2{
  font-family: "Noto Serif JP", serif;
}

.smartphone-only {
  display: none;
}

a[href*="tel:"] {
  pointer-events: none;
  text-decoration: none;
  color:#282828
  }


/*　画面サイズが480px以下　スマホ用*/
@media screen and (max-width: 480px) {
  /* * {
    border: 1px solid #00f;
  } */

  a[href*="tel:"] {
    pointer-events: initial;
    color: blue;}

/*header*/
.header {
  width: 100%;
  background-image: none;
  height: auto;
}

.smartphone-only {
  display: block;
  width: 100%;
  height: auto;
}

.header-title {
  display: none;
}

  
.title{
  margin: 1vh auto 1vh ;
  font-size: 15px;
}


/* ごあいさつ */

.title.pc{
 display: none;
}

.greeting {
  width: 100%;
  padding: 2vh 0;
}

.greeting-content{
  display: flex;
  flex-direction:column-reverse;

}

.greeting-image{
  width: 100%;
}

.greeting-coment{
  width: 90%;
  margin: 0 20px;
}

.greeting-coment p{
  font-size: 12px;
  margin: 0 0 4vh 0;
}

/* 名物 */
.specialty{
  padding: 0;
  margin: 0;
}

.specialty-detail{
  display: flex;
  flex-direction: column;
  margin: 0;
  text-align: center;
}

.specialty-detail.ika{
  flex-direction:column-reverse;
}

.specialty-detail.unaju{
  flex-direction:column-reverse;
}


.specialty-image {
  width: 90%;
  margin:10px auto 0
}

.specialty-coment{
  width: 100%;
  padding: 0;
  border-bottom: 1px dotted rgb(110, 110, 110);
}

.specialty-coment h3{
  font-size: 4.5vw;
  margin: 0;
}

.specialty-coment p{
  margin:1em 0 2em;
  font-size: 3.5vw;
}

/* メニュー */
.menu{
  font-size: 14px;
}

.menu-content{
  margin: 0;
  justify-content:center;
}

.menu-image{
  width: 47%;
  margin: 2px;
}


/* 伊彌彦米 */

.iyahikomai{
  width: 100%;
  padding: 4vh 0 0 0;
  margin: 4vh 0;
}

.iyahikomai-content{
  display: block;
  text-align: left;
  margin: 30px 10px;
  padding: 0 0 30px 0;
}

.iyahikomai-text{
  width: 90%;
  margin: 0 0 0 30px;
}

span.iyahikomai{
  font-size: 18px;
  padding: 0;
  margin: 10px;
}

.iyahikomai-text p{
  font-size: 14px;
}

.iyahikomai img{
  width: 100%;
}

/* お席 */
.seat{
  padding: 0 0 30px 0;
}

.seet-content p{
  font-size: 3vw;
}

.seet-content{
  display: flex;
  flex-wrap: wrap;
  margin: 0;
}

.seet-image{
  width: 50%;
}

/* アクセス */
.access-content {
  width: 90%;
  display: flex;
  flex-direction: column;
  margin: 20px;
}

.access-text{
  font-size: 3vw;
}

th, td {
  height: 0;
}

th{
  width: 90px;
}

td{
  width: 65vw;
}

.access-map{
  width: 90%;
  height: 300px;
  margin: 20px auto;
}

.title.kappou h2{
  font-size: 4vw;
}

.access{
  padding: 50px 0 50px 0;
}

/* hamburger button ----------*/

  /* g-nav */

  #g-nav {
    position: fixed;
    z-index: 999;
    top: 0;
    right: -100%;
    width: 100%;
    height: 100vh;
    background: #dededecb;
    transition: all 0.6s;
  }

  #g-nav.panelactive {
    right: 0;
  }

  #g-nav ul {
    position: absolute;
    z-index: 99;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding: 0;
  }

  #g-nav li {
    list-style: none;
    text-align: left;
    font-size: 20px;
    line-height: 2em;
  }

  #g-nav li a {
    position: relative;
    color: #333;
    text-decoration: none;
    padding: 10px;
    display: block;
    text-transform: uppercase;
    font-weight: bold;
  }

  #g-nav li a:hover {
    color: #888;
  }

  #g-nav li a::after {
    content: '';
    position: absolute;
    bottom: 5%;
    left: 5%;
    width: 100%;
    height: 2px;
    background: #888;
    transition: all .3s;
    transform: scale(0, 1);
    transform-origin: left top;
  }

  #g-nav li a:hover::after {
    transform: scale(1, 1);
  }

  /* openbtn */
  .openbtn {
    position: fixed;
    z-index: 9999;
    top: 0%;
    right: 1%;
    cursor: pointer;
    width: 70px;
    height: 50px;
  }

  .openbtn span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
    background-color: #333;
    width: 45%;
  }

  .openbtn span:nth-of-type(1) {
    top: 15px;
  }

  .openbtn span:nth-of-type(2) {
    top: 23px;
  }

  .openbtn span:nth-of-type(3) {
    top: 31px;
  }

  .openbtn.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
  }

  .openbtn.active span:nth-of-type(2) {
    opacity: 0;
  }

  .openbtn.active span:nth-of-type(3) {
    top: 30px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
  }



  /* footer */
footer {
  display: block;
  padding: 10px;
  width: 100%;
}

.footer-logo h2{
  font-size: 3vw;
}

.gnav-navi{
  width: 100%;
}

.gnav-navi ul {
  margin: 0;
}
.gnav-navi ul li{
  font-size: 10px;
}
}