@charset "UTF-8";
body {
  color: #25292f;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;

  background-color: #f5f5f5;
  background-image: url(../images/basebg.jpg);
  background-repeat: repeat;
}

html { scroll-behavior: smooth;}

.left {
  float: left;
}

.right {
  float: right;
}

header {
  /*background-image: url(../images/h_bg.png),
  linear-gradient(to top, #eee, #fff);*/
  background-size: 15%;
  color: #333;
}

.header {
  width: 1120px;
    margin: 0 auto;
    position: relative;
    padding-top: 8px;
}

.header h1 {
  font-size: 12px;
  text-align: right;
}

.header .left {
  width: 730px;
  padding-bottom: 10px;
}

.header .right {
  padding-top: 16px;
  text-align: right;
}

.header .time dl {
  font-size: 24px;
}

.header .time dt {
    width: 160px;
    font-size: 20px;
    color: #fff;
    float: left;
    text-align: center;
    padding: 2px 0;
    background-color: #a59988;
}

.header .time dd {
    margin-left: 180px;
}

.header .tel {
  font-size: 40px;
  color: #e20a18;
}

.header .notice {
    position: absolute;
    font-size: 20px;
    color: #333;
    font-weight: bold;
    right: 540px;
    top: 64px;
}

nav {
  margin-bottom: 24px;
}

.g_navi {
    margin: 0 auto;
    background-color: #fefefe;
    border-top: 1px solid #c3944d;
}

.g_navi ul {
    width: 1120px;
    font-size: 0;
    margin: 0 auto;
    display: table;
}

.g_navi li {
    display: table-cell;
    font-size: 16px;
    text-align: center;
    border-left: 1px solid #f0e4d2;
}
.g_navi li:last-child {
    border-right: 1px solid #f0e4d2;
}
.g_navi li:hover {
  background-color: #f6efe5;
}
.g_navi li a {
    padding: 12px 16px;
    display: block;
    color: #fff;
}
.g_navi li a span {
    display: block;
    color: #c3944d;
}
.g_navi li a span:last-child {
    font-size: 12px;
    color: #333;
}

.g_navi .on {
  color: #e3ba69;
}

.main_body {
  width: 1120px;
  margin: 30px auto 0;
  background-color: rgba(255,255,255,0.5);
  box-shadow: 0 0 32px rgba(0,0,0,0.11);
}
.inner_block {
  width: 1080px;
  margin: 0 auto;
  padding: 25px 0 40px;
}
footer {
    padding: 30px 0;
    text-align: center;
    background-color: #463f35;
}

footer .f_navi {
  height: 24px;
}

footer .f_navi:nth-of-type(2) {
  padding-top: 10px;
}

footer .f_navi li {
  display: inline-block;
  padding-right: 10px;
}

footer .f_navi li + li {
  border-left: 2px solid #ffffff;
  padding-left: 12px;
}

footer .f_navi a {
  color: #ffffff;
}

footer .copywriter {
  color: #ffffff;
}

footer .copywriter p:first-child {
  padding-top: 20px;
}

footer .copywriter p:last-child {
  padding-top: 10px;
}

footer .copywriter a {
  color: #ffffff;
}

input,select,textarea  {
    border: 1px solid #ddd;
    border-radius: 4px;
}

h4 {
    font-size: 16px;
    margin-bottom: 4px;
    color: #25292f;
}


.reservation_btn {
  text-align: center;
  margin: 20px 0;
}
.shiny_btn01 img {
    width: 32px;
    vertical-align: middle;
    margin-right: 10px;
}
.shiny_btn01 {
  display: inline-block;
  position: relative;
  width: 100%;
  max-width: 440px; /* ボタン幅 */
  padding-top: 6px;
  line-height: 74px;
  background: linear-gradient(90deg, rgb(251, 141, 59), rgb(255, 182, 37)); /* 背景色 */
  box-shadow: 0 3px 0 0 #ff7c1b; /* 影の色 */
  border-radius: 10px;
  font-weight: bold; /* 文字の太さ */
  font-size: 24px;
  color: #fff !important; /* 文字の色 */
  text-align: center;
  text-decoration: none;
  overflow: hidden;
  transition: 0.3s;
}
.shiny_btn01::before {
  position: absolute;
  content: '';
  display: inline-block;
  top: -180px;
  left: 0;
  width: 30px;
  height: 100%;
  background-color: #fff;
  transition: 0.2s;
  animation: shiny_btn01 3s ease-in-out infinite;
}

/* マウスオーバーした際のデザイン */
.shiny_btn01:hover {
  text-decoration: none;
  color: #fff;
  box-shadow: none;
  -webkit-transform: translateY(3px);
}

/* 光るアニメーション */
@-webkit-keyframes shiny_btn01 {
  0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
  80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
  81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
  100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}
@keyframes shiny_btn01 {
  0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
  80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
  81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
  100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}

.header-center {
  text-align: center;
}
.header-center h1 {
  text-align: center;
}
.header-center .set {
    display: table;
    margin: 0 auto;
}
.header-center .time,
.header-center .tel {
    display: table-cell;
    font-size: 20px;
    padding: 10px;
}
.header-center .time span,
.header-center .tel span {
    font-size: 14px;
    vertical-align: 2px;
    margin-right: 4px;
}
.header-center .time {
}
.header-center .tel {
  color: #333;
}
.notice {
    text-align: center;
    color: #e20a18;
    margin-bottom: 20px;
    margin-top: 20px;
    font-size: 16px;
}
.newopen {
    text-align: center;
    color: #e20a18;
    margin-bottom: 20px;
    margin-top: 20px;
    font-size: 48px;
}