body {
    font-family: 'Noto Serif JP', serif;
}

#key h2 {
    top: 54vw;
}

.h2 {
    font-weight: 200;
    font-size: 6vw;
    line-height: 10vw;
    letter-spacing: 0.2em;
}

.desc {
    text-align: justify;
}

#lead {
    background: url("../img/dinner/lead_bg.jpg") no-repeat center top/cover;
    color: #f4ecd9;
    padding: 20vw 0;
}

#lead h2 {
    width: 20vw;
    height: 76vw;
    margin: 0 auto;
}
#lead h2 > span {
    height: 100%;
}

#lead .desc {
    padding-top: 20px;
}

#course {
    background: url("../img/dinner/bg01.jpg") repeat center top;
    padding: 5vw 0 10vw;
}

#course .note {
    text-align: right;
}

#course h2 {
    text-align: center;
    padding-top: 30px;
}

#course h2 img {
    display: block;
    width: 61px;
    margin: 0 auto 10px;
}

#course .box01 {
    padding-top: 10px;
}

#course .box01 h3 {
    color: #806449;
    font-size: 3.5vw;
    line-height: 6vw;
    letter-spacing: 0;
    text-align: center;
}

#course .box01 .plus {
    color: #8a6348;
    font-weight: 200;
    font-size: 63px;
    line-height: 0.8;
    text-align: center;
    padding-bottom: 15px;
}

#course .box01 dl {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    background-color: rgba(255, 255, 255, 0.39);
    position: relative;
}

#course .box01 dl:before {
    content: '';
    width: 100%;
    height: 100%;
    background: url("../img/dinner/course_deco.png") no-repeat center top/100% auto;
    position: absolute;
    top: -16%;
    left: 0;
}

#course .box01 dl>* {
    width: 50%;
    box-sizing: border-box;
}

#course .box01 dl dt {
    padding: 15px 15px;
}

#course .box01 dl dd {
    text-align: center;
    font-size: 3.2vw;
    line-height: 6vw;
    letter-spacing: 0;
}

#course .box02 {
    text-align: center;
    font-size: 13px;
    padding-top: 40px;
    padding-bottom: 50px;
}

#course .box02 h3 {
    font-weight: 200;
    font-size: 20px;
    letter-spacing: 0.2em;
    line-height: 30px;
    padding-top: 30px;
}

#course .box02 .price {
    font-weight: 200;
    font-size: 18px;
    letter-spacing: 0.075em;
    line-height: 30px;
    padding-top: 20px;
}

#course .box02 .txt {
    padding-top: 20px;
}
@media screen and (max-width: 400px) {
    #course .box02 .txt:last-child {
        font-size: 12px;
    }
}

#whisky {
    background: url("../img/dinner/whisky_bg.jpg") no-repeat center top/cover;
    color: #fff;
    padding-bottom: 10vw;
}

#whisky h2 {
    width: 20vw;
    height: calc(60vw + 50px);
    margin: 0 5vw 0 auto;
    padding-top: 50px;
    position: relative;
}

#whisky h2:before {
    content: '';
    width: 0;
    height: 50%;
    border-left: 1px solid #fff;
    position: absolute;
    top: 0;
    right: 8px;
}

#whisky h2 span {
    background-color: #251606;
    margin-top: 30px;
    padding: 10px 0;
}

#whisky .desc {
    padding-top: 80px;
}

#whisky .bnr {
    width: 80%;
    margin: 0 auto;
    padding: 20px 0 0;
}

#other {
    padding: 10vw 0;
}

#other h2 {
    font-family: 'Libre Baskerville', serif;
    font-weight: 400;
    text-align: center;
}

#other h2 img {
    display: block;
    width: 60px;
    margin: 0 auto;
    padding-bottom: 10px;
}

#other .note {
    text-align: center;
    padding: 15px 0 30px;
}

#other .row {
    background: url("../img/dinner/other_bg.jpg") repeat center top;
    color: #fff;
    padding-bottom: 40px;
}

#other .row h3 {
    font-weight: 200;
    font-size: 18px;
    letter-spacing: 0.2em;
    line-height: 30px;
    text-align: center;
    padding-top: 40px;
}

#other .row .price {
    font-weight: 200;
    font-size: 17px;
    letter-spacing: 0.075em;
    line-height: 30px;
    text-align: center;
    padding-top: 15px;
}

#other .row .txt {
    font-size: 13px;
}

#other .row .txt p {
    padding-top: 20px;
}

#other .pairing_set {
    text-align: center;
    border-top: 2px solid #351809;
    border-bottom: 2px solid #000;
    margin: 40px 0;
    padding: 30px 0;
    position: relative;
}

#other .pairing_set:before {
    content: '';
    border-top: 2px solid #351809;
    border-bottom: 2px solid #000;
    position: absolute;
    top: 2px;
    right: 0;
    bottom: 2px;
    left: 0;
}

#other .pairing_set h3 {
    font-family: 'Libre Baskerville', serif;
    font-weight: 400;
    font-size: 20px;
    letter-spacing: 0.075em;
    line-height: 30px;
}

#other .pairing_set ul {
    padding-top: 20px;
}

#link {
    background: url("../img/dinner/link_bg.jpg") no-repeat center top/cover;
    color: #fff;
    text-align: center;
    padding: 18vw 0;
    margin-bottom: -1px;
}

#link h2 {
    font-size: 5vw;
}

#link .txt {
    font-size: 10px;
    line-height: 20px;
    padding-top: 20px;
}

#link ul {
    padding-top: 20px;
}

#link ul li {
    padding-top: 10px;
}


#menu {
  padding: 60px 0;
}

#menu h2 {
  font-weight: 600;
  margin-bottom: 30px;
  padding-bottom: 40px;
  position: relative;
  font-size: 25px;
  text-align: center;
}

#menu h2::before {
  content: '';
  width: 1px;
  height: 30px;
  position: absolute;
  left: 50%;
  bottom: 0;
  background: #000000;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

#menu h3 {
  font-size: 16px;
  font-weight: 600;
}

#menu .toggle .toggle-link {
  text-align: center;
}

#menu .toggle .toggle-link::after {
  display: none;
}

#menu .toggle .toggle-link .triangle {
  width: 0;
  height: 0;
  -webkit-transition: .5s all;
  transition: .5s all;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 15px solid #707070;
  margin: 20px auto 0;
}

#menu .toggle.active .toggle-link .triangle {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

#menu .list .item {
  margin-bottom: 30px;
}

#menu .list .item h3 {
  font-weight: bold;
  border-bottom: 2px solid #595752;
  padding-bottom: 10px;
  line-height: 20px;
  font-size: 15px;
}

#menu .list .item dl {
  border-bottom: 1px solid #595752;
  padding: 11px 0;
  line-height: 30px;
  font-size: 14px;
}

#menu .list .item dl dt {
  float: left;
  text-align: left;
}

#menu .list .item dl dd {
  float: right;
  text-align: right;
}

.tax_b a{
	font-size: 110%;
	color: #B8080B;
	font-weight: bold;
	text-decoration: underline;
}

.txt_coupon{
    font-weight: bold;
    color: #B10D10;
    background-color: rgba( 255, 255, 255, 0.8 );
    padding: 0 5px !important;
}
.txt_coupon2{
    font-weight: bold;
    color: #B10D10;
    background-color: rgba( 255, 255, 255, 0.8 );
    padding: 0 5px !important;
}