@charset "utf-8";

/* reset
------------------------------------------------------------*/
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin:0;padding:0;}
ol, ul ,li {list-style: none;}
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;}
ul{list-style:none;}
table{border-collapse:collapse;border-spacing:0;}
caption,th{text-align:left;}
q:before,q:after{content:'';}
object,embed{vertical-align:top;}
legend{display:none;}
h1,h2,h3,h4,h5,h6{font-size:100%;}
img,abbr,acronym,fieldset{border:0;}

/* bace
------------------------------------------------------------*/
body {
  font-size: .9em;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Times New Roman", Times, serif;
  font-weight: normal;
  font-variant-ligatures: none;
  /*合字回避*/
  -webkit-text-size-adjust: 100%;
  /*iPhone用*/
  text-rendering: optimizeLegibility;
  /*カーニング*/
  overflow-x: hidden;
  color: #000;
  background: #fff;
}
#wrapper {
  /* 一番大きな囲み */
}
#content_wrapper {
  /* つぎに大きな囲み */
  max-width: 960px;
  margin: 0 auto;
}
.inner {
  width: 94%;
  margin: 0 auto;
  padding-bottom: 80px;
}
.innerS {
  width: 80%;
  margin: 0 auto;
}
.clear {
  clear: both;
}
.color {
	color: #C00;
}
.box_shadow {
	/*角丸*/
	border-radius: 4px;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	/*ボックスシャドウ*/
	box-shadow: 0px 0px 4px #ccc;
	-moz-box-shadow: 0px 0px 4px #ccc;
	-webkit-box-shadow: 0px 0px 4px #ccc;
	text-decoration: none;
}
.border-bottom {
	border-bottom: dotted 1px #C00;
}
.margin5 {
	margin-top: 5px;
}.margin10 {
	margin-top: 10px;
}
.column{
  display:block;
  text-align: justify;
/*コラム数*/
  column-count:2;
  -webkit-column-count:2;
  -moz-column-count:2;
/*コラム間隔*/
  column-gap:20px;
  -webkit-column-gap:20px;
  -moz-column-gap:20px;
}
@media screen and (max-width: 900px) {
  .column{
  display:block;
  text-align: justify;
/*コラム数*/
  column-count:1;
  -webkit-column-count:1;
  -moz-column-count:1;
  }
  }

/* リンク設定
------------------------------------------------------------*/
a {
  color: #000;
  text-decoration: none;
}
a:hover {
  color: #A0A0A0;
  text-decoration: none;
}
a:active, a:focus, input:active, input:focus {
  outline: 0;
}


/* ヘッダー
------------------------------------------------------------*/
#header h1 {
	font-size: 2.6em;
	color: #930323;
	font-weight: bold;
	line-height: 1.5em;
	margin: 20px 0px 10px 30px;
	float: left;
}
#en {
	font-size: 1.6em;
  	letter-spacing: .1em;
}
#info{
	float: right;
}
#info_tel{
	font-size: 1.4em;
	text-align: right;
	line-height: 1.2em;
	vertical-align: top;
}
#info_web{
	font-size: 1em;
	line-height: 2em;
	text-align: right;
}
#info {
  float: right;
  margin: 30px 30px 10px 0px;
}
#info_tel {
  text-align: right;
}
@media screen and (max-width: 900px) {
  #header h1 {
    font-size: 2em;
  }
  #info_web {
    display: none;
  }
}
@media screen and (max-width: 650px) {
#info_tel{
	font-size: 1.2em;
}
}
@media screen and (max-width: 600px) {
	#header {
	/*ボックスシャドウ*/
	box-shadow: 0px 0px 6px #555;
	-moz-box-shadow: 0px 0px 6px #555;
	-webkit-box-shadow: 0px 0px 6px #555;
	text-decoration: none;
}
  #info {
    display: none;
  }
}

/* グローバルナビゲーション
------------------------------------------------------------*/
#mainnav a {
  color: #fff;
}
@media screen and (min-width: 961px) {
  a#menu {
    display: none;
  }
  .panel {
    display: block !important;
  }
  ul a { 
    display: block; 
  }
  #mainnav ul {
  background: #C00;
  }
  #mainnav li {
    font-size: .9em;
    letter-spacing: 0.1em;
    text-align: center;
    width: 16.57%;
    display: inline-block;
    margin: 0px;
    padding: 10px 0px;
    border-left: 1px solid #fff;
  }
  #mainnav li:hover {
	background-color: #561414;
  }
  #mainnav li:first-child {
    border-left: none;
  }
}
@media screen and (min-width: 601px) and (max-width: 960px) {
  a#menu {
    display: none;
  }
  .panel {
    display: block !important;
  }
  ul a { 
    display: block; 
  }
  #mainnav ul {
    background-color: #C00;
  }
  #mainnav li {
    font-size: .9em;
    letter-spacing: 0.1em;
    text-align: center;
    width: 33.1%;
    display: inline-block;
    margin: 0px;
    padding: 10px 0px;
    border-left: 1px solid #fff;
    border-bottom: 1px solid #fff;
  }
  #mainnav li:hover {
    background-color: #561414;
  }
  #mainnav li:first-child {
    border-left: 1px solid #fff;
  }
}
@media screen and (max-width: 600px) {
  #header {
    position: fixed;
    width: 100%;
    z-index: 500;
  }
  #header h1 {
    font-size: 1.8em;
    margin-top: 0px;
    padding-top: 16px;
    text-align: center;
  }
  #headerWrap {
    position: relative;
    width: 100%;
    height: 70px;
    background: #fff;
    border-bottom: 1px solid #fff;
  }
  a#menu {
    display: inline-block;
    position: relative;
    width: 40px;
    height: 40px;
    margin: 10px;
  }
  #menuBtn {
    display: block;
    position: absolute;
    top: 60%;
    left: 50%;
    width: 18px;
    height: 2px;
    margin: -1px 0 0 -7px;
    background: #000;
    transition: .2s;
  }
  #menuBtn:before, #menuBtn:after {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 18px;
    height: 2px;
    background: #000;
    transition: .3s;
  }
  #menuBtn:before {
    margin-top: -7px;
  }
  #menuBtn:after {
    margin-top: 5px;
  }
  a#menu .close {
    background: transparent;
  }
  a#menu .close:before, a#menu .close:after {
    margin-top: 0;
  }
  a#menu .close:before {
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
  }
  a#menu .close:after {
    transform: rotate(-135deg);
    -webkit-transform: rotate(-135deg);
  }
  #mainnav {
    position: absolute;
    top: 0;
    width: 100%;
    text-align: right;
    z-index: 500;
  }
  #mainnav ul {
    font-size: .8em;
    background: #C00;
    text-align: center;
    clear: both;
  }
  #mainnav li a {
    position: relative;
    display: block;
    padding: 10px 0px;
    border-bottom: 1px solid #fff;
  }
  #mainnav li a:before {
    display: block;
    position: absolute;
    top: 50%;
    left: 5px;
    width: 6px;
    height: 6px;
    margin: -4px 0 0 0;
    border-top: solid 2px #000;
    border-right: solid 2px #000;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
}

/* メイン画像
------------------------------------------------------------*/
#main_img {
  width: 100%;
  margin-bottom: 38%;
}
#main_img img {
  width: 100%;
  height: auto;
  margin-top: 2px;
}
#slideshow {
    position: relative;
}
#slideshow img {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 8;
}
#slideshow img.active {
    z-index: 10;
}
#slideshow img.last-active {
  z-index: 9;
}
@media screen and (max-width: 601px) {
  /* メインイメージ非表示 */
  .pc_part {
    display: none;
  }
  #main_img {
    display: none;
}
}
@media screen and (min-width: 600px) {
  /* メインイメージ非表示 */
  .sp_part {
    display: none;
  }
}

/* コンテンツエリア
------------------------------------------------------------*/
.content {
	width  : 100%;
}
.title{
	font-size: 1.2em;
	color: #fff;
 	font-weight: bold;
    text-align: center;
	width: 100%;
	background-color: #930323;
	margin: 20px 0 20px 0;	
	padding: 4px 0 6px 0;
	/*角丸*/
	border-radius: 4px;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
}
.sub_title{
	font-size: 1.6em;
	color: #C00;
	font-weight: bold;
	width: 100%;
}
.text-indent{
	text-indent: -10px;
}

/* くずはモールオープン
------------------------------------------------------------*/
#new_open{
	font-size: 2em;
	line-height: 1.4em;
	color: #FF0003;
	text-align: center;
	margin: 0px 0 10px 0;
	padding-top: 30px;
	text-decoration: none;
}
#kuzuha{
	font-size: 1em;
	line-height: .8em;
	text-align: center;
	text-decoration: none;
}
@media only screen and (max-width: 900px) {
  #new_open{
	font-size: 1.6em;
  }
  }
  @media screen and (max-width: 1200px) {
  .new_line2 {
    display: inline-block;
  }
}

/* SEC01 トップ
------------------------------------------------------------*/
#sec01{
	background-color: #fff;
	padding: 20px 0 20px 0;
}
/* 予約 */
.reserve {
	font-size: 1.1em;
	line-height: 1.2em;
	color: #fff;
	text-align: center;
	background-color: #f90;
	margin: 0px 0 10px 0;
	padding: 8px 0 8px 0;
	text-decoration: none;
	/*角丸*/
	border-radius: 4px;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	/*ボックスシャドウ*/
	box-shadow: 0px 0px 4px #ccc;
	-moz-box-shadow: 0px 0px 4px #ccc;
	-webkit-box-shadow: 0px 0px 4px #ccc;
}
.reserve:hover {
	color: #f90;
	background-color: #fff;
	border: 1px solid #f90;
}
h2 {
	font-size: 1.5em;
	color: #930323;
	font-weight: bold;
	line-height: 1.4em;
	text-align: center;
	margin-top: 20px;
	margin-bottom: 6px;
}
.winter {
	font-size: 1.7em;
	color: #FA3964;
	font-weight: bold;
	line-height: 1.4em;
	text-align: center;
	margin-top: 12px;
	margin-bottom: 10px;
	padding-bottom: 3px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
}
.winter_text{
	font-size: 1.2em;
	line-height: 1.5em;
	color: #000;
	text-align: center;
	margin-bottom: 24px;
}
.content_text_top{
	font-size: 1em;
	line-height: 1.8em;
	color: #000;
	text-align: justify;
	overflow-x: hidden;
}
/*お知らせ*/
.news {
	font-size: 1em;
	color: #FF0003;
	background-color: #fff;
	text-align: center;
	margin-top: 20px;
	padding: 4px 0px 4px 0px;
	border: 1px solid;
	/*角丸*/
	border-radius: 2px;
	-moz-border-radius: 2px;
	-webkit-border-radius: 2px;
}
.news_text_top {
	color: #C00;
	font-size: .9em;
	line-height: 1.4em;
	margin: 20px 0px 20px 0px ;
}
.news_text {
	font-size: .9em;
	line-height: 1.4em;
	margin-bottom: 6px;
}
.fb {
	float: left;
	width: 40px;
	margin: 16px 16px 0 0;
}
.fb_text {
	font-size: 1em;
	color: #3B5998;
	display: table-cell;
	vertical-align: middle;
	padding-top: 24px;
  }
  /* sp設定*/
@media screen and (max-width: 480px) {
.fb {
	width: 30px;
	margin: 0;
	margin: 16px 10px 10px 0;
	padding: 0;
	float: left;
}
.fb_text {
	font-size: .8em;
	line-height: 0em;
	padding-top: 32px;
  }
}
/* SEC02 こだわり
------------------------------------------------------------*/
#sec02{
	background-color: #F4F5EA;
	padding: 20px 0 20px 0;
}
/* SEC03 メニュー
------------------------------------------------------------*/
#sec03{
	background-color: #fff;
	padding: 20px 0 20px 0;
}
/* アコーディオン----------------*/
/*全体*/
.hidden_box {
	margin: 1em 0;/*前後の余白*/
	padding: 0;
}
/*ボタン装飾*/
.hidden_box label {
	font-size: 1.2em;
	color: #930323;
	background-color: #FEFCE2;
	text-decoration: none;
	margin: 10px auto 0 auto;
	width: 100%;
	padding: 5px 0 5px 0;
	font-weight: 500;
	border: 1px solid #930323;
	display: block;
	cursor : pointer;
	text-align: center;
	/*角丸*/
	border-radius: 3px;
	-moz-border-radius: 3px;
	-webkit-border-radius: 3px;
}
.attention_text {
	font-size: .9em;
}
/*ボタンホバー時*/
.hidden_box label:hover {
	color: #fff;
	background-color: #540214;
}
/*チェックは見えなくする*/
.hidden_box input {
    display: none;
}
/*中身を非表示にしておく*/
.hidden_box .hidden_show {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}
/*クリックで中身表示*/
.hidden_box input:checked ~ .hidden_show {
    padding: 10px 0;
	width: 100%;
    height: auto;
    opacity: 1;
}
.ac {
	width: 100%;
	height: auto;
}
/*ここからメニュー設定*/
.menu_course {
	width: 300px;
	float: left;
}
.menu_sub_title{
	font-size: 1.6em;
	color: #C00;
	font-weight: bold;
	width: 100%;
}
.menu_course_piece {
	color: #930323;
	font-weight: bold;
	font-size: 1.4em;
	line-height: 1.2em;
}
.menu_piece {
	color: #930323;
	font-weight: bold;
	font-size: 1.4em;
	line-height: 1.8em;
}
.menu_tax {
	font-size: .8em;
}
@media screen and (max-width: 480px) {
.menu_piece {
	font-size: 1.1em;
	line-height: 1.5em;
}
.menu_sub_title{
	font-size: 1.2em;
}
}
.menu_minititle {
	font-weight: bold;
	font-size: 1.2em;
	color: #FF0003;
	margin: 14px 0px 6px 0px;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #FF0003;
}
.menu_text {
	font-size: 1.1em;
	line-height: 1.4em;
	margin-top: 6px;
}
.menu_cap {
	font-size: .9em;
	line-height: 1em;
	padding: 0;
	margin-bottom: 8px;
}
.menu_course_menu {
	font-size: 1em;
	color: #930323;
	line-height: 1.7em;
	margin-top: 6px;
}
.menu_motsu {
	padding-right: 40px;
	margin-bottom: 30px;
}
.menu_motsu_subtitle {
	font-size: 1em;
	color: #930323;
}
.menu_tsuikamenu {
	font-size: 1em;
	line-height: 1.4em;
}

/* SEC04 店舗情報
------------------------------------------------------------*/
#sec04{
	background-color: #F4F5EA;
	padding: 20px 0 20px 0;
}
.shop_img_box {
	width: 100%;
	margin: 6px 0 6px 0;
}
.shop_img {
	width: 32%;
	margin-right: 1.4%;
	/*角丸*/
	border-radius: 4px;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	/*ボックスシャドウ*/
	box-shadow: 0px 0px 4px #ccc;
	-moz-box-shadow: 0px 0px 4px #ccc;
	-webkit-box-shadow: 0px 0px 4px #ccc;
	text-decoration: none;
}
.shop_img2 {
	width: 32%;
	/*角丸*/
	border-radius: 4px;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	/*ボックスシャドウ*/
	box-shadow: 0px 0px 4px #ccc;
	-moz-box-shadow: 0px 0px 4px #ccc;
	-webkit-box-shadow: 0px 0px 4px #ccc;
	text-decoration: none;
}
.read_copy{
	font-size: 1.3em;
	width: 100%;
	color: #FF0003;
	border-bottom: dotted 1px #FF0003;
	margin: 6px 0 6px 0;
}
.shop_time {
	font-size: 1.1em;
	line-height: 1.4em;
	padding-bottom: 4px;
	padding-left:6em;
	text-indent:-6em;
}
.shop_info {
	font-size: 1.1em;
	line-height: 1.4em;
	padding-bottom: 4px;
}
@media screen and (max-width: 480px) {
  .shop_info {
	font-size: 1em;
	line-height: 1.4em;
	padding-bottom: 5px;
	padding-left:1em;
	text-indent:-1em;
}
.time_indent {
	text-indent:3.3em;
}
}
.last_order {
	font-size: .2em;
}
.shop_attention {
	font-size: .9em;
	line-height: 1.4em;
}
.info_tel {
	font-size: 1.3em;
	line-height: 1.5em;
	color: #C00;
	}

/* SEC05 アクセス
------------------------------------------------------------*/
#sec05{
	background-color: #fff;
	padding: 20px 0 20px 0;
}
.access_info{
	font-size: 1.2em;
	line-height: 1.3em;
	padding-top: 6px;
}
.access_text{
	font-size: 1em;
	line-height: 1.4em;
	padding-top: 4px;
	padding-bottom: 10px;
}
/* フッター
------------------------------------------------------------*/
#footer{
	font-size: .8em;
	text-align: center;
	border-top: dotted 1px #000;
	border-top-width: 100%;
	padding: 16px 0 16px 0;
}

/* ページtopへ戻る
------------------------------------------------------------*/
#page-top {
	position: fixed;
	bottom: 14px;
	right: 10px;
	font-size: 0.8em;
	line-height: 1em;
}
#page-top a {
	text-decoration: none;
	color: #000;
	text-align: center;
	display: block;
}
#page-top a:hover {
	text-decoration: none;
}

/* レスポンシブ表示・非表示
------------------------------------------------------------*/
@media screen and (max-width: 480px) {
  .br-sp {
    display: none;
  }
  span {
    display: inline-block;
  }
}
@media screen and (max-width: 580px) {
  .br-tb {
    display: none;
  }
  span-tb {
    display: inline-block;
  }
}

/* レスポンシブ強制改行
------------------------------------------------------------*/
@media screen and (max-width: 500px) {
  .new_line {
    display: inline-block;
  }
}