@charset "UTF-8";
/* CSS Document */

/*******基本設定*******/
* {margin: 0 auto;padding: 0;box-sizing: border-box;}
body {
	font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	background: url(../img/bg.jpg);
	color: #622203;
	height: 100%;
}
html {overflow-y: scroll;height: 100%;}
h1,h2,h3,h4,h5,h6 {font-weight: normal;}
p,li,dt,dl {line-height: 1.75;}
p {margin: 0 0 1em 0;/*最初に消したマージンをふっかつ*/}
li {list-style: none;}
img {border: none;vertical-align: bottom;max-width:100%;}

/*******table*******/
table,th,td {
	border: solid 1px;
	border-collapse: collapse;
	padding: 10px;
}

/*******リンク*******/
a:link {
	color: #622203;
	text-decoration: none;
}

a:visited {
	color: #622203;
	text-decoration: none;
}

a:hover {
	color: #622203;
	text-decoration: none;
}

a:hover img {opacity: 0.7;filter: alpha(opacity=70);-ms-filter: "alpha(opacity=70)";}

/*******レイアウト*******/
.left {float: left;}
.right {float: right;}

.tx-l {text-align: left;}
.tx-r {text-align: right;}
.tx-c {text-align: center;}

.ofa {overflow: auto;}
.clear {clear: both;overflow: hidden;}

.cf {display: inline-table;}
.cf:after {
  display: block;
  clear: both;
  content: "";
}

/*******余白*******/
.m0 { margin: 0 !important; }

.mb0 { margin-bottom:0px !important;}
.mb10 { margin-bottom:10px !important;}
.mb20 { margin-bottom:20px !important;}
.mb30 { margin-bottom:30px !important;}
.mb40 { margin-bottom:40px !important;}
.mb50 { margin-bottom:50px !important;}

.mt0 { margin-top:0px !important;}
.mt10 { margin-top:10px !important;}
.mt20 { margin-top:20px !important;}
.mt30 { margin-top:30px !important;}
.mt40 { margin-top:40px !important;}
.mt50 { margin-top:50px !important;}

.pb0 { padding-bottom:0 !important;}
.pb10 { padding-bottom:10px !important;}
.pb20 { padding-bottom:20px !important;}
.pb30 { padding-bottom:30px !important;}
.pb40 { padding-bottom:40px !important;}
.pb50 { padding-bottom:50px !important;}

.pt0 { padding-top:0px !important;}
.pt10 { padding-top:10px !important;}
.pt20 { padding-top:20px !important;}
.pt30 { padding-top:30px !important;}
.pt40 { padding-top:40px !important;}
.pt50 { padding-top:50px !important;}

/*******wrapper*******/
.wrap {
	width: 1140px;
}

/*******header*******/
header {
	position: relative;
}

.head-bar {
	background: rgba(255,255,255,0.4);
	overflow: auto;
	padding: 16px 0;
	position: fixed;
	top: 8px;
	left: 0;
	z-index: 1000;
	width: 100%;
}

.logo {
	float: left;
	font-size: 170%;
}

/*******nav*******/
nav {
	float: right;
}

nav ul {
	overflow: auto;
	padding-top: 4px;
}

nav li {
	float: left;
	margin-left: 40px;
}

nav li a {
	display: block;
}

nav li img {
	vertical-align: middle;
}

/*******icatch*******/
.icatch {
	position: relative;
}

.icatch::after {
	content: url(../img/icatch-leaf.png);
	position: absolute;
	bottom: -13%;
	right: 4%;
}

.icatch .slider img {
	width: 100%;
}

/*******contents*******/
.contents {
	overflow: auto;
}

.content-ttl {
	background: url(../img/ttl-bg.png) repeat-x;
	margin-bottom: 64px;
	text-align: center;
	padding: 24px 0;
}

/*******about*******/
#about {
	padding: 192px 0 96px;
	margin-top: -96px;/*リンク用*/
}

.about-box {
	background: #fff;
	box-shadow: 0px 5px 10px rgba(0,0,0,0.4);
	text-align: center;
	padding: 56px 0;
	position: relative;
	width: 1040px;
}

.about-box::before {
	content: url(../img/about-pict01.png);
	position: absolute;
	top: -7%; right: -4%;
}

.about-box::after {
	content: url(../img/about-pict02.png);
	position: absolute;
	bottom: -10%;
	left: -6%;
}

.about-box .about-ttl {
	margin-bottom: 48px;
}

.about-box p {
	line-height: 3;
}

/*******menu*******/
#menu {
	padding-top: 96px;/*リンク用*/
	margin-top: -96px;/*リンク用*/
}

.menu-bg {
	background: url(../img/bg-leaf01-2.png) no-repeat;
	background-position: 1200px 150px;
	max-width: 1440px;
}

.menu-box {
	overflow: auto;
	padding-bottom: 80px;
	width: 1000px;
}

.menu-photo-list {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 32px;
}

.menu-photo-list li {
	text-align: center;
	margin-bottom: 32px;
}

.menu-photo-list .menu-img {
	margin-bottom: 16px;
}

.menu-photo-list .menu-name {
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 8px;
}

.menu-photo-list .menu-name .menu-price {
	color: #a63a05;
	margin-left: 1em;
}

.menu-photo-list .detail {
	font-size: 14px;
}

.tab-box {
	background: rgba(255,255,255,0.2);
	overflow: auto;
	padding: 40px 64px;
}

.tab-box h3 {
	text-align: center;
	margin-bottom: 40px;
}

.tab-inner-list {
	float: left;
	margin: 0 2%;
	width: 46%;
}

.tab-inner-list .menu-item {
	border-bottom: 1px solid #622203;
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 12px;
	padding: 0 8px;
}

.tab-inner-list .price {
	color: #a63a05;
	font-weight: bold;
	float: right;
}

.tab-inner-list .child {
	margin-bottom: 16px;
}

.tab-inner-list .child li {
	font-size: 14px;
	margin-bottom: 4px;
	padding: 0 8px;
}

/*******gallery*******/
#gallery {
	padding-top: 96px;/*リンク用*/
	margin-top: -96px;/*リンク用*/
}

.gallery-bg {
	background: url(../img/bg-leaf01.png),url(../img/bg-leaf01-2.png),url(../img/bg-leaf01.png);
	background-repeat: no-repeat;
	background-position: 30px 80px,1200px 400px,30px 700px;
	max-width: 1440px;
}

.gallery-list {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 48px;
	width: 1040px;
}

.gallery-list li {
	margin-bottom: 32px;
}

/*******access*******/
#access {
	margin-bottom: 64px;
	padding-top: 96px;/*リンク用*/
	margin-top: -96px;/*リンク用*/
}

#access .content-ttl {
	margin-bottom: 0;
}

.access-bg {
	background: url(../img/bg-leaf02.png),url(../img/bg-leaf03.png),url(../img/bg-leaf04.png);
	background-repeat: no-repeat;
	background-position: 50px 0px,1120px 400px,20px 1750px;
	padding-top: 64px;
	max-width: 1440px;
}

.access-flow {
	background: rgba(255,255,255,0.2);
	text-align: center;
	margin-bottom: 88px;
	padding: 48px 0;
	position: relative;
	width: 850px;
}

.access-flow p {
	margin-bottom: 24px;
}

.access-flow img {
	width: 440px;
}

.access-flow::after {
	content: "";
	position: absolute; top: 105%; left:0; right:0;
	margin: auto;
	height: 0;
	width: 0;
	border: 70px solid transparent;
	border-top: 40px solid #622203;
}

.access-flow.last::after {
	content: none;
}

#access .wrap {
	display: flex;
}

.access-tb {
	display: table;
	width: 45%;
}

.access-tb .access-tb-row {
	display: table-row;
}

.access-tb .access-tb-row dt,.access-tb .access-tb-row dd {
	border-bottom: 1px solid #622203;
	display: table-cell;
	padding: 12px;
}

.access-tb .access-tb-row dt {
	font-weight: bold;
}

.map {
	width: 45%;
}

/*******footer*******/
footer {
	font-size: 12px;
	clear: both;
}

footer .pan li {
	margin: 0 10px 0 17px;
	display: inline;
}

.copy {
	font-size: 13px;
	text-align: center;
}

/*******上へ戻るボタン*******/
#page-top {
	background: #004419;
	border-radius: 50%;
	color: #fff;
	cursor: pointer;
	text-align: center;
	padding-top: 12px;
	position: fixed;
	bottom: 5%;
	right: 5%;
	width: 50px;
	height: 50px;
}