@charset "utf-8";
/* -------------------------------------------------- reset */
/* ------------------------------ default */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font-weight: normal;
}
img {
	height: auto;
	max-width: 100%;
	vertical-align: bottom;
}

body {
	overflow-x: hidden;
	overflow-y: scroll;
	color: #2d1f08;
	font-family: "Times New Roman","ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝","MS PMincho","MS 明朝",serif;
	font-size: 14.5px;
	line-height: 1.6;
	letter-spacing: 1px;
	-webkit-text-size-adjust: 100%;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
}
.mincho {font-family: "Times New Roman","ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝","MS PMincho","MS 明朝",serif;}
.kakugo {font-family: Verdana,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;}
.tpl {font-family: sans-serif;} /* ThreePointLeader */
.spr {letter-spacing: -0.5em;} /* SPaceRemove */
.no-lt-space {letter-spacing: 0;}
/* link */
a {color: #870126;text-decoration: none;}
a:hover {color: #440001;}
a:focus {outline: none;}
a.no {color: inherit;text-decoration: none;}

/* ul, ol */
ul,ol {list-style-type: none;}

/* table */ 
table {
	border-collapse: collapse; 
	border-spacing: 0;
}

/* ------------------------------ clearfix */
	.clearfix:after {/*for modern browser*/
	   content: "";
	   display: block;
	   clear: both;
	}

	* html .clearfix {zoom: 1;} /*for IE6*/
	*:first-child+html .clearfix {zoom: 1;} /*for IE7*/

/* ------------------------------ fade */
	.fade, .fade_img {  
		-webkit-transition: .2s linear;
		transition: .2s linear;
	}  
	.fade_img:hover {  
		opacity: 0.6;  
		filter: alpha(opacity=60);
	}

/* ------------------------------ size */
	.sml {font-size: 80%;}
	.big {font-size: 130%;}

	.mrb-10 {margin-bottom: 10px !important;}
	.mrb-20 {margin-bottom: 20px !important;}
	.mrb-30 {margin-bottom: 30px !important;}
	.mrb-40 {margin-bottom: 40px !important;}
	.mrb-50 {margin-bottom: 50px !important;}
	.mrb-60 {margin-bottom: 60px !important;}
	.mrb-70 {margin-bottom: 70px !important;}
	.mrb-80 {margin-bottom: 80px !important;}
	.mrb-90 {margin-bottom: 90px !important;}
	.mrb-100 {margin-bottom: 100px !important;}

	.tel-big {font-size: 180%; letter-spacing: 2px; }

/* ------------------------------ none */
	.none {display: none !important;}
/* ------------------------------ br */
	.br-sp {display: none;}
	.br-tbl {display: none;}

/* -------------------------------------------------- common */
	.inner_res {
		width: 100%;
		padding-left: 2%;
		padding-right: 2%;
		margin: 0 auto;
		box-sizing: border-box;
	}
	.inner_l {
		max-width: 1600px;
	 }
	.inner_s {
		max-width: 1280px;
	 }

/* ----------------------------------- header */
	#header {
		position: relative;
		left: 0;top: 0;
		z-index: 1010;
		width: 100%;
		background: #000;
	}

	#header .inner_res {
		position: relative;
		overflow: hidden;
	}
	#header h1 {
		color: #fff;
		font-size: 80%;
		text-align: left;
		padding-top: 8px;
	}
	#header .logo {
		float: left;
		width: 330px;
		max-width: 100%;
		margin-top: 5px;
		-webkit-transition: .2s linear;
		transition: .2s linear;
	}

	#header .shopinfo {
		-webkit-transition: .2s linear;
		transition: .2s linear;
	}
	#header .shopinfo p {
		color: #fff;
		font-size: 105%;
		text-align: right;
	}
	#header .shopinfo a {
		color: #fff;
	}
	#header .shopinfo a:hover { 
		color: #C2AF67;
		}
	#header .shopinfo img {
		width: 27px;
		margin-left: 10px;
		margin-right: 3px;
		vertical-align: text-bottom;
	}
	#header .shopinfo a img:hover {
		width: 30px;
	}

/* ------------------ gnav */
	#gnav {
		float: right;
		margin: 10px 0;
	}
	#gnav li {
		display: inline-block;
		margin-left: 10px;
	}
	#gnav li a {
		position: relative;
		display: inline-block;
		background:#222;
		padding: 5px 20px;
		color: #fff;
	    -webkit-transition: all 0.3s ease;
	    -moz-transition: all 0.3s ease;
	    -o-transition: all 0.3s ease;
	    transition: all  0.3s ease;
	}
	#gnav li a:hover,
	#gnav li.now a{
		background:#C2AF67;
	}

	/* btn */
	#gnav_btn {
		display: none;
		position: absolute;
		top:0;
		right: 0;
		width: 40px;height: 40px;
		margin: 8px 5px 5px;
		cursor: pointer;
	}
	#gnav_btn .fa {
		position: absolute;
		left: 0;top: 0;
		display: block;
		width: 40px;
		font-size: 30px;
		line-height: 30px;
		text-align: center;
		color: #fff;
	}
	#gnav_btn .fa_title {
		display: block;
		width: 40px;
		margin-top: 1px;
		font-family: Arial, sans-serif;
		font-size: 10px;
		line-height: 10px;
		letter-spacing: 0;
	}
	#gnav_btn .open {opacity: 1;filter: alpha(opacity=100);}
	#gnav_btn .close {opacity: 0;filter: alpha(opacity=0);}
	#gnav_btn.on .open {opacity: 0;filter: alpha(opacity=0);}
	#gnav_btn.on .close {opacity: 1;filter: alpha(opacity=100);}

/* ------------------ header on */
	#header.on {
		position: fixed;
		background: rgba(0,0,0,0.9);
	}
	#header.on h1 {	display: none;}
	#header.on .logo {	width: 250px;}
	#header.on .shopinfo p { 
		font-size: 95%;
		margin-top:2px;
	}
	#header.on #gnav { margin: 5px 0;}
	#header.on #gnav li a {
		padding: 3px 20px;
		font-size: 90%;
	}

/* ------------------ header_bg */
	#header_bg {
		position: relative;
		z-index: 1;
		overflow: hidden;
		width: 100%;
		margin-top: 0;
		background: #000;
		border-bottom: #C2AF67 6px solid;
	}
	#header_bg .header_bg_before {
		background: rgba(45,31,8,0.7);
		height: 10px;
		width: 100%;
		display: block;
		position: absolute;
		z-index: 99999;
	}
	#header_bg .header_bg_in {
		overflow: hidden;
		position: relative;
		top: 0;left: -5%;
		width: 110%;
	}

	#header_bg .header_bg_in.under {height: auto;}
	#header_bg .header_bg_logo {
		position: absolute;
		left: 0;top: 0;
		z-index: 1001;
	}
	#header_bg .catch,
	#header_bg h2  {
	    font-size: 40px;
	    line-height: 50px;
	    letter-spacing: 3px;
	    font-weight: bold;
		text-shadow: 
		-2px -2px 3px rgba(45,31,8, 0.5), 
		2px -2px 3px rgba(45,31,8, 0.5), 
		2px 2px 3px rgba(45,31,8, 0.5), 
		-2px 2px 3px rgba(45,31,8, 0.5),
		0px 0px 15px rgba(45,31,8, 0.7),
		0px 0px 20px rgba(45,31,8, 0.7);
	    position: absolute;
	    color: #fff;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		width: 400px;
		height: 100px;
		z-index: 999999;
		margin: auto;
		text-align: center;
	}
	#header_bg .catch span { 
		font-size: 60%;
		text-shadow: 
		-1px -1px 2px rgba(45,31,8, 0.7), 
		1px -1px 2px rgba(45,31,8, 0.7), 
		1px 1px 2px rgba(45,31,8, 0.7), 
		-1px 1px 2px rgba(45,31,8, 0.7),
		0px 0px 10px rgba(45,31,8, 0.7),
		0px 0px 15px rgba(45,31,8, 0.7);
	}
	#header_bg h2 {
		font-weight: normal;
		letter-spacing: 5px;
	}

/* ----------------------------------- footer */
	#footer {
		position: relative;
		z-index: 1;
		width: 100%;
		padding: 50px 0 0;
		background: url(../../img/bg_footer.jpg) center bottom no-repeat;
		background-attachment: fixed;
		text-align: center;
		color: #fff;
	}
	#footer a {color: #fff;}
	#footer a:hover {text-decoration:underline;}
	#footer .rec-btn {
		display: block;
		max-width: 300px;
		margin-left: auto;
		margin-right: auto;
	}
	#footer .ft-box {
		display:-webkit-box;
		display:-moz-box;
		display:-ms-flexbox;
		display:-webkit-flex;
		display:-moz-flex;
		display:flex;
		    -webkit-box-lines:multiple;
		    -moz-box-lines:multiple;
		    -webkit-flex-wrap:wrap;
		    -moz-flex-wrap:wrap;
		    -ms-flex-wrap:wrap;
		flex-wrap:wrap;

	}
	#footer .ft-box li{
		float: left;
		width: 28%;
		margin: 1%;
		padding: 20px 1.5%;
		background: rgba(45,31,8, .85);
	}
	#footer .ft-box .title {
		font-size: 180%;
		letter-spacing: 0.35em;
	}
	#footer .logo { width: 50%;}
	#footer .add { 
		text-align: left;
		width: 90%;
		margin-left: auto;
		margin-right: auto;
	}
	#footer .add dt{
		float: left;
		clear: both;
		width: 15%;
	}
	#footer .add dt img {
		width: 90%;
		max-width: 25px;
	}

	#footer .add dd {
		float: right;
		width: 85%;
		line-height: 1;
		min-height: 30px;
		display: flex;
		align-items: center;
	}

	#footer .sns {
		max-width: 150px;
		text-align: left;
		margin-left: auto;
		margin-right: auto;
	}
	#footer .sns dt{
		float: left;
		clear: both;
		width: 40%;
	}
	#footer .sns dt img {width: 85%;}
	#footer .sns dd{
		float: right;
		width: 60%;
		padding-bottom: 20px;
		line-height: 1.5em;
		letter-spacing: 2px;
	}
	#footer .ft-menu {
		display: inline-block;
		margin-left: auto;
		margin-right: auto;
	}
	#footer .ft-menu li {
		float: none;
		width: 100%;
		margin: 0;
		padding: 0;
		background: none;
		text-align: left;
		list-style-type: disc;
	}

	#footer .copyright {
		background: #2d1f08;
		margin-top: 20px;
		font-size: 75%;
		padding: 5px 0;
	}

/* ---------------- pagetop */
	#pagetop {
		display: none; /* js */
		position: fixed;
		bottom: 30px;
		right: 20px;
		z-index: 1008;
		opacity: 0;
		filter: alpha(opacity=0);
	}
	#pagetop.on {
		opacity: 1;
		filter: alpha(opacity=100);
	}
	#pagetop a {
		display: block;
		font-size: 32px;
		color: #aaa;
		opacity: .6;
		filter: alpha(opacity=60);
	}
	#pagetop a:hover {
		opacity: 1;
		filter: alpha(opacity=100);
	}

/* ----------------------------------- main */
	#main {
		overflow: hidden;
		width: 100%;
	}

/* ---------------- row */
	.row {
		position: relative;
		z-index: 1;
		padding: 60px 0 80px;
		background: #fff;
		text-align: center;
		overflow: hidden;
	}

/* ---------------- btn */
	/* ---- brown */
	.btn-br {
		display: inline-block;
		background:#2d1f08; 
		color: #fff;
		padding: 15px 10%;
		letter-spacing: 5px;
		-webkit-transition: .2s linear;
		transition: .2s linear;
	}
	.btn-br:hover {
		background: #5f0912;
		color: #fff;
	}
	/* ---- light brown */
	.btn-l-br {
		display: inline-block;
		background:#222; 
		color: #fff;
		padding: 15px 10%;
		letter-spacing: 5px;
		-webkit-transition: .2s linear;
		transition: .2s linear;
	}
	.btn-l-br:hover {
		background: #5f0912;
		color: #fff;
	}

	/* ---- red */
	.btn-rd {
		display: inline-block;
		background:#7b1313; 
		color: #fff;
		padding: 15px 10%;
		letter-spacing: 5px;
		-webkit-transition: .2s linear;
		transition: .2s linear;
	}
	.btn-rd:hover {
		background: #5f0912;
		color: #fff;
	}

	/* ---- red透過 */
	.red-btn {
		background: rgba(123,19,19,.85); /* Old browsers */
		-webkit-transition: .2s linear;
		transition: .2s linear;
	}
	.red-btn:hover {background: #7b1313;}

	/* ---- brown透過 */
	.brown-btn {
		background: rgba(45,31,8, .85); /* Old browsers */
		-webkit-transition: .2s linear;
		transition: .2s linear;
	}
	.brown-btn:hover {background: #2d1f08;}

/* ---------------- balloon */

	.balloon {
	 	position: relative;
		display: inline-block;
		padding: 10px 15px;
		min-width: 120px;
	 	max-width: 100%;
		background: #a72429;
		border-radius: 10px;
		color: #fff;
		text-align: left;
	}

	.balloon:before{
		content: "";
		position: absolute;
		top: 100%;
		left: 50%;
	 	margin-left: -10px;
		border: 10px solid transparent;
		border-top: 10px solid #a72429;
	}

/* ---------------- action */
	.action {position: relative;}
	.action.on {
		-webkit-transition-property: top, opacity;
		transition-property: top, opacity;
		-webkit-transition-duration: .7s;
		transition-duration: .7s;
		-webkit-transition-timing-function: ease-in-out;
		transition-timing-function: ease-in-out;
	}
	.action.unvisi {
		top: 30px;
		opacity: 0;
		filter: alpha(opacity=0);
	}
	.action.visi {
		top: 0;
		opacity: 1;
		filter: alpha(opacity=100);
	}


/* -------------------------------------------------- layout */
/* ----------------------------------- index */
    .uber-pc {
    	margin-bottom: 50px;
    	display: block !important;
    }
     .uber-sp{
    	display: none !important;
    }
/* ---------------- osusume */
	.osusume {
		background:#ffffff url(../../img/body-bg2.jpg) center top ;
		background-size: 100%;
	}
	.osusume .osusume-menu {
		width: 100%;
	  	font-size: 0;
		}
	.osusume .osusume-menu li {
		float: left;
		width: 12%;
		margin: 0 0.25%;
	}
	.osusume .osusume-title {
		width: 100%;
	  	font-size: 1.5em;
	  	color: #fff;
		}

/* ---------------- what's new */
	.whats-new {
		max-width: 900px;
		margin-left: auto;
		margin-right: auto;
		background: rgba(255,255,255,.65);
		overflow: hidden;
		padding: 2.5% 5%;
	}
	.whats-new .whatsnew-list {
		float: left;
		width: 60%;
		margin-right: 5%;
	}
	.whats-new .whatsnew-list dl {
		overflow: hidden;
	}
	.whats-new .whatsnew-list .new_mark {
		background :#7b1313;
		color: #fff;
		font-size: 70%;
		padding: 3px 5px;
		margin-left: 3px;
	}
	.whats-new .whatsnew-list dt {
		float: left;
		width: 170px;
		color: #7b1313;
		text-align: left;
		padding: 5px;
	}
	.whats-new .whatsnew-list dd {
		text-align: left;	
		border-bottom: 1px dotted #C2AF67;
		padding: 5px;
	}
	.whats-new .whatsnew-list dd a{
		color: #2d1f08;
	}
	.whats-new .whatsnew-photo {
		float: right;
		width: 35%;
		background:#fff;
		padding: 0 0 10px;
	}
	.whats-new .whatsnew-photo .pickup {
		color: #b02121;
		font-size: 110%;
		font-weight: bold;
	}
	.whats-new .whatsnew-photo img {
		max-height: 400px;
	}

/* ---------------- shop-area */
	#shop-area{
		background: url(../../img/body-bg2.jpg) center top;
	    background-size: auto auto;
		background-size: 100%;
	}
	#shop-area .inner_res {
		max-width: 1400px;
		display: inline-block;
		margin-left: auto;
		margin-right: auto;
		background: #000;
	}
	#shop-area .col{
		float: left;
		width: 28%;
		margin: 0 2.5%;
		padding: 2% 0;
		color: #fff;
	}

	#shop-area .logo {
		width: 80%;
	}
	#shop-area .shop-add {
		text-align: left;
		border-top: dotted #C2AF67 1px;
	}
	#shop-area .shop-add dt{
		float: left;
		clear: left;
		color: #C2AF67;
		width: 5.5em;
		padding: 5px;
	}
	#shop-area .shop-add dd{
		border-bottom: dotted #C2AF67 1px;
		padding: 5px;
	}
	#shop-area .shopimage div {
		float: left;
		width: 30%;
		margin: 1.577%;
	}
	#shop-area .shopimage .tit {
		background: #59390a;
		color: #fff;
		padding: 3px; 
	}
	#shop-area .shopimage .disc {
		padding-top: 2px;
		text-align: left;
		font-size: 95%;
		line-height: 1.4;
		letter-spacing: .5;
		color: #fff;
	}

/* ---------------- menu(gallery) */
	#gallery {
		overflow: hidden;
		position: relative;
		width: 100%;
		padding: 130px 0 130px;
	}
	#gallery #gallery_bg{
		position: absolute;
		left: -20%;bottom: 0;
		width: 140%;height: auto;
		z-index: -1;
	}
	#gallery .inner_res {
		max-width: 1000px;
		display: inline-block;
		margin-left: auto;
		margin-right: auto;
	}
	#gallery h2 {
		font-size: 130%;
		color: #2d1f08;
		text-shadow: 
		-1px -1px 2px rgba(255,255,255, 0.8), 
		1px -1px 2px rgba(255,255,255, 0.8), 
		-1px 1px 2px rgba(255,255,255, 0.8),
		1px 1px 2px rgba(255,255,255, 0.8)
	}
	#gallery .menubtn {
		float: left;
		width: 30%;
	}
	#gallery .menubtn {
		padding: 35px 5%;
		margin: 0 25px; 
		color: #fff;
		letter-spacing: .5em;
		text-indent: 10px;
		font-size: 140%;
		display: block;
		text-shadow: 1px 1px 0 #000;
	}

/* ---------------- gmap */
	#shop-map {
		padding: 0;
	}
	#gmap_wrap {position: relative;}
	#gmap {
		width: 100%;
		height: 500px;
	}
	#gmap_wrap .cover {
		position: absolute;
		left: 0;top: 0;
		display: block;
		width: 100%;height: 100%;
		background: rgba(0,0,0,.1);
	}

/* ----------------------------------- newspage */
	.newspage {
			background:#ffffff url(../../img/body-bg.jpg) center top ;
			background-size: 100%;
		}
	.newspage h2 {
		color: #7b1313;
		font-size: 150%;
		font-weight: bold;
	}
	.whatsnew {
		width: 90%;
		padding :2% 5%;
		max-width: 850px;
		margin-left: auto;
		margin-right: auto;
		background: rgba(255,255,255,.7);
	}
	#news_view  a {
		cursor: pointer;
	}
	.toggle{
		-webkit-transition: all 0.8s ease;
	    -moz-transition: all 0.8s ease;
	    -o-transition: all 0.8s ease;
	    transition: all  0.8s ease;
	}
	#news_view dt a {
		color: #2d1f08;
		text-align: left;	
		display: block;
		font-size: 110%;
		padding: 5px;
		margin: 15px 0;
		border-bottom: 1px dotted #7b1313;

	}
	#news_view dt.opened a {
		background:#edd8d8;
	}
	.toggle:before {
	            content: "\f054";
	            font-family: FontAwesome;
	            color: #7b1313;
	            padding-right: 5px;
	}
	.opened .toggle:before {
		        content: "\f077";
	            font-family: FontAwesome;
	            color: #7b1313;
	            padding-right: 5px;
	}
	#news_view dt .ymd{
		padding: 2px 5px;
		background:#7b1313;
		color: #fff;	
		border-radius: 3px;
		font-size: 80%;
	}
	#news_view dd {
		text-align: left;
		padding: 0 10px;
		box-shadow: 0px 5px 5px -5px #ccc;
	}
	#news_view .photo {
		float: left;
		max-width: 33%;
		margin-right: 2%;
		margin-bottom: 15px;
	}
	#news_view .detail {
		padding-bottom: 5px;	
	}
	#news_view .new_mark {
		background :#000;
		color: #fff;
		font-size: 70%;
		padding: 3px 5px;
		margin-left: 3px;
		float: right;
	}

/* ----------------------------------- menupage */
	.menupage {
			background:#ffffff center top ;
			background-size: 100%;
		}
	.menupage h3 {
		background: #7b1313;
		padding: 5px;
		overflow: hidden;
		text-align: left;
		margin-bottom: 15px;
	} 
	.menupage h3 img{
		width: 85%;
		max-width: 200px;
	}
	.menupage h4 {
		text-align: left;
		margin: 15px 0 20px;
		background: linear-gradient(transparent 50%, rgba(133,82,12,.2) 50%);
		overflow: hidden;
	}
	.menupage h4 img {
		width: 85%;
		max-width: 280px;
	}
	.menupage .pickup {
		display:-webkit-box;
		display:-moz-box;
		display:-ms-flexbox;
		display:-webkit-flex;
		display:-moz-flex;
		display:flex;
		    -webkit-box-lines:multiple;
		    -moz-box-lines:multiple;
		    -webkit-flex-wrap:wrap;
		    -moz-flex-wrap:wrap;
		    -ms-flex-wrap:wrap;
		flex-wrap:wrap;
	}
	.menupage .pickup li {
		float: left;
		width: 21%;
		margin: 1%;
		padding: 10px 1%;
		background: rgba(255,255,255,.85);
		text-align: left;
		border-radius: 5px;
	}
	.menupage .pickup .tit {
		font-weight: bold;
		font-size: 90%;
		margin-bottom: 5px;
	}
	.menupage .pickup .disc {
		font-size: 85%;
		letter-spacing: 0;
	}
	.menupage dl {
		float: left;
		width: 46%;
		margin: 0 2%;	
		font-size: 115%;
		overflow: hidden;
		border-bottom: dashed 1px #b3966d;
	}
	.menupage dt {
		float: left;
		clear: left;
		width: 75%;
		padding: 1%;
		text-align: left;
		border-top: dashed 1px #b3966d;
	}
	.menupage dd {
		float: left;
		width: 21%;
		padding: 1%;
		text-align: right;
		color: #7b1313;
		border-top: dashed 1px #b3966d;
	}
	.menupage .menu-image-box {
		border-top: dashed 1px #b3966d;
		display: inline-block;
		overflow: hidden;
	}
	.menupage .menu-image {
		float: left;
		width: 30%;
		margin:10px 1.57777%;
	}
	.menupage .other {
		background: rgba(255,255,255,.6);
		border-radius: 10px;	
		overflow: hidden;
		margin-top: 10px;
		padding: 15px;
		border:2px solid #b3966d;
		display: inline-block;
		text-align: left;
	}
	.menupage .comment {
		font-size: 70%;
		background: #816337;
		color: #fff;
		margin-left: 5px;
		padding: 1px 10px;
		border-radius: 10px;
		font-family: Verdana,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
	}

/* ----------------------------------- bentopage */
	.bentopage {
			background:#000  center top ;
			background-size: 100%;
		}
	.bentopage .sp { display: none; }


/* ----------------------------------- takeour */
	.takeout {
			width: 100%;
			padding-bottom: 30px;
		}

	.takeout .content{
			margin: 0;
			padding: 0;
			width: calc(100% / 3);
			display: inline;
		}
/* ----------------------------------- recruitpage */
	.recruitpage {
			background:#ffffff url(../../img/body-bg2.jpg) center top ;
			background-size: 100%;
		}
	.recruitpage .title{
		color: #7b1313;
		font-size: 150%;
		font-weight: bold;
	}
	.recruitpage .rec-info{
		background: rgba(255,255,255,.7);
		padding:3%;	
		overflow: hidden;	
	}
	.recruitpage .rec-photo {
		float: left;
		width: 45%;
	}
	.recruitpage dl{
		float: right;
		width: 50%;
		display: inline-block;
		margin-left: auto;
		margin-right: auto;
		border-bottom: solid 1px #b3966d;
	}
	.recruitpage dt {
		float: left;
		clear: left;
		width: 21%;
		border-top: solid 1px #b3966d;
		padding:1%;
		font-weight: bold;
		text-align: right;
	}
	.recruitpage dd {
		float: left;
		text-align: left;
		width: 75%;
		border-top: solid 1px #b3966d;
		padding:1%;

	}
	.recruitpage .point {
		padding-top: 10px;
		font-weight: bold;
		font-size: 110%;
		color: #872727;
	}

/* ----------------------------------- pppage */
	.pppage {
			background:#ffffff url(../../img/body-bg.jpg) center top ;
			background-size: 100%;
		}
	.pppage .pp-area {
		background: rgba(255,255,255,.7);
		padding:3%;
	}
	.pppage h2 {
		color: #7b1313;
		font-size: 150%;
		font-weight: bold;
	}
	.pppage p{
		text-align: left;
	}


/* ----------------------------------- contactpage */
	.contactpage {
			background:#ffffff url(../../img/body-bg.jpg) center top ;
			background-size: 100%;
		}

	/* ---------------- table */
	#contact_table {
		table-layout: fixed;
		width: 100%;
		max-width: 740px;
		margin: 30px auto 0;
	}
	#contact_table th {
		width: 15em;
		padding: 15px 30px 15px 0;
		border-right: #d1bf9c 2px solid;
		text-align: right;
		vertical-align: top;
	}
	#contact_table td {
		padding: 15px 20px 15px 30px;
		text-align: left;
	}
	#contact_table .req {
		margin-left: 2px;
		font-size: 12px;
		color: #f00;
	}
	#contact_table p {
		background: #ccc;
		padding: 0 10px;
		margin-bottom: 3px;
	}

	#contact_table .age {
		width: 50px !important;
	}

	/* ---------------- form */
	#contact_table input,
		input[type="submit"] {
		-webkit-appearance: none;
		border-radius: 0;
	}
	/* text */
	#contact_table input[type="text"] {
		width: 260px;
		padding: 5px;
		border: #ccc 1px solid;
		box-sizing: border-box;
	}
	#contact_table input.s {width: 100px;}
	#contact_table input.l {width: 90%;}

	/* textarea */
	#contact_table textarea {
		width: 100%;
		height: 200px;
		padding: 5px;
		border: #ccc 1px solid;
		box-sizing: border-box;
		line-height: 1.4;
	}

	/* btn */
	#contact_btns {
		margin-top: 40px;
		text-align: center;
	}
	#contact_btns .btn {
		display: inline-block;
		width: 190px;
		margin: 0 20px;
		padding: 5px 0;
		background: #59390a;
		border: none;
		border-radius: 2px;
		box-sizing: border-box;
		font-family: Verdana,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
		font-size: 13px;
		line-height: 24px;
		letter-spacing: 1px;
		text-align: center;
		vertical-align: top;
		text-decoration: none;
		color: #fff;
		cursor: pointer;
		-webkit-transition: .3s ease-in-out;
		transition: .3s ease-in-out;
	}
	#contact_btns .btn:hover {
		opacity: .7;
		filter: alpha(opacity=70);
	}

	#mailer p {
		text-align: center;
	}

	/* errm */
	#mailer .errm {
		display: inline-block;
		margin-top: 30px;
	}
	#mailer .errm li {
		text-align: left;
		color: #f00;
	}
	#mailer .errm li:before {content: '・';}

	/* validetta */
	.validetta-bubble {
		display: none;
		position: absolute; 
		z-index: 1;
		max-width: 325px; 
		padding: 3px 15px 3px 10px; 
		background: #fff;
		border: #f00 1px solid;
		border-radius: 2px;
		font-size: 11px;
		line-height: 12px;
		color: #f00;
	}
	.validetta-bubble:before,
	.validetta-bubble:after {
		content: '';
		position: absolute; 
		display: block; 
		width: 0;height: 0;
		border: transparent 7px solid;
	}
	.validetta-bubble:before {
		top: -14px;left: 5px; 
		border-bottom-color: #f00;
	}
	.validetta-bubble:after {
		top: -13px;left: 5px; 
		border-bottom-color: #fff;
	}
	.validetta-bubbleClose {
		position: absolute; 
		top: -1px;right: 3px; 
		display: block; 
		font-weight: bold; 
		font-size: 10px;
		cursor: pointer; 
	}

/* -------------------------------------------------- responsive */

@media screen and (max-width: 1200px) {
	#header h1 {font-size: 75%;}
	#header .logo {width: 280px; }
	#header .shopinfo p {font-size: 90%;}
}

@media screen and (max-width: 1020px) {
	.br-tbl {display: inline-block;}
	#header h1 {text-align: center;}
	#header .logo {
		float: none;
		margin: 0 auto;
		width: 350px; 
	}
	#header .shopinfo p {
		text-align: center;
		font-size: 80%;
	}
	#gnav {
		float: none;
		text-align: center;
	}
	#gnav li a {
    	padding: 3px 20px;
    	font-size: 90%;
	}
	#shop-area .col {
	    width: 30%;
	    margin: 0 1.5%;
	    padding: 2% 0;
	    font-size: 90%;
	    letter-spacing: 0;
	}
	#shop-area .col .menubtn {
		letter-spacing: 2px;
		padding: 15px 5px;
	}
	.menupage .pickup li {
    	width: 46%;
    	margin-bottom: 10px;
	}
	.recruitpage .rec-photo {
		float: none;
		width: 100%;
		max-width: 500px;
	}
	.recruitpage dl{
		float: none;
		width: 90%;
		margin: 5% 5% 0;
}

@media screen and (max-width: 900px) {

	#gallery .menubtn {
		letter-spacing: .1em;
	}
	#shop-area .col {
		float: left;
	    width: 47%;
	    margin: 0 1.5%;
	    padding: 2% 0;
	    letter-spacing: 0;
	}
	#shop-area .col03 {
		clear: both;
		width: 100%;
		padding: 10% 0;
		margin-left: auto;
		margin-right: auto;
		font-size: 100%;
	}
	#footer .ft-box li.ft-box01 {
		float: none;
		width: 100%;
	    margin-bottom: 20px;
	}
	#footer .ft-box li.ft-box02,
	#footer .ft-box li.ft-box03 {
	    float: left;
	    width: 45%;
	}
	.menupage dl {font-size: 100%;}

	.bentopage .pc {display: none;}
	.bentopage .sp {display: block;}
	.bentopage .sp .copy {
		text-align: left;
	}  
	.bentopage .sp .copy .red {
		color: #7b1313;
		font-size: 120%;
		font-weight: bold;
	}

}

@media screen and (max-width: 767px) {

	.br-sp {display: inline-block;}
	.br-tbl {display: inline-block;}
	.br-pc {display: none;}

	/* --------------- size */
	.mrb-10 {margin-bottom: 5px !important;}
	.mrb-20 {margin-bottom: 10px !important;}
	.mrb-30 {margin-bottom: 15px !important;}
	.mrb-40 {margin-bottom: 20px !important;}
	.mrb-50 {margin-bottom: 25px !important;}
	.mrb-60 {margin-bottom: 30px !important;}
	.mrb-70 {margin-bottom: 35px !important;}
	.mrb-80 {margin-bottom: 40px !important;}
	.mrb-90 {margin-bottom: 45px !important;}
	.mrb-100 {margin-bottom: 50px !important;}


	/* --------------- common */
	.inner_res {
		width: 100%;
		padding-left: 10px;
		padding-right: 10px;
	}

	/* --------------- header */
	#header h1 {text-align: left;}
	#header .shopinfo {
		position: absolute;
		top:310px;
		z-index: 99999;
	}
	#header .shopinfo p,
	#header.on .shopinfo p {
		font-size: 90%;
		line-height: 2.3;
		text-align: left;
	}
	#header .shopinfo img {
	    width: 25px;
	    margin-left: 15px;
	    margin-right: 3px;
	    vertical-align: text-bottom;
	}
	#header_bg .header_bg_in {
	    left: -25%;
	    width: 150%;
	}


	/* ------------------ gnav */
	#gnav_btn,
	#gnav .gnav_title {display: block;}
	#gnav_wrap {
		display: none; /* js */
		position: fixed;
		top: 60px;
		right: -230px;
		z-index: 1009;
		width: 230px;
		height: 1000px;
		background: #000;
		background: rgba(45,31,8,0.9);		
		-webkit-transition: right .3s cubic-bezier(0.55, 0, 0.1, 1);
		transition: right .3s cubic-bezier(0.55, 0, 0.1, 1);
	}
	#gnav_wrap.on {right: 0;}
	#gnav_wrap .inner {
		overflow-y: auto;
		overflow-x: hidden;
		-webkit-overflow-scrolling: touch;
		height: 100%; /* js */
	}
	#gnav {
		position: relative;
		float: none;
		height: auto;
		margin: 0;
		line-height: 1.6;
	}
	#gnav li {
		display: block;
		margin: 0;
	}
	#gnav li a {
		display:block;
		padding: 15px 0;
		text-align: center;
		letter-spacing: 2px;
		color: #fff;
		border-bottom: 1px dotted #C2AF67;
	}
	#gnav li a:after { display: none;}
	#gnav li a:before {
		content: '';
		position: absolute;
		left: 8px;
		top: 20px;
		display: block;
		width: 0;height: 0;
		border: transparent 5px solid;
		border-left-color: #fff;
	}
	/* on */
	#header.on #gnav {
		height: 100%;
		line-height: 1.6;
		margin: 0;
	}
	#header.on #gnav li a {
	    padding: 15px 0;
	    font-size: 90%;
	}






	/* --------------- index */
	#header_bg .catch {
		font-size: 25px;
		line-height: 32px;
		width: 280px;
		height: 70px;
	}
	.osusume .osusume-menu {
		width: 85%;
		margin: 0 auto;
	}
	.osusume .osusume-menu li {
	width: 24%;
	margin: 2px 0.5%;
	}	

	.uber-pc {
    	display: none !important;
    }
     .uber-sp{
     	margin-bottom: 30px;
    	display: block !important;
    }

	/* what's new */
	.whats-new .whatsnew-list .whatsnew-title {
		max-width: 200px;
	}
	.whats-new .whatsnew-list {
		float: none;
		width: 100%;
		margin-right: 0;
	}
	.whats-new .whatsnew-list dt {
		float: none;
		padding: 2px 5px 0;
	}
	.whats-new .whatsnew-list dd {
		padding: 0 5px 2px 10px;
	}
	.whats-new .whatsnew-list dd::before {
		content: "\f138";
  		font-family: FontAwesome;
		width: 10px;
		padding-right: 3px;
	}
	.whats-new .whatsnew-list .new_mark {
		padding: 1px 5px;
	}

	.whats-new .whatsnew-photo {
	    float: none;
	    width: 80%;
	    padding: 0 0 10px;
	    margin-left: auto;
	    margin-right: auto;
	    background: none;
	}
	#shop-area .shopimage div {
		float: none;
		width: 90%;
		margin: 0 auto 20px auto;
	}
	#shop-area .shopimage img {
		width: 100%;
	}

	#header_bg h2 {
	    letter-spacing: 3px;
	    font-size: 20px;
	}
	
	.menupage dl {
	    float: none;
	    width: 100%;
	    margin: 0;
	    font-size: 100%;
	    overflow: hidden;
	    border-bottom: dashed 1px #b3966d;
	}

}

@media screen and (max-width: 600px) {
	body {
		line-height: 1.4;
		letter-spacing: .5;
	}
	/* --------------- header */
	#header .inner_res,
	#header.on .inner_res,
	#header .logo {
		-webkit-transition: none;
		transition: none;
	}
	#header h1 {display: none;}
	#header .logo,
	#header.on .logo {
		float: left;
		margin: 0;
		width: 220px;
	}
	#header_bg .header_bg_in.under {width: 200%;left: -50%;}


	/* --------------- index */
	.row {padding: 30px 0;}


	/* what's new */
	.whats-new .whatsnew-list dl {
		height: 150px;
		overflow-y: auto;
		font-size: 95%;
	}
	/* --------------- footer */
	#footer .ft-box li {
		margin-bottom: 0 !important;
		padding: 5px 0;
	}
	#footer .ft-box li.ft-box02{
		width: 25%;
	}
	#footer .ft-box li.ft-box03 {
		width:75%;
	}
	#footer .ft-box .title {display: none;
	}
	#footer .sns {
		max-width:75%;
		text-align: center;
	}
	#footer .sns img {
		margin-bottom: 5px;
	}
	#footer .sns dt {
		width: 100%;
	}
	#footer .sns dd {
		display: none;
	}
	#footer .ft-box li {
	    margin: 0;
	    padding: 5px 0;
	}
	#footer .ft-box .ft-menu li {
		padding: 8px 1%;
		text-align: center;
		list-style-type: none;
		background: rgba(133,82,12,.5);
		margin:1% 1% !important;
		float: left;
		width: 45%;
		font-size: 85%;
	}


	#gallery {
		padding: 
		20px 0;
	}
	#gallery h2 {
    	font-size: 110%;}

	#gallery .menubtn {
	    float: none;
	    width: 80%;
	    padding: 15px 5%;
	    margin: 0 25px;
	    font-size: 120%;
	    margin-bottom: 10px;
	}
	#shop-area .col {
	    float: none;
	    width: 100%;
	    margin: 0 0 10px 0; 
	    padding: 2% 0;
	    letter-spacing: 0;
	    color:#fff;
	}
	#shop-area .logo {
	    width: 50%;
	}

	#shop-area .col .menubtn {
		letter-spacing: .1em;
	}
	#shop-area .col01 img {
		width: 85%;
	}
	#shop-area .col03 .bento {
		margin:0;
	}
	.menupage dl {font-size: 90%;}


	/* ---------------- gmap */
	#gmap {height: 300px;}

	/* --------------- contact */
	/* table */
	#contact_table th,
	#contact_table td {
		display: block;
		width: 100%;
		text-align: left;
	}
	#contact_table th {
		padding: 0 0 2px;
		border-right: none;
		border-bottom: #d1bf9c 2px solid;
	}
	#contact_table td {
		padding: 10px 10px 30px;
		box-sizing: border-box;
		font-size: 14px;
	}

	#contact_table .input_content {text-align: left;}
	#contact_table tr:last-child td {padding-bottom: 0;}
	
	/* text textarea */
	#contact_table input[type="text"],
	#contact_table textarea {width: 100%;}


	#contact_table .age {
    	width: 50px !important;
	}
	/* btn */
	#contact_btns .btn {
		width: 45%;
		max-width: 190px;
		margin: 0 2%;
	}

	#mailer p {
		text-align: left;
	}

	/* --------------- what's new */
	#news_view .photo {
	float: none;
	max-width: 80%;
	margin-right: 0;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 15px;
	}

	.recruitpage dt {
	    float: none;
	    width: 100%;
	    text-align: left;
	}
	.recruitpage dd {
	    float: none;
	    width: 100%;
	    border-top: none;
	}
}

