@charset "UTF-8";
/*-------------------------------
          styles 2019
-------------------------------*/

@import url('https://fonts.googleapis.com/css?family=Sawarabi+Gothic');
@import url('https://fonts.googleapis.com/css?family=Quicksand:700');
@import url('https://fonts.googleapis.com/css?family=M+PLUS+1p:100,400');
@import url('https://fonts.googleapis.com/css?family=Noto+Serif+JP');

/*.change {
    position: relative;
}

.cursor {
	cursor: url(../common/mouse.png),auto;
}*/

#wrapper {
	width: 100%;
	height: 100%;
	position: relative;
}

h2 {
	height: 100px;
	line-height: 3rem;
	font-size: 3rem;
	text-align: center;
	border-bottom: 1px solid #008463;
}

h3 {
	margin-bottom: 40px;
	font-size: 36px;
	text-align: center;
}

#link ul li:hover {
	color: white;
	background-color: #F39800;
}

#cont_wrap {
	position: relative;
	overflow: hidden;
}

/*-- header --*/

header {
	width: 100%;
	height: 100%;
	position: fixed;
	overflow: hidden;
	top: 0;
	z-index: 0;
}

header #logo {
	float: left;
	width: 6%;
	height: 100px;
	padding: 20px 2%;
	background: url(../images/logo.gif) center center no-repeat;
	background-size: 80px auto;
	border-bottom: 1px solid #008463;
	text-align: center;
}

header #logo a {
	width: 100%;
	height: 100%;
	display: block;
	text-indent: -9999px;
}

/*-- nav --*/

nav {
	position: relative;
}

#gnav {
	position:relative;
	float: right;
  	width:10%;
  	height:100%;
}

#sp_gnav {
	display: none;
}

nav ul {
	width: 10%;
	position:absolute;
	top: 5%;
	bottom: 5%;
	right: 50%;
	height: 90%;
	text-align: center;
	display: table;
	-webkit-writing-mode: vertical-rl;
	-moz-writing-mode: vertical-rl;
  	-ms-writing-mode: tb-rl;
  	-ms-writing-mode: vertical-rl;
  	writing-mode: vertical-rl;
  	transform: translate(50%, 5%);
	-webkit-transform: translate(50%, 5%);
	-moz-transform: translate(50%, 5%);
	-o-transform: translate(50%, 5%);
	-ms-transform: translate(50%, 5%);
}

nav ul li {
	font-size: 12px;
	display: table-cell;
	padding-bottom: 10px;
}

nav ul li:last-child {
	padding-bottom: 0;
}

/*-- nav end --*/
/*-- header end --*/

/*-- main --*/
main {
	position: relative;
	width: calc(80% - 2px);
	height: 100vh;
	border-right: 1px solid #008463;
	border-left: 1px solid #008463;
	position: relative;
	left: 10%;
	right: 10%;
	line-height: 2em;
	z-index: 300;
	overflow: auto;
}

.info {
	margin: 100px 0;
	text-align: center;
}

.info img {
	width: 50%;
	margin: 0 auto;
}

article.cont {
	padding: 3%;
	margin-bottom: 100px;
	overflow: hidden;
}

.reserve ul {
	display: flex;
	flex-wrap: nowrap;
}

.reserve ul li {
	width: calc(100%/4);
	margin: 0 10px 60px 0;
	text-align: center;
}

.reserve ul li:last-child,
.reserve .webreserve ul li:last-child {
	margin-right: 0;
}

.reserve ul li img {
	width: 100%;
}

.reserve .webreserve ul {
	width: 90%;
	margin: 10px auto 0;
}

.reserve .webreserve ul li {
	width: calc(100%/2);
	margin: 0 10px 0 0;
	text-align: center;
	font-size: 14px;
	background-color: #008463;
	border-radius: 20px;
	-webkit-border-radius: 20px;
	-mos-border-radius: 20px;
	-o-border-radius: 20px;
	-ms-border-radius: 20px;
}

.reserve .webreserve ul li:hover {
	color: white;
	background-color: #F39800;
}

.reserve .webreserve ul li a {
	color: white;
}

.cont section {
	height: 100px;
	border-top: 1px solid #EEE;
	line-height: 100px;
	overflow: hidden;
}

section.high {
	height: 150px;
}

section.high dt {
	line-height: 150px;
}

section.high dd {
	padding: 50px 0;
	line-height: normal;
}

section.end {
	border-bottom: 1px solid #EEE;
}

section dt {
	float: left;
	width: 30%;
}

section dd {
	float: right;
	width: 70%;
}

#box {
	clear: both;
	background: #f9f9f9;
	margin-bottom: 100px;
	padding: 3%;
	overflow: hidden;
}

#box h2,
h2#shoproute {
	height: auto;
	margin: 0 0 60px;
	border-bottom: none;
	line-height: normal;
}

#box ul {
	padding: 0;
	overflow: hidden;
}

#box ul li:last-child {
	margin-right: 0;
}

#box ul li img {
	width: 100%;
	margin-bottom: 10px;
}

article .left_cont {
	float: left;
	width: 40%;
}

article .right_txt {
	float: right;
	width: 58%;
}

.footer {
	clear: both;
	height: 130px;
	text-align: center;
	line-height: 130px;
	border-top: 1px solid #008463;
}

/*-- main end --*/

/*-- footer  --*/

footer {
	float: left;
	width: 10%;
	height: calc(100% - 140px);
	text-align: center;
	position: fixed;
	top: 140px;
	left: 0;
}

footer p {
	height: 100%;
	position: absolute;
	font-size: 9px;
  	-webkit-writing-mode: vertical-rl;
	-moz-writing-mode: vertical-rl;
  	-ms-writing-mode: tb-rl;
  	-ms-writing-mode: vertical-rl;
  	writing-mode: vertical-rl;
	top: 0;
	bottom:0;
  	left: 50%;
  	transform:translate(-50%, 0);
	-webkit- transform: translateY(-50%) translateX(0);
}

/*-- footer end --*/

@media only screen and ( max-width : 1024px ) {
body {
	font-size: 12px;
}


}



/*-- ここからスマホcss START --*/
@media only screen and ( max-width : 820px ) {
	
body {
	font-size: 14px;
}
	
header {
	position: fixed;
	float: right;
	width: 20%;
	height: 100%;
	right: 0;
	z-index: 200;
}
	
h2 {
	height: 50px;
	line-height: 1rem;
	font-size: 2rem;
	text-align: center;
	border-bottom: 1px solid #008463;
	font-family: 'Quicksand', sans-serif;
}

h3 {
	margin-bottom: 40px;
	font-size: 21px;
	text-align: center;
}
	
.br-pc {
	display: block;
}

.br-sp {
	display: none;
}
	
.cursor {
  cursor: pointer;
}
	
#box h2 {
	margin: 0 0 30px;
}
	
article.cont {
	margin-bottom: 60px;
}
	
article .cont .title {
	float: none;
	width: 100%;
	left: 0;
	position: static;
	text-align: left;
	writing-mode: horizontal-tb;
	-webkit-writing-mode: horizontal-tb;
	-moz-writing-mode: horizontal-tb;
	-ms-writing-mode: horizontal-tb;
}
	
article .left_cont,
article .right_txt {
	float: none;
	width: 100%;
}
	
header #logo {
	display: none;
}
	
/*-- nav --*/

#gnav {
	display: none;
}
	
#sp_gnav {
	display: block;
}
	
main {
	clear: both;
	width: 100%;
	height: 100%;
	border-right: none;
	border-left: none;
	position: relative;
	left: 0;
	right: 0;
	overflow: auto;
	z-index: 0;
}
	
.info img {
	width: 90%;
	margin: 0 auto;
}
	
.reserve ul {
	display: flex;
	flex-wrap: wrap;
}
	
.reserve ul li {
	width: calc(100%/2 - 5px);
	margin: 0 10px 40px 0;
	text-align: center;
	box-sizing: border-box;
}
	
.reserve ul li:nth-child(2),
.reserve ul li:nth-child(4){
	margin-right: 0;
}

.reserve ul li img {
	width: 100%;
}

.reserve .webreserve ul {
	width: 90%;
	margin: 10px auto 0;
}

.reserve .webreserve ul li {
	width: 100%;
	margin: 0 0 10px 0;
	text-align: center;
	font-size: 14px;
	background-color: #008463;
	border-radius: 20px;
	-webkit-border-radius: 20px;
	-mos-border-radius: 20px;
	-o-border-radius: 20px;
	-ms-border-radius: 20px;
}
	
.footer {
	font-size: 12px;
	height: 80px;
	text-align: center;
	line-height: 80px;
	border-top: 1px solid #008463;
}

	
/*-- footer  --*/

footer {
	float: none;
	width: 94%;
	height: 20%;
	padding: 3%;
	text-align: center;
	position: static;
	top: 0;
	b0ttom: 0;
	left: 0;
	right: 0;
}
	
footer p {
	position: static;
	text-align: center;
	font-size: xx-small;
  	-webkit-writing-mode: horizontal-tb;
	-ms-writing-mode: lr-tb;
	-ms-writing-mode: horizontal-tb;
	writing-mode: horizontal-tb;
	left: 0;
  	transform:translate(0%, 0);
	-webkit- transform: translateY(0%) translateX(0);
}
}