contact
@charset "UTF-8";

/* reset
----------------------------------- */

* {
	margin:0px;
	padding:0px;
}

body,
h1, h2, h3, h4, h5, h6,
p, address, blockquote, pre, div,
dl, ol, ul, li,img,
form, input, select, textarea, fieldset, legend { 
	margin: 0; 
	padding: 0; 
}

h1, h2, h3, h4, h5, h6,
p, address, blockquote, pre, div,
dl, ol, ul,
th { 
	font-weight: normal;
	font-style: normal; 
}

strong { 
	font-weight:normal; 
	font-style: normal; 
}

img {
	border: none;
}

ul {
list-style: none;
}


/* headline
----------------------------------- */

h1 {
	font-family:"ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
	font-size:17px;
	font-weight:300;
	text-align:center;
	line-height:40px;
	margin-bottom:20px;
	letter-spacing:0.15rem;

}

h2 {
	font-size:30px;
	font-weight:300;
	text-align:center;
	color: #1b1b1b;
	letter-spacing:0.15rem;
	
}

h2 span {
	font-size:16px;
	display:block;
	line-height:60px;
}


h2 span img {
	margin-top:10px;
}



h3 {
	font-size:30px;
	text-align:center;
}

h3 span {
	font-size:14px;
	display:block;
}

h3 span.sub {
	font-size:12px;
	display:block;
}


h4 {
	
}
h5 {
	font-size:14px;
	
	line-height:40px;
	border-top:1px solid #ececec;
	border-bottom:1px solid #ececec;
	padding:0 6px;
}
h5 span {
	border-left:2px solid #3e3f41;
	padding:0px 10px;
}



/* body
----------------------------------- */
html{
overflow-x : hidden;
overflow-y : auto;
}

body {	color: #121620;
	font-size: 12px;
	line-height: 28px;
	font-family:,uGothic, '游ゴシック', 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',Arial,Osaka,Sans-Serif;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	margin: 0;
	padding: 0;
	background: #fff;
}
a {	text-decoration:none; }
a:link {  color:#3d3c3c; text-decoration:none; }
a:visited {  color:#3d3c3c; text-decoration:none; }
a:hover {	color:#9a9a9a; }


input, select, textarea { 
	font-family: Verdana, Arial, sans-serif;
	color: #444; 	
	  -webkit-appearance: none;
}


/* class
----------------------------------- */

.clear {
	font-size: 0;
	line-height: 0;
	clear: both;
	height: 0px;
	visibility: hidden;
}

.ud {
text-decoration:underline;

}

.r {
	float:right;
}

.l {
	float:left;
}


.center {
text-align:center;

}

.left {
	text-align:left;
}

a span {
}
 
.pc {
	display:none;
}
.sp {
}


.mt10s {
margin-top:10px;
}
.mt15s {
margin-top:15px;
}
.mt20s {
margin-top:20px;
}

.mb5s {
margin-bottom:5px;
}
.mb10s {
margin-bottom:10px;
}
.mb15s {
margin-bottom:15px;
}
.mb20s {
margin-bottom:20px;
}
.mb25s {
margin-bottom:25px;
}
.mb30s {
margin-bottom:30px;
}
.mb40s {
margin-bottom:40px;
}
.mb50s {
margin-bottom:50px;
}

.mr10s {
margin-right:10px;
}
.mr15s {
margin-right:15px;
}
.mr20s {
margin-right:20px;
}
.mr30s {
margin-right:30px;
}
.pl10s {
padding-left:10px;
}

.ml5s {
margin-left:5px;
}
.ml10s {
margin-left:10px;
}
.ml15s {
margin-left:15px;
}
.ml20s {
margin-left:20px;
}
.mb50s {
margin-bottom:50px;
}

/* oowaku
----------------------------------- */

#all {
overflow-x : hidden;
position:relative;
}
.book-sm {
	position:fixed;
	right:0;
	bottom:100px;
	z-index:20;
}
.book-sm  img {
	width:45px;
	height:auto;
}
#all .book {
	visibility:hidden;
	display:none;
	width:0;
	height:0;
}

#container {
	margin:0 auto;
	width:100%;
}

#container-in2 {
	position: relative;
	width:100%;
	margin:0 auto;
}

#container-in2 h2 img {
	width:110px;
	
}
#container-in3 {
	position: relative;
	width:100%;
	margin:0 auto;
	padding:10px 4% 0px;
	text-align:center;
}
#container-in3 img {
	width:100%;
}

#container-in3 h2 img {
	width:280px;
	
}

#container-in4 {
	position: relative;
	width:100%;
	margin:0 auto;
	padding:0 4% 52px;
}

#container-in4 img {
	width:100%;
}
#container-in5 {
	width:100%;
	margin:0 auto 20%;;
	height:auto;
}


#container-in5 h2 img {
	width:250px;
}
#container-in5 h2 span img {
	width:60px;
}
#container-in6 {
	position: relative;
	width:100%;
	margin:0 auto;
	padding:0 4% 37px;
	background:#f1f1ec;
}



/* key
----------------------------------- */

.top-hero {display:none;}
.top-hero-sm {
	position:relative;
}
.top-hero-sm p.logo {
	text-align:center;
	width:100%;
	position: absolute;
    top: 35%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 2;

}
.top-hero-sm p.logo img {
	width:320px;
}

.scroll_sm {
	text-align:center;
	width:100%;
	position: absolute;
    top: 70%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 2;
}
.key_second {display:none;}
.key_second02 {display:none;}
.key_second_sm {
}
.key_second_sm img {width:100%;}

.key_second_sm02 img {width:100%;}

/* menu
----------------------------------- */
.menu-bar {
	width:100%;
	height:66px;
	background:#fff;
	position:fixed;
	top:0;
	left:0;
	z-index:10;
	
}
.menu-in {
	display:none;
}
.menu-sm {
	width:100%;
	height:66px;
	position:relative;
}
.menu-sm img {
	width:169px;position: absolute;
    top: 50%;
	left:50%;	transform: translate(-50%, -50%);
	
}




/* key_second 
----------------------------------- */
.key_second {
	display:none;
}

.key_second_sm {
	width:100%;
}

.key_second_sm img {
	width:100%;
}




/* copy & footer
----------------------------------- */

#footer {
	width:100%;
	margin:0 auto;
	text-align:left;
	background:#32322f;
	color:#fff;
}

.footer_in {
	width:100%;
	height:512px;
	position:relative;
	margin:0 auto;
	background:url(../img/bg_footer_in.png) no-repeat right top;
	background-size:100% auto;
	padding-top:35px;
	box-sizing:border-box;
	
}

.footer_in a {
	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;
}
.footer_in a:hover {
	opacity:0.7;
}

.footer_in a.footer_btn {
	display:block;
	text-align:center;
	margin-bottom:35px;
}

.footer_in a.footer_btn img{
	width:186px;
}

.footer_in table {
	text-align:left;
	width:80%;
	margin:0 auto;
}

.footer_in table td {
	display:block;
	width:100%;
}
.footer_in table td.tel {
	padding-bottom:30px;
	text-align:center;
}
.footer_in table td.tel img {
	width:270px;
}
.footer_in table td.txt {
	padding-bottom:30px;
}

.footer_in  p.footer_logo {
	text-align:center;
}

.footer_in  p.footer_logo img{
	width:154px;
	margin-bottom:25px;
}

p.footer_policy {
	text-align:center;
	}



#copyright {
	
	text-align:center;
	font-size:12px;
	color:#fff;
	width:100%;}

#copyright p {
	text-align:center;
}
#page-top {
position: fixed;
bottom: 20px;
right: 5%;
}
 
#page-top div a #img{
display:block;
width:44px;
height:0;
padding-top:44px;
overflow:hidden;
background:url(../img/page_top.png) no-repeat;
background-size:100% auto;
}
 
#page-top div a p:hover{
-moz-opacity:0.6;
opacity:0.6;
filter: alpha(opacity=60);
text-decoration:none;
}


/* ----------------------------------------------------------------------------------------------------
												top_contents
----------------------------------------------------------------------------------------------------- */

/* top_concept
----------------------------------- */

#container .concept {
	text-align:center;
	padding:0 4% 20px;
}



#container .concept ul {
	display:none;
}
a.youtube img {
	width:100%;
}


/* top_case
----------------------------------- */
#case {
	padding:28px 0 0;
}

#case ul {
	
}
#case ul li{
	display:table-cell;
}
#case ul li:nth-child(odd){
	width:49%;
	padding-right:1%;
	float:left;
}
#case ul li:nth-child(even){
	width:49%;
	padding-left:1%;	
	float:right;
}
#case ul li img {
}


#case ul li a.click{
	width:100%;
	height:auto;
	display:block;
	position:relative;
}
#case ul li a.click img{
	width:100%;
	height:auto;
}
#case ul li a {
	text-decoration:underline;
}
#case a:hover {
	opacity:0.8;
}

#case ul li a .loupe{
	display:none;
}

#case ul li a.click img.wide{
	width:18px;
	height:18px;
	position:absolute;
	bottom:6px;
	right:7px;
}

#case ul li span {
	font-size:9px;
	background:#e8e8e3;
	display:table;
	padding:0 15px;
	line-height:20px;
}
#case ul li p {
	line-height:20px;
	padding:15px 2% 20px;
}
#case ul li p em {
	display:none;
}

#case ul li p b {
	font-size:13px;
	line-height:25px;
	display:block;
	font-weight:normal;
}



/* top_plan
----------------------------------- */
#price {
	width:100%;
	margin:0 auto;
	padding:33px 0 20px;
}

#price  h3 {
	text-align:center;
	margin-bottom:30px;
}
#price .cont_l {
	width:92%;
	float:inherit;
		padding:20px 10px ;
	margin:0 auto;
	background:#f0f0ec;
	border:1px solid #e5e5de;
	margin-bottom:33px;
}
#price .cont_l h3 img {
	width:140px;
}

#price .cont_r {
	width:92%;
	float:inherit;
		padding:20px 10px ;
	margin:0 auto;
	background:#f0f0ec;
	border:1px solid #e5e5de;
	margin-bottom:33px;
}
#price .cont_r h3 img {
	width:130px;
}



#price .cont_l table,#price .cont_r table {
	width:100%;
	margin:0 auto;
}
#price .cont_l table b,#price .cont_r table b {
	font-family: "Avenir Next" !important;
	font-weight:normal;
	font-size:30px;
	padding-left:20px;
}
#price .cont_l table td.plus,#price .cont_r table td.plus {
	font-weight:bold;
	font-size:20px;
	}
#price .cont_l table td.last,#price .cont_r table td.last {
	font-weight:bold;
	padding-top:10px;
	}

#modal-overlay{
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:120%;
	background-color:rgba(0,0,0,0.60);
	z-index:9999;
}

#product_detail {
	width:100%;
	height:560px;
	position:relative;
	background:#fff;
}


#product_detail img{
	width:100%;
	margin-bottom:10px;
}



a.delete {
	position:absolute;
	top:14px;
	right:12px;
}
#product_detail a.PopPrev img,#product_detail a.PopNext img {
	width:12px;
}
a.PopPrev {
	position: absolute;
	top: 140px;
	left: 5px;
}

a.PopNext {
	position: absolute;
	top: 140px;
	right: 5px;
}
#product_detail h4 {
	font-size:15px;
	margin-bottom:10px;
}
#product_detail p {
	padding-bottom:50px;
}
.product_detail01 {	
	width:100%;
	height:560px;
	padding:50px 25px 0;
	overflow-y:auto;
	overflow-x:hidden;
	box-sizing:border-box;
}
.product_detail02 {	
	width:100%;
	height:560px;
	padding:50px 25px 0;
	overflow-y:auto;
	overflow-x:hidden;
	box-sizing:border-box;
}
.product_detail03 {	
	width:100%;
	height:560px;
	padding:50px 25px 0;
	overflow-y:auto;
	overflow-x:hidden;
	box-sizing:border-box;
}
.product_detail04 {	
	width:100%;
	height:560px;
	padding:50px 25px 0;
	overflow-y:auto;
	overflow-x:hidden;
	box-sizing:border-box;
}
.product_detail05 {	
	width:100%;
	height:560px;
	padding:50px 25px 0;
	overflow-y:auto;
	overflow-x:hidden;
	box-sizing:border-box;
}
.product_detail06 {	
	width:100%;
	height:560px;
	padding:50px 25px 0;
	overflow-y:auto;
	overflow-x:hidden;
	box-sizing:border-box;
}


/* モーダルCSS */
.modalArea {
  display: none;
  position: fixed;
  z-index: 10; /*サイトによってここの数値は調整 */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
 
}

.modalBg {
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.60);
}

.modalWrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform:translate(-50%,-50%);
  width:92%;
  max-width: 961px;

height: 560px;
  overflow : auto; 
  padding: 45px 0 0;
  background-color: #fff;
color:#494947;
box-sizing:border-box;

}

.modalWrapper.newyear_modal{
	height: 360px;
	padding: 55px 0 0;
}

.modalWrapper.newyear_modal p{
	text-align: center;
}

.modalWrapper.newyear_modal .Contents03{
	padding: 20px 4%;
}

.modalContents {
	position:relative;
	
}

.closeModal {
  position: absolute;
  top: 0.5rem;
  right: 1rem;
  cursor: pointer;
}
.Contents01 {
	padding:0 4%;
	
}
.modalContents  h2 {  
color:#494947;
	margin-bottom:30px;
}
.modalContents  h2 span{
	font-size:17px;
	line-height:30px;
}
.modalContents  h2 img{
	width:100px;
	height:auto;
	margin-bottom:35px;
}
.modalContents  p{
color:#494947;
	text-align:center;
}


.Contents02 {
	padding:32px 4% 20px;
	background:#f1eee8;	
}
.Contents02 .waku {
	background:#fff;
	border-radius:15px;
	padding:30px 4%;
	margin-bottom:30px;
}

.Contents02 .waku h3 {
	font-weight:bold;
	font-family:Avenir;
	font-size:23px;
	margin-bottom:15px;
}

.Contents02 .waku:first-child {
	padding:15px 4%;
}

.Contents02 .waku:first-child h3 {
	border-bottom:1px solid #494947;
	padding-bottom:10px;
	margin-bottom:10px;
	font-size:16px;
}
.Contents02 .flex-area { width: 100%;
	display:flex; 
		justify-content: space-between;
	flex-wrap:wrap;
	box-sizing:border-box;
}
.Contents02 .flex-area .waku {
	background:#fff;
	border-radius:25px;
	padding:15px;
	margin-bottom:30px;
	width:48%;
}

.Contents02 .flex-area .waku:first-child {
	padding:15px;
}

.Contents02 .flex-area .waku:first-child h3 {
	border-bottom:none;
	padding-bottom:0;
	margin-bottom:20px;
	font-size:23px;
}
.Contents02 .flex-area h3 {
	margin-bottom:10px;
}

.Contents03 {
	padding:45px 4%;
}
.Contents03 .close_btn {
	width:80%;
	margin:20px auto 0;
	height:42px;
	border-radius:50px;
	background:#4a4a47;
	color:#fff;
	display:block;	
}
.Contents03 .close_btn:hover {
	opacity:0.7;
}




/* top_kiyaku
----------------------------------- */


#kiyaku {
	padding-bottom:25px;
}
p.open {
	margin-bottom:10px;
	text-align:center;
}
/* アコーディオンA */
.ac-box{
width: auto;
margin: 0px auto 5px;
}

/*ラベル*/
.ac-box label{
font-size: 16px;
text-align: center;
margin: auto;
position: relative;
display: block;
border-radius: 8px;
cursor: pointer;
transition: all 0.5s;
width:80px;
height:27px;
white-space:nowrap;
}


/*チェックを隠す*/
.ac-box input{
display: none;
}

/*チェックのアイコン（↓）*/
.ac-box label:before{
font-family:"FontAwesome";
content:" \f078";
background:url(../img/down.png) no-repeat center center;
background-size:80% auto;
display:block;
color:#fff;
}

/*チェックのアイコン（↑）*/
.ac-box input:checked ~ label::before {
font-family:"FontAwesome";
content:" \f077";
background:url(../img/up.png) no-repeat center center;
background-size:80% auto;
display:block;
color:#fff;
}
.ac-box input:checked ~ label {
	
color:#fff;
}

/*中身を非表示にしておく*/
.ac-box div{
height: 0px;
padding: 0px;
overflow: hidden;
opacity: 0;
transition: 0.5s;
}

/*クリックで中身を表示*/
.ac-box input:checked ~ div{
height: auto;
padding: 5px;
opacity: 1;
padding-top:30px;
}

/*表示内容の調整*/
.ac-small dl{
	width:100%;
	margin:0 auto;
	text-align:left;
}

.ac-small dl dt{
	font-weight:bold;
	font-size:15px;
	padding-bottom:10px;
}

.ac-small dl dd{
	padding-bottom:30px;
}


.ac-small p.border {
	border:1px solid #e5e5de;
	width:100%;
	margin:0 auto;
	text-align:left;
	box-sizing:border-box;
	padding:15px 20px;
}

/* top_insta
----------------------------------- */
#container-in6 h2 {
	text-align:center;
}
#container-in6 h2 img {
	width:147px;
	margin-bottom:49px;
}
div.insta_pc {
	display:none;
}



/* second
----------------------------------- */
#second {
	width:100%;
	margin:0 auto;
	
	padding:30px 0 0;
}
#second h2 {
	text-align:center;
	margin-bottom:10px;
}

#second h2 img {
	width:160px;
	font-weight:bold;
}



#second  p.txt {
	text-align:center;
}
/* form.html
----------------------------------- */
#booking {
	margin:30px auto 86px;
	text-align:left;
	font-size:11px;
	line-height:28px;
	
}
#booking h3 {
	width:100%;
	font-size:14px;
	line-height:50px;
	text-align:center;
	border-top:1px solid  #dcdcdc;
	border-bottom:1px solid  #dcdcdc;
	margin-bottom:30px;	
	display:table;
}
#booking h3 span {
	display:table-cell;
	font-size:14px;
}
#booking h3 span.active {
	border-bottom:4px solid #dcdcde;
}


#booking .cont_l {
	padding:0 4% 30px;
}

#booking .cont_r img {
	width:100%;
	margin-bottom:20px;
}


/*カレンダー*/
.cal_wrapper {
  max-width: 394px; /* 最大幅 */
  min-width: 90%; /* 最小幅 */
  margin: 2.0833% auto 25%;
}
 
.googlecal {
  position: relative;    padding-bottom: 100%;
  height: 0;
}
.googlecal iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 120% !important;
}

/* contact
----------------------------------- */

#form {
	width:92%;
	padding:0 4%;
	margin:0px auto;
}

#form h1 {
	margin-bottom:30px;
	}



table.form {
	width:100%;
}

table.form td{
	color:#535545;
	font-size:11px;
	padding:0 0 9px;
	text-align:left;
	line-height:28px;
	border-top:none;
}

table.form td span {
	color:#f39700;
}

table.form td input.form_text {
    -webkit-appearance:none;
    -moz-appearance:none;
    appearance:none;
	width:100%;
	border:none;
	
	border:1px solid #dcdcdc;
	height:38px;
	margin-top:3px;
	font-size:11px;
	text-indent:10px;
}

table.form select {
}

table.form select.form_text {
    -webkit-appearance:none;
    -moz-appearance:none;
    appearance:none;
    text-indent: .01px; /*Firefox用*/
    text-overflow: ""; /*Firefox用*/
	height:38px;
	border:none;
	width:100%;
	font-size:11px;
	text-indent:5px;
	background:url(../img/select_arrow.png) no-repeat right;
	background-size:auto 38px;
	border:1px solid #dcdcdc;
	margin-top:3px;
}

/* css checkbox01 */
table.form td.option span {
	color:#535545;
}
.checkbox01-input{
  display: none;
}
.checkbox01-parts{
  padding-left: 32px;
  position:relative;
  margin-right: 10px;
  line-height:52px;
  padding-top:5px;
  letter-spacing:-0.03em;
}
.checkbox01-parts::before{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 23px;
  height: 23px;
  background:#ebebe3;
}
.checkbox01-input:checked + .checkbox01-parts{
  color: #535545;
}
.checkbox01-input:checked + .checkbox01-parts::after{
  content: "";
  display: block;
  position: absolute;
  top: 4px;
  left: 8px;
  width: 5px;
  height: 11px;
  transform: rotate(40deg);
  border-bottom: 3px solid #535545;
  border-right: 3px solid #535545;
}



table.form input.form_text02 {
	width:66px;
	border:none;
	background:#ebebe3;
	height:49px;
	margin-top:10px;
	margin-right:20px;
	font-size:11px;
	text-indent:10px;
}





table.form td textarea{
	box-sizing:border-box;
	width:100%;
	padding:10px;
	height:147px;
	font-size:10px;
	overflow-y:auto;
	
	border:1px solid #dcdcdc;
	margin-top:3px;
	line-height:18px;
}

p.to_policy {
	text-align:center;
}

p.to_policy a {
	text-decoration:underline;
	background:url(../img/bg_kiyaku.png) no-repeat center right;
	padding-right:17px;
}
p.to_policy a:hover {
	text-decoration:none;
}

div.agree {
	display:block;
	text-align:center;
	width:100%;
	margin:20px auto 0;
}
 
 
 div.policy h4{
	 line-height:52px;
 }
 
 div.policy {
	 width:100%;
	 padding: 10px;
	 height:187px;
	 margin:0 auto;
	 overflow-y:auto;
	border:1px solid #dcdcdc;
	background:#f5f5f2;
	line-height:23px;
	font-size:11px;
	margin-bottom:30px;
	 
 }


.submit_pc {
	display:none;
}

.submit_sm {
	text-align:center;
	width:285px;
	height:65px;
	display:block;
	cursor:pointer;
	margin:30px auto 0;
}


.submit_sm  input {
	width:285px;
}


div.cont_l02 span,div.cont_l02 a {
	color:#f39700;
}



table.form02 {
	width:96%;
	margin:30px auto 0;
	text-align:left;
}

table.form02 td {
	padding:0 10px;
	padding-bottom:10px;
}
table.form02 td span {

    color: #f39700;

}
table.form02 td.next{
	padding:0;
  border-left: solid 5px #ccc;/*左線（実線 太さ 色）*/
  padding-left:10px;
  padding-left:10px;
}
p.kakunin {
	text-align:center;
	margin-top:20px;
}
p.kakunin span {
	display:block;
}
#book #form  table.form02 th {

    padding: 0;
        padding-left: 0px;
    border-left: solid 2px #ccc;
    padding:5px 8px;
	position:relative;
	display:inline;
	font-size:12px;
	

}
 #book #form  table.form02 td.text {
 }
 #book #form  table.form02 th strong {
	background:#ffa948;
	color:#fff;
	font-size:13px;
	line-height:24px;
	width:67px;
	display:inline-block;
	text-align:center;
	position:absolute;
	right:5px;
	top:0px;
}

 #book #form  table.form02 td.text-right {
	 text-align:right;
 }


/* top_menu
----------------------------------- */

ul.service_link {
	width:100%;
	margin:0 auto 10px;
	display:flex;    justify-content: center;
}
ul.service_link li {
	width:33%;
	border:1px solid #ccc;
	margin-right: 7px;
}
#container-in3 ul.service_link li img {
	height:24px;
	width:auto;
	margin-bottom:5px;
}
ul.service_link li  a{
	width:33%;
	height:auto;
	display:block;
	background:url(../img/bg_service_link_sp.png) right bottom no-repeat;
	background-size:	10px;
	display:table-cell;
	text-align:center;
	vertical-align:middle;
	font-size:12px;
	line-height:18px;
	padding:5px 0;
}
#menu {
	margin:0 auto;
	padding:30px 0% 0px;
}
#container-in3  h2.tit_derivery img {
    width: 148px;
}
#container-in3  h2.tit_takeout img {
    width: 177px;
}
#container-in3  h2.tit_catering img {
    width: 177px;
}
#menu p.sub_tit {
}
#menu .menu {
	width:100%;
	margin:0 auto 60px;
	background:#f0f0ec;
	border:1px solid #e5e5de;
	padding:33px 0% 35px ;
}
#menu .menu  h3 {
}
#menu .menu  .cont_l {
	width:100%;
	box-sizing:border-box;
	padding:0 8%;
}

#menu .menu  .cont_r {
	width:100%;
	box-sizing:border-box;
	padding:0 8%;
}

#menu .menu  .cont_r02 {
	width:100%;
	box-sizing:border-box;
	padding:0 0%;
}


#menu .menu  .cont_l p.detail,#menu .menu  .cont_r p.detail {
	line-height:40px;
}
#menu .menu  .cont_l p.detail02,#menu .menu  .cont_r p.detail02 {
	line-height:24px;
}
#menu .menu  .cont_l p.detail span,#menu .menu  .cont_r p.detail span {
	line-height:24px;
	display:inline-block;
	padding-top:10px;
}
#menu .menu  .cont_l p.detail small,#menu .menu  .cont_r p.detail small {
	font-size:10px;
}
#menu .menu  .cont_l p.detail {
}

.drink_menu {
	width:100%;
	height:135px;
	background:url(../img/bg_drink_menu.png) no-repeat center;
	background-size:auto 100% ;
	padding-top:107px;
	font-weight:bold;
}
table.subtit {
	background:#fff;
	width:100%;
	margin:0 auto 20px;
	padding:20px 0;
}
table.subtit th {
	width:35%;
	text-align:center;
	vertical-align:middle;
	padding: 10px 0;
}
#container-in3 table.subtit th img {
	width:70%;
}
table.subtit td {
	text-align:left;
	white-space:nowrap;
	padding: 10px 0;
}
#menu .cont_l table b,#menu .cont_r table b {
	font-family: "Avenir Next" !important;
	font-weight:normal;
	font-size:20px;
}
#menu .cont_l table strong,#menu .cont_r table strong {
	font-family: "Avenir Next" !important;
	font-weight:bold;
	font-style:inherit;
}
#menu .cont_l table td.plus,#menu .cont_r table td.plus {
	font-weight:bold;
	font-size:36px;
	}
#menu .cont_l table td.last,#menu .cont_r table td.last {
	font-weight:bold;
	padding-top:10px;
	}

.menu_sample {
	background:#e4ded3;
	width:92%;
	margin:100px auto 50px;
	position:relative;
	padding:30px 0;
}
#container-in3  .menu_sample img.tit_img {
	width:43px;
	position:absolute;
	top:-66px;left: 0;
  right: 0;
  margin: auto;
}

.menu_sample b.under {
	text-decoration:none;
	border-bottom:1px solid #494947;
	padding-bottom:5px;
	line-height:46px;
}
.food_menu {
	width:100%;
	height:135px;
	background:url(../img/bg_food_menu.png) no-repeat center;
	background-size:auto 100% ;
	padding-top:107px;
	font-weight:bold;
	margin-bottom:15px;
}
.cruising_menu {
	width:100%;
	height:135px;
	background:url(../img/bg_food_menu.png) no-repeat center;
	background-size:auto 100% ;
	padding-top:107px;
	font-weight:bold;
	margin-bottom:15px;
}

.kiyaku_link {
	background:url(../img/kiyaku_link.png) center right no-repeat;
	padding-right:12px;
	font-size:12px;
	/* line-height:24px; */
}

/* 20231206金岡追記 */
.cruising_link {
	padding-right: 12px;
	background:url(../img/kiyaku_link.png) center right no-repeat;
}
/*  --------------*/

a.access_link {
	background:url(../img/kiyaku_link.png) center right no-repeat;
	padding-right:15px;
	text-decoration:underline;
}

table.subtit02 {
	background:#fff;
	width:100%;
	margin:0 auto 20px;
}
table.subtit02 td {
	padding:20px 0;
}

#menu .cont_l table b em,#menu .cont_r table b em {
	font-size:12px;
	vertical-align:top;
	display:table-cell;
	display:inline-block;
	padding-right:5px;
}

/*アラカルト・ドリンク*/
#drink  {
	width:96%;
	padding:45px 2%; 
}
#drink h2 {
	margin-bottom:20px;}
#drink h2.tit_alacarte img {
	width:184px;}
#drink h2.tit_drink img {
	width:217px;}
#drink dl {
	width:100%;
	margin:0 auto 30px;
	border-bottom:1px solid #ccc;
	font-size:11px;
	line-height:18px;
	}
#drink dt {
	border-top:1px solid #ccc;
	text-align:left;
	padding:10px 2% 0px;}
#drink dt small {
	font-size:10px;
	line-height:20px;
}
#drink dd {
	text-align:right;
	color:#121620;
	padding:0 2% 10px;}
#drink dd span {
	font-family: "Avenir Next" !important;
	font-size:12px;
	padding-left:10px;
	display:inline-block;
	white-space:nowrap;
}
#drink p.sub_tit {
	text-align:center;
	margin-bottom:50px;
}
#drink p.tit_wine {
	width:100%;
	text-align:left;
	margin:0 auto;
}
#drink p.tit_wine small {
	font-size:10px;
	line-height:20px;
}

#drink dl.glass {
	margin-bottom:10px;	}
	
#drink p.bottom {
	width:100%;
	text-align:left;
	margin:0 auto 30px;
	font-size:10px;
	line-height:20px;
}

#all .close {
	text-align:center;
	margin:25px auto ;
	width:90%;
	height:38px;
	border-radius:50px;
	background:#494947;
	color:#fff;
	line-height:38px;
}
#close .close:hover {
	opacity:0.7;
}
a.underline {
	text-decoration:underline;
}
.bottom_txt {
	font-size:14px;
	display:inline-block;
	margin-bottom:10px;}



/* 見積もり
----------------------------------- */
ul.book_link {
	display:flex;
justify-content: space-evenly;  /* 各アイテムを均等に配置し
                                   各アイテムの周りに同じ大きさの間隔を置く */
	margin:30px auto;
	font-size:14px;
}
ul.book_link li {
	width:32%;
	text-align:center;
	border:1px solid #313131;
}
ul.book_link li a {
	display:block;
	width:100%;
	line-height:36px;
	text-align:center;
}
ul.book_link li a.active {
	background:#ededed;
}
ul.book_link li a span {
	background:url(../img/bg_yajirushi.png)  no-repeat center left;
	background-size:auto 80%;
	padding-left:15px;
}
#book{
	margin:30px auto 86px;
	text-align:left;
	font-size:11px;
	line-height:28px;
	
}
#book h3 {
	width:100%;
	font-size:14px;
	line-height:50px;
	text-align:center;
	border-top:1px solid  #dcdcdc;
	border-bottom:1px solid  #dcdcdc;
	margin-bottom:24px;	
	display:flex;
	
}
#book h3 span {
	width:33.3%;
	font-size:14px;
}
#book h3 span.active {
	border-bottom:3px solid #dcdcde;
}


#book #form {
	width:100%;
	padding:0;
	margin:0 auto;
}
#book #form .cont_l {
	width:100%;
}
#book #form .cont_r {
	width:100%;
}
#book #form h4 {
	width:100%;
	height:44px;
	background:#f9f3e5;
	padding:0 18px;
	line-height:44px;
	font-size:14px;
	margin-bottom:18px;
}
#book #form  table.form {
	margin:0 auto;
	width:92%;
	box-sizing:border-box;
}

#book #form  table.form th{
	color:#121621;
	font-size:14px;
	padding:12px 8px;
	box-sizing:border-box;
	text-align:left;
	border-top:1px solid #ececec;
	border-bottom:1px solid #ececec;
	position:relative;
}
#book #form  table.form th em{
	display:block;
	color:#ffa949;
	font-size:13px;
	line-height:17px;
	font-style:normal;
}
#book #form  table.form th em.em02{
	display:block;
	color:#ffa949;
	font-size:13px;
	line-height:17px;
	font-style:normal;
}

/* オプションメニューの注意文 */
#book #form  .menu-box em{
	display:block;
	color:#ffa949;
	font-size:13px;
	line-height:17px;
	font-style:normal;
}
#book #form  .menu-box em.em02{
	display:block;
	color:#ffa949;
	font-size:13px;
	line-height:17px;
	font-style:normal;
}
/* ------------------------ */

#book #form  table.form td{
	box-sizing:border-box;
	color:#121621;
	font-size:14px;
	padding:16px 8px;
	text-align:left;
	line-height:28px;
	border-top:none;
}

#book #form  table.form td span, #book #form  table.form02 td span{
	font-size:14px;
	color:#121621;
}

#book #form  table.form td input.form_text {
	width:100%;
	border:none;
	border:1px solid #dcdcdc;
	height:38px;
	font-size:12px;
	text-indent:10px;
	background:#f5f5f3;
	border-radius:5px;
	margin-top:3px;
}

#book #form  table.form td input.form_text_half {
	width:40%;
	border:none;
	border:1px solid #dcdcdc;
	height:38px;
	font-size:12px;
	text-indent:10px;
	border-radius:5px;
	background:#f5f5f3;
	margin-bottom:10px;
	margin-top:3px;
}

#book #form  table.form td input.form_text_half02 {
	width:28%;
	border:none;
	border:1px solid #dcdcdc;
	height:38px;
	font-size:14px;
	text-indent:10px;
	border-radius:5px;
	background:#f5f5f3;
	margin-bottom:10px;
	margin-top:3px;
}
.table_in {
	display:block;
	white-space:nowrap;
	font-size:12px;
}
.table_in i {
	width:85px;
	display:inline-table;
	font-style:normal;
	white-space:nowrap;
}
/* css checkbox01 */

#book #form .checkbox01 {
}
#book #form .checkbox01-input{
  display: none;
}
#book #form .checkbox01-parts{
  padding-left: 28px;
  position:relative;
  margin-right: 10px;
  line-height:22px;
  letter-spacing:-0.03em;
  display:table-cell;
}
#book #form .checkbox01-parts::before{
  content: "";
  display: block;
  position: absolute;
  top: 8px;
  left: 0;
  width: 19px;
  height: 19px;
  background:#f5f5f3;
}
#book #form .checkbox01-input:checked + .checkbox01-parts{
  color: #535545;
}
#book #form .checkbox01-input:checked + .checkbox01-parts::after{
  content: "";
  display: block;
  position: absolute;
  top:8px;
  left: 6px;
  width: 7px;
  height: 14px;
  transform: rotate(40deg);
  border-bottom: 3px solid #535545;
  border-right: 3px solid #535545;
}

/* ラジオボタン01 */
input[type=radio] {
    display: none;
}
.radio01 {
    box-sizing: border-box;
    cursor: pointer;
    display: inline-block;
    padding: 5px 30px;
    position: relative;
    width: auto;
}
.radio01::before {
    background: #fff;
    border: 1px solid #dfdfdf;
    border-radius: 50%;
    content: '';
    display: block;
    height: 16px;
    left: 5px;
    margin-top: -8px;
    position: absolute;
    top: 50%;
    width: 16px;
}
.radio01::after {
  transform: rotate(40deg);
  border-bottom: 3px solid #535545;
  border-right: 3px solid #535545;
    content: '';
    display: block;
    left: 6px;
    margin-top: -4px;
    opacity: 0;
    position: absolute;
    top: 16px;
  top: 12px;
  left: 12px;
  width: 7px;
  height: 14px;
	
}
input[type=radio]:checked + .radio01::after {
    opacity: 1;
	
}
#book #form  table.form th strong {
	background:#ffa948;
	color:#fff;
	font-size:14px;
	line-height:20px;
	width:49px;
	display:inline-block;
	text-align:center;
	position:absolute;
	right:5px;
	top:15px;
}

#book #form  table.form td p {
	font-size:12px;
}

#book #form .cont_bottom {
	width:100%;
	margin:20px auto 40px;
}
#book #form .cont_bottom h4 {
	margin-bottom:24px;
	text-align:left;
}

#book #form .base_menu {
	background:#d8d4c9;
	width:100%;
	margin:0 auto;
	padding:20px 0 0px;
}
#book #form .base_menu table.form  {
	width:92%;
	margin:0 auto;
	
}
#book #form .base_menu table.form th {
	border:none;
	background:#fff;
	padding:0px 20px;
	height:38px;
}
#book #form .base_menu table.form th strong {
	right:10px;
	top:10px;
}

#book #form .base_menu table.form select {
	font-size:12px;
}
#book #form .base_menu table.form td {
	border:none;
	padding:20px 0px;
}

#book #form .base_menu table.form select.form_text {
    -webkit-appearance:none;
    -moz-appearance:none;
    appearance:none;
    text-indent: .01px; /*Firefox用*/
    text-overflow: ""; /*Firefox用*/
	height:38px;
	border:none;
	width:100%;
	font-size:12px;
	text-indent:10px;
	background-color:#f5f5f3;
	background-image:url(../img/select_arrow.png) no-repeat right;
	margin-top:3px;
}
table.form td.right {
	padding-bottom:15px;
}

/* ドリンクメニュー */
#book #form .drink_menu {
	background:#d8d4c9;
	width:100%;
	margin:30px auto 30px;
	padding:20px 0 0px;
}
#book #form .drink_menu table.form  {
	width:92%;
	margin:0 auto;
	
}
#book #form .drink_menu table.form th {
	border:none;
	background:#fff;
	padding:0px 20px;
	height:38px;
}
#book #form .drink_menu table.form th strong {
	right:10px;
	top:10px;
}

#book #form .drink_menu table.form select {
	font-size:12px;
}
#book #form .drink_menu table.form td {
	border:none;
	padding:20px 0px;
}

#book #form .drink_menu table.form select.form_text {
    -webkit-appearance:none;
    -moz-appearance:none;
    appearance:none;
    text-indent: .01px; /*Firefox用*/
    text-overflow: ""; /*Firefox用*/
	height:38px;
	border:none;
	width:100%;
	font-size:12px;
	text-indent:10px;
	background-color:#f5f5f3;
	background-image:url(../img/select_arrow.png) no-repeat right;
	margin-top:3px;
}

/* アコーディオンA */
.menu-box{
width: 92%;
height:auto;
margin: 0px auto 35px;
position:relative;
}

.menu-box h5 {
	position:relative;
}

.menu-box h5 small {
	display:inline-block;
	line-height:22px;
}

/*ラベル*/
.menu-box label.btn_menu{
	line-height:15px;
font-size: 10px;
border-radius: 15px;
padding:0px 10px 0px 10px;
text-align:center;
cursor: pointer;
transition: all 0.5s;
border:1px solid #40403e;
position:absolute;
top:13px;
right:0;
white-space:nowrap;

}


/*チェックを隠す*/
.menu-box input.open_btn{
display: none;
}
/*チェックのアイコン（↓）*/
.menu-box label.btn_menu:before{
content:"　 メニューを表示";
background:url(../img/open.jpg) no-repeat left center;
display:block;

}

/*チェックのアイコン（↑）*/
.menu-box input:checked ~ label.btn_menu::before {
font-family:"Avenir";
content:" 　　CLOSE　";
background:url(../img/close.jpg) no-repeat 5px center;
display:block;
}
.menu-box input:checked ~ label {
	
}

/*中身を非表示にしておく*/
.menu-box div{
height: 0px;
padding: 0px;
overflow: hidden;
opacity: 0;
transition: 0.5s;
}

/*クリックで中身を表示*/
.menu-box input:checked ~ div{
height: auto;
padding: 5px;
opacity: 1;
}
.menu-small {
	width:100%;
}
.menu-small table {
	width:100%;
	box-sizing:border-box;
	padding:10px 0;
	font-size:14px;
	border-bottom:1px solid #ececec;
}
table.menu .menu_bottom {
	text-align:right;
	padding:10px 0;
}

#book #form  table.menu td input.form_text_half {
	width:85px;
	border:none;
	border:1px solid #dcdcdc;
	height:38px;
	margin-top:3px;
	font-size:12px;
	text-indent:10px;
	border-radius:5px;text-align    : right;

background: #f5f5f3;	padding-right:10px;
margin-left:10px;
	}
	

/* css checkbox01 */
table.form td.option span {
	color:#535545;
	
}
.checkbox01 {
}



#book #form  table.form td textarea {width: 100%;
    padding: 10px;
    height: 370x;
	font-size:12px;
    overflow-y: auto;
    border: none;
    margin-top: 3px;
    border: 1px solid #dcdcdc;
	background: #f5f5f3;border-radius: 10px;
}



#book #form  table.form div.policy {
	 width:100%;
	 padding: 20px;
	 height:187px;
	 margin:0 auto;
	 overflow-y:auto;
	border:1px solid #dcdcdc;
	background:#f5f5f2;
	line-height:23px;
	font-size:14px;
	margin-bottom:0px;
	 
 }
 
#book #form  table.form .submit_sp {
	margin-top:0;
}
#book #form  table.form .submit_sm input {
	text-align:center;
	 width:100%;
	height:41px;
	display:block;
	cursor:pointer;
	margin:40px auto 0;
	background:#4a4a47;
	border-radius:30px;
	color:#fff;
}
#book #form  table.form .submit_sm input:hover {
	opacity:0.7;
}


#book #form  table.form .submit_pc {
	display:none;
}

/*ポップアップ*/
.popup {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: .6s;
}
.popup.is-show {
  opacity: 1;
  visibility: visible;
}
.popup-inner {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  width: 80%;
  max-width: 926px;
  padding: 0px;
  background-color: #fff;
  z-index: 2;
  overflow:auto;
}
.popup-inner img {
  width: 100%;
}
.close-btn {
  position: absolute;
  right: 5px;
  top: 5px;
  width: 33px;
  height: 33px;
  line-height: 33px;
  text-align: center;
  cursor: pointer;
  z-index: 3;
}
.close-btn img {
	width:33px;
	height:auto;
}
.black-background {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,.8);
  z-index: 1;
  cursor: pointer;
}

/* 20231206金岡追記 */

.box {
	display: inline-block;
	margin-top: 30px;
	width: 90%;
	border: silver 1px solid;
	padding: 15px;
}

.mt10 {
	margin-top: 10px;
} 

.leaf-menu {
	position: relative;
}

.leaf-icon {
	position: absolute;
    right: 25px;
	bottom: 93px;
}

.leaf-icon img{
	position: absolute;
	width: auto !important;
}

.plus-menu {
	width: 60px !important;
	height: 60px;
	margin-bottom: 10px;
}

.number-input {
	display: flex;
	text-align: center;
}

.number-input p {
	margin: 15px 0px 0px 5px;
}

/* モーダルを開くボタン */
#js-line-open-pc, #js-line-open-sm{
	position: fixed;
	top: 50%;
	left: 50%;
	font-size: 16px;
	font-weight: bold;
	width: 300px;
	height: 60px;
	color: #fff;
	background: #000;
	border: none;
	cursor: pointer;
	translate: -50% -50%;
  }
  
  /* モーダルと背景の指定 */
  .line-modal-sm{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-align: center;
	background: rgba(0,0,0,50%);
	padding: 40px 20px;
	overflow: auto;
	opacity: 0;
	visibility: hidden;
	transition: .3s;
	box-sizing: border-box;
  }
  
  /* モーダルの擬似要素の指定 */
  .line-modal-sm:before{
	content: "";
	display: inline-block;
	vertical-align: middle;
	height: 100%;
	margin-left: -0.2em;
  }
  
  /* クラスが追加された時の指定 */
  .line-modal-sm.line-is-show{
	opacity: 1;
	visibility: visible;
  }
  
  /* モーダル内側の指定 */
  .line-modal-inner-sm{
	position: relative;
	display: inline-block;
	vertical-align: middle;
	/* max-width: 600px; */
	width: 90%;
  }
  
  /* モーダルを閉じるボタンの指定 */
  #js-line-close-sm{
	position: absolute;
	display: flex;
	align-items: center;
	justify-content: center;
	top: 80%;
	left: 45%;
	width: 40px;
	height: 40px;
	color: #fff;
	cursor: pointer;
  }
  
  /* モーダルのコンテンツ部分の指定 */
  #js-line-img-sm{
	background: #fff;
	text-align: center;
	line-height: 1.8;
	padding: 20px 20px 80px;
  }

  #js-line-img-sm p {
	font-size: 14px;
  }
  
  
  /* モーダルのコンテンツ部分のテキストの指定 */
  /* .modal-content p{
	margin: 1em 0;
  } */

  .modal {
    visibility: hidden;
    display: none;
    width: 0;
    height: 0;
  }