@charset "UTF-8";
body {
  color: #25292f;
  font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ", Meiryo,Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
  background-color: #ffffff;
    background-image: url(../images/bg.jpg);
    background-repeat: repeat;
}
.header {
  position: fixed;
  z-index: 10000;
  width: 100%;
}

.header h1 {
  width: 100%;
  height: 20px;
  line-height: 20px;
  color: #ffffff;
  font-size: 0.8rem;
  font-weight: normal;
  text-align: center;
  background-color: #333;
}

.header .home_nav {
  width: 100%;
  background-color: #eee;
}

.header .box {
  height: 80px;
  text-align: center;
}

.header .box.left {
  float: left;
  width: 30%;
}

.header .box.left a {
    position: relative;
    display: block;
    width: 50px;
    height: 70px;
    margin-left: 0vw;
    margin-top: 5px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.header .box.left img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 30px;
  vertical-align: middle;
}

.header .box.mid {
  float: left;
  width: 40%;
}

.header .box.mid img {
    height: 60px;
    margin-top: 10px;
}

.header .box.right {
  float: left;
  width: 30%;
}

.underlayer {
  padding-top: 140px;
}

.content {
  width: 94%;
  margin: 0 auto;
}

.content h2 {
    width: auto;
    line-height: 1.6;
    text-align: center;
    margin: 0 auto;
    background-color: #b9ccec;
    font-size: 16px;
}

.footer {
  color: #ffffff;
  margin-top: 30px;
  background-color: #429DED;
}

.footer a {
  color: #ffffff;
}

.footer .f_navi {
  width: 96%;
  margin: 0 auto;
}

.footer .f_navi li {
  width: 30%;
  float: left;
  line-height: 1;
  margin-top: 15px;
  text-align: center;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 2px solid #ffffff;
  border-radius: 10px;
}

.footer .f_navi li:nth-of-type(3n-1) {
  margin-left: 5%;
  margin-right: 5%;
}

.footer .f_navi li a {
  display: block;
  padding: 1rem 0;
}

.footer .f_navi li.two-stage {
  padding: 0.5rem 0;
}

.footer .copywriter {
  width: 96%;
  margin: 0 auto;
  padding-top: 15px;
  text-align: center;
  font-size: 0.75rem;
}

.footer .copywriter p:nth-of-type(2) {
  padding-top: 5px;
}

.footer .f_tel {
  margin-top: 10px;
  padding: 8px 0;
  background-color: #4c4b4a;
}

.footer .f_tel a {
  display: block;
  width: 96%;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 2px solid #ffffff;
  border-radius: 5px;
}

.footer .f_tel .btn {
  width: 82%;
  line-height: 1.2;
  float: left;
}

.footer .f_tel .btn a {
  padding: 0.1rem 0;
}

.footer .f_tel .btn .body {
  width: 90%;
  max-width: 14rem;
  margin: 0.2rem auto;
  background-image: url(../images/icon_tel.png);
  background-size: 22px 41px;
  background-repeat: no-repeat;
  background-position: left center;
}

.footer .f_tel .btn .body p:nth-of-type(1) {
  text-indent: 2.2rem;
}

.footer .f_tel .btn .body p:nth-of-type(2) {
  font-size: 1.2rem;
  text-indent: 3.2rem;
}

.footer .f_tel .move_top {
  width: 16%;
  line-height: 1;
  float: left;
  text-align: center;
}

.footer .f_tel .move_top a {
  padding: 0.6rem 0;
}

.footer .f_tel .move_top span {
  display: block;
  font-size: 1rem;
}
.notice {
    position: absolute;
    top: 105px;
    width: 100%;
    text-align: center;
    color: red;
    font-weight: bold;
    font-size: 20px;
}

.header .h_reserve {
	position: absolute;
	top: 50%;
	left: 50px;
}
.header .h_reserve a {
    display: inline-block;
    color: #ffffff;
    padding: 1px 5px;
    border-radius: 5px;
    background-color: #ff3368;
}


.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: 94%;
  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: 22px;
  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; }
}
