
:root{
    --font-family-sans-serif: 'Noto Serif JP';
    --font-family-monospace: 'Roboto Mono';
}

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

h1, h3, h4, h5, h6 {
  font-family: 'Noto Serif JP';
}

h2 {
  font-family: 'Roboto Mono';
}

img{
  width: 100%;
}

a{
  color: #1D1D1D;
}

.title-sp{
  width: 150px;
  height: auto;
}

.navbar-light .navbar-toggler{
  color: #fff;
  border-color: #fff;
}
.navbar{
  background-color: #fff;
}
#navbarNav2{
  background-color: #fff;
}

button.navbar-toggler{
  padding-left: 0;
  padding-right: 0;
}

.navbar-light .navbar-nav .nav-link{
  color: #1D1D1D;
}
.nav-item{
  padding-top: 6px;
  padding-bottom: 6px;
}

span.marker{
background: linear-gradient(transparent 50%, #ffff8d 50%);
}
span.marker-top{
background: linear-gradient(transparent 10%, #fcc 10%);
}
.top-bg-wrap{
  margin-bottom: 40px;
  margin-top: 40px;
}
.top-bg-img{
  background-image: url('../img/top.jpg');
  height: 540px;
  width: 100%;
  background-repeat: no-repeat;
  background-position: 55% 50%;
  background-size: cover;
}
.top-logo{
  width: 125px;
  height: auto;
  margin-bottom: 6px;
}

.top-logo > img{
  width: 100%;  margin-top: 15px;
}


.top-title{
  position: relative;
  max-width: 300px;
  margin-bottom: 10px;
}

.top-title img{
  display: block;
  width: 100%;
  height: auto;
}

.top-gabbeh{
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 22.14%;
}
a.top-gabbeh{
  transition: opacity 0.2s;
}
a.top-gabbeh:hover{
  opacity: 0.8;
}


.top-day{
  font-size: 21px;
  line-height: 1;
  margin-bottom: 20px;
  font-weight: bold;
}

span.sat{
  color: #03c;
}

span.sun{
  color: #c00;
}

.top-time{
  font-size: 14px;
  font-weight: bold;
}

.top-res-sub{
	margin: 50px 0 0 0;
}
.top-res-sub a{
	display: block;
	width: 220px;
	background: #191C88;
	border-radius: 10px;
	transition: .25s;
}
.top-res-sub a:hover{
	opacity: 0.85;
}
.top-res-sub img{
	display: block;
	width: 100%;
	height: auto;
}

.bg-sub{
  background-color: #EDF1FD;
}
.bg-res{
  background-color: #191C88;
}

.head-img{
  padding-left: 0px;
  padding-right: 0px;
}

h2.head-h2{
  font-size: 18px;
  color:#777777;
  font-family: 'Roboto Mono';
  letter-spacing: 2px;
  margin-bottom: 16px;
  margin-top: 30px;
}
h3.head-h3{
  font-size: 21px;
  line-height: 1.5;
  font-weight: bold;
}

h3.head-h3-small{
  margin-top: 30px;
  font-size: 17px;
  margin-bottom: 16px;
  font-weight: bold;
  line-height: 1.5;
}


.head-text{
  margin-top: 30px;
  font-size: 15px;
  letter-spacing: 1.5px;
  line-height: 1.8;
}



.res-comm{
  font-size: 18px;
  text-align: center;
  color: #fff;
  margin-bottom: 20px;
}
.res-text{
  color: #fff;
  text-align: center;
}
.res-btn-wrap{
  display: flex;
  justify-content: center;
  margin-top: 20px;
}
.btn-res{
  width: 250px;
  height: 70px;
  background-color: #fff;
  color: #191C88;
  display: block;
  text-align: center;
  font-size: 24px;
  line-height: 1;
  padding-top: 23px;
  letter-spacing: 6px;
}

.btn-res:hover{
  opacity: 0.8;
}

.res-text-sub{
  font-size: 14px;
  color: #fff;
  margin-top: 6px;
  text-align: center;
}

.head-h3-sub{
  font-size: 16px;
}



.flow-wrap{
  position: relative;
  padding: 10px;
}

.flow-wrap-last{
  position: relative;
  padding: 10px;
}

.flow-wrap:before{
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-bottom: -10px;
  margin-left: -10px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 10px 0 10px;
  border-color: #7c88a3 transparent transparent transparent;
}


.flow-step{
  text-align: center;
  font-size: 24px;
  color: #7C88A3;
  line-height: 1;
}


.flow-num{
  text-align: center;
  font-size: 70px;
  color: #7C88A3;
  line-height: 1;
}

.flow-day{
  text-align: center;
  font-size: 18px;
  margin-top: 10px;
  font-weight: bold;
  margin-top: 24px;

}
.flow-day span{
  background-color: #ABD3F0;
  padding-right: 10px;
  padding-left: 10px;
}

h4.head-h4{
  padding-top:14px;
  font-size: 18px;
  font-weight: bold;
}

.p-st{
  font-size: 15px;
  margin-top: 20px;
  line-height: 1.8;
}

.voice-name{
  font-size: 14px;
  color: #1D1D1D;
}

.pdf-btn-wrap{
  display: flex;
  justify-content: center;
}

.btn-pdf{
  width: 250px;
  background-color: #CCCCCC;
  text-align: center;
  color: #1D1D1D;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-top: 30px;
}



.btn-pdf > i{
 margin-left: 8px;

}


.change-arrow:before{
  content: '';
  position: absolute;
  top: 50%;
  left: 100%;
  margin-left: -4px;
  margin-top: -20px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 0 10px 10px;
  border-color: transparent transparent transparent #7c88a3;
}

.change-before{
  color: #03c;
}

.change-after{
  color: #c00;
}


.head-text-big{
  line-height: 3;
}




.text-nowrap{
  word-wrap: break-word;
  letter-spacing: 2px;
}

footer{
  background-color: #9194AA;
}

.bg-footer{
  background-color: #9194AA
}

.footer-logo{
  width: 120px;
}

.footer-address{
  font-size: 14px;
}
.footer-tel{
  font-size: 20px;
  color: #1D1D1D;
}
.footer-tel:hover,
.footer-tel:visited{
  opacity: 0.8;
}

.footer-day{
  font-size: 14px;
}
footer .btn-map{
  font-size: 21px;
  color: #191C88;
 line-height: 1.5;
 margin-left: 6px;
}

/* ページネーション */


/* グーグルマップレスポンシブ */
.ggmap {
position: relative;
padding-bottom: 56.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}

.ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}



@media (min-width: 768px) {

div.top-logo{
  margin-bottom: 20px;
}

 .top-bg-wrap{
  /* margin-top: 40px; */
  margin-left: 20px;
  margin-right: 20px;
 }
  .top-bg-img{
    height: 680px;
  }

  .top-title{
    max-width: 360px;
  }

  .head-img{
    padding-left: 15px;
    padding-right: 15px;
  }


  .flow-wrap:before{
    content: '';
    position: absolute;
    top: 50%;
    left: 100%;
    margin-left: 8px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 0 10px 10px;
    border-color: transparent transparent transparent #7c88a3;
  }

  .btn-res{
    width: 300px;
  }

	.top-res-sub{
		margin: 170px 0 0 0;
	}
	.top-res-sub a{
		width: 300px;
	}

}


@media (min-width: 992px) {

.navbar{
  background-color: #fff;
}


div.top-logo{
  padding-top: 20px;
  margin-bottom: 30px;
}

  .nav-item{
    padding-top: 10px;
    padding-bottom: 10px;
    padding-right: 10px;
  }

 .top-bg-wrap{
  margin-right: 40px;
  margin-left: 40px;
  margin-top: 80px;
 }
  .top-bg-img{
    height: 900px;
  }
  .top-logo{
    width: 300px;
  }
/*   .top-sub{
    font-size:30px;
  } */
  .top-title{
    max-width: 550px;
  }
  .top-day{
    font-size: 40px;
    margin-bottom: 10px;
  }

  .top-time{
    font-size: 21px;
  }
  h2.head-h2{
    margin-top: 0px;
  }

  h3.head-h3{
    font-size: 24px;
  }


  h3.head-h3-small{
    margin-top: 30px;
    line-height: 1.8;
    font-size: 21px;
    margin-bottom: 16px;
    font-weight: bold;
	}

	.top-res-sub{
		margin: 150px 0 0 0;
	}
	.top-res-sub a{
		width: 320px;
	}

}



@media (min-width: 1200px) {
  div.top-logo{
    padding-top: 40px;
    margin-bottom: 40px;
  }
.title-sp{
  padding-left: 20px;
}

 .top-bg-wrap{
  /* margin-top: 60px; */
  /* width: 1200px; */
/*   margin-right: 100px;
    margin-left: 50px; */
 }

  .navbar-nav{
    padding-right: 20px;
  }

}

@media (min-width: 1540px) {
 .top-bg-wrap{
/*   width: 1500px;
  margin: 60px auto; */
 }

}



/* ハンバーガーメニュー */

nav{
 width: 100%;
 height: 60px;
 position: relative;
 background: #fff;
 position: fixed;
 z-index: 10;
 top: 0;
 left: 0;
}
.drawer{
 display: flex;
 flex-direction: row;
 align-items: center;
 justify-content: space-between;
 position: relative;
 height: 60px;
 padding: 0 1em;
}


.navbar_toggle{
 z-index:9999;
}
.navbar_toggle_icon {
 position: relative;
 display: block;
 height: 2px;
 width: 30px;
 background: #5c6b80;
 -webkit-transition: ease .5s;
 transition: ease .5s;
}
.navbar_toggle_icon:nth-child(1) {
 top: 0;
}
.navbar_toggle_icon:nth-child(2) {
 margin: 8px 0;
}
.navbar_toggle_icon:nth-child(3) {
 top: 0;
}
/*OPEN時の動き*/
.navbar_toggle.open .navbar_toggle_icon:nth-child(1) {
 top: 10px;
 -webkit-transform: rotate(45deg);
 transform: rotate(45deg);
}
.navbar_toggle.open .navbar_toggle_icon:nth-child(2) {
 -webkit-transform: translateY(-50%);
 transform: translateY(-50%);
 opacity: 0;
}
.navbar_toggle.open .navbar_toggle_icon:nth-child(3) {
 top: -10px;
 -webkit-transform: rotate(-45deg);
 transform: rotate(-45deg);
}


.menu{
 -webkit-transform: translateX(-100%);
 transform: translateX(-100%);
 -webkit-transition:ease .5s;
 transition:ease .5s;
 z-index:1000;
}
.menu ul{
  list-style-type: none;
  padding-left: 0;
}
.menu ul li{
 padding: 1em;
 border-bottom: 1px solid #CCC;
}
/*OPEN時の動き*/
.menu.open {
 -webkit-transform:translateX(0);
 transform:translateX(0);
 overflow-y: auto;
 -webkit-overflow-scrolling: touch;
 background-color: #fff;
}


@media screen and (min-width: 992px) {
  nav{
   display: flex;
   flex-direction: row;
  }
  .navbar_toggle{
   display: none;
  }
  .menu{
   width: 100%;
   -webkit-transform: translateX(0);
   transform: translateX(0);
  }
  .menu ul{
   height: 70px;
   display: flex;
   flex-wrap: wrap;
   justify-content: flex-end;
   align-items: center;
  }
  .menu ul li{
   padding: 0 1em;
   border-bottom: none;
  }
}


/* 追記20201020 */
.reserve{
	margin: 0 auto;
	display: flex;
	max-width: 550px;
	justify-content: center;
	align-items: center;
}
.reserve-photo{
	width: 40%;
	padding-right: 20px;
}
.reserve-photo img{
	display: block;
	width: 100%;
	height: auto;
}
.reserve-body{
	width: 60%;
}
.rusk-comment{
	margin: 0 0 20px;
	position: relative;
}
.rusk-comment::before{
	content: "";
	display: block;
	position: absolute;
	left: -30px;
	top: 50%;
	margin-top: -10px;
	width: 30px;
	height: 20px;
	background: url(../img/rusk_comment_arrow.png) no-repeat right center / 100% 100%;
}
.rusk-comment p{
	background: #FFE000;
	margin: 0;
	padding: 8px 5px;
	font-size: 13px;
	font-weight: bold;
	text-align: center;
	border-radius: 5px;
}
.rusk-comment p span{
	font-size: 1.4em;
}
@media screen and (max-width: 320px){
	.rusk-comment p{
		font-size: 12px;
	}
	.rusk-comment p span{
		font-size: 1.3em;
	}
}
.reserve-btn{
	margin: 0 0 10px;
	padding: 0 8px;
}
.reserve-btn a{
	display: block;
	height: 60px;
	background-color: #fff;
	color: #191C88;
	text-align: center;
	font-size: 24px;
	letter-spacing: 6px;
	line-height: 60px;
	transition: .25s;
}
.reserve-btn a:hover{
	opacity: 0.85;
}
.reserve-sub{
	font-size: 13px;
	color: #fff;
	margin: 0;
	text-align: center;
}
.reserve-arrow{
	display: inline-block;
	width: 20px;
	height: 20px;
	background: url(../img/reserve_arrow.png) no-repeat center / 100% 100%;
	vertical-align: -3px;
	margin: 0 0 0 5px;
}

@media screen and (max-width: 320px){
	.reserve-sub{
		font-size: 10px;
	}
}
@media screen and (min-width: 321px) and (max-width: 400px){
	.reserve-sub{
		font-size: 11px;
	}
}
@media screen and (min-width: 480px){
	.reserve-photo{
		padding-right: 30px;
	}
	.rusk-comment p{
		padding: 10px;
		font-size: 15px;
	}
	.rusk-comment{
		margin: 0 0 30px;
	}
	.rusk-comment p{
		padding: 15px;
		font-size: 16px;
	}
	.reserve-btn a{
		height: 70px;
		line-height: 70px;
	}
}
