@charset "UTF-8";
/*--------------------------------
初期設定
---------------------------------*/
html {font-size: 62.5%;} /* 1.6rem=16px */
body {width: 100%; color: #000; font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", HelveticaNeue, "Segoe UI",  "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; line-height: 1; word-break: break-all; -webkit-font-feature-settings: "palt"; font-feature-settings: "palt"; letter-spacing: 1px; min-width: 320px; padding: 0px;}
a {color: #000;}
a:hover img {}
img {max-width: 100%;height: auto;}
p, ul li, ol li, dl dt, dl dd{margin:0; padding:0; font-size:1.6rem}
ul{ margin:0; padding:0}
ul li{ margin:0; padding:0; list-style-type:none}

.pb40{ padding-bottom:40px;}
.mb40{ margin-bottom:40px;}
.mb10{ margin-bottom:10px!important;}
.pb20{ padding-bottom:20px;}
.pb80{ padding-bottom:80px;}
.attention,.rd{ color:#C00}
.ib{ display:inline-block}
.f-l{ float:left}
.f-r{ float: right}
.clear{ clear:both}
.w100{ width:100%}
caption{ font-size:1.6rem; padding-bottom:10px; text-align:left}
.min,
.campaign-area ul li p,
.concept-area-photo2 p,
.main section h3,
.btn01,
.contact-btn li a,
.contact-area dl,
.footer-add dd,
.price-list01-title,
.price-list01-price,
.about-area h2{  font-family: "Times New Roman", Times, serif, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; transform: rotate(.03deg);}
html{overflow-y:scroll;}
.bk{ color:#000!important}
.right{ text-align:right}
.bold{ font-weight:bold}
.clearfix::after { content: ""; display: block; clear: both;}

/*--------------------------------
share
---------------------------------*/
img[src$=".svg"] {width: 100%; height: auto;}
a{ transition: opacity 0.5s ease-out;}
a:hover{ text-decoration:none;}
.center{ text-align:center}
.ggmap {position: relative; padding-bottom: 70.25%; padding-top: 30px; height: 0; overflow: hidden;}
.ggmap iframe,
.ggmap object,
.ggmap embed {position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
/* page-top */
#page-top {position: fixed; bottom: 0; right: 0; margin:0;}
#page-top a {width: 50px; height:50px;}
#page-top a img{width: 50px;height:50px;}
#page-top a:hover {}
.main section, main ul li {line-height:1.8}


	.fixed-contact ul{position: fixed; bottom: 0;display: flex; justify-content: space-between; width: 100%; z-index: 1;
    border-top: 1px solid #fff;}
	.fixed-contact ul li{width: 100%; text-align: center; font-size: 1.2rem}
	.fixed-contact ul li img { width: 20px; height: auto; vertical-align: middle }
	.fixed-contact ul li a { display: block; padding: 15px 0; text-decoration: none; color: #fff; background: #ff8205}
	.fixed-contact ul li:nth-child(2){ border-left:1px solid #fff;border-right:1px solid #fff;}


.outline1-1{ margin: 0; color: #1b4433; font-size: 2.4rem; font-weight: normal; text-align: center}
.outline2-1{ margin: 0; padding-bottom: 0!important;
    font-size: 24px;
    color: #1b4433;
    text-align: center;
    font-family: 'Shippori Mincho', serif;}
.btn01{ display: inline-block;  padding: 0 20px; background:#1b4433; color: #fff; text-decoration: none;border-radius: 10px; font-size: 1.6rem}
.titleline{
    margin: 20px auto 20px auto;
    width: 70%;}
	.main section.share-section{padding: 20px;}

/* header */
header{ border-bottom: 2px solid #1b4433 }
.header-wrap h1{ margin:0;width: 300px;}
.header-wrap h1 a{display: block}


/* #contents */
/* トップページ */
.main section{ padding: 20px 0}
.main section h2{ padding-bottom: 20px; text-align: center}
.main section h2 img{width: 80%; max-width: 440px }

/* キャンペーン */
.main section.campaign-area { }
.campaign-area ul{ display: flex; flex-wrap: wrap;  justify-content: center;   padding:0 10px;box-sizing: border-box}
.campaign-area ul li{ width: 50%;  padding: 0 10px 20px; box-sizing: border-box}
.campaign-area ul li img{ width: 100%; max-width: 275px;}
.campaign-area ul li p{color: #1b4433;font-size: 1.4rem}
.campaign-area ul li a{display: block; text-decoration: none}

/* コンセプト */
.concept-area .concept-box-wrap{background:  #ecf2e9;}
.concept-box{ padding: 20px 10px}
.concept-box p{ padding-bottom: 20px}
.concept-area-photo1{text-align: center}
.concept-area-photo2{text-align: center}
.concept-area-photo2 p{ padding-bottom: 20px; color: #1b4433; font-size: 2rem }

/* メニュー */
.main section.topmenu-area{ background: #ccdfc3;}
.topmenu-area ul{ display: flex; flex-wrap: wrap; padding:0 5px; max-width: 1154px; margin: 0 auto; }
.topmenu-area ul li{ padding: 0 5px 40px; box-sizing: border-box; }
.topmenu-wrap{ height: 100%;padding: 15px 15px 5px; background: #fff}
.topmenu-area ul li p{padding: 0 5px 10px; font-size: 1.2rem}

/* フォトギャラリー */
.photogallery-area{background: #ccdfc3}
.photogallery-area h2 + p{padding: 0 10px 20px;}
.main section.photogallery-area h2 { padding-bottom:0 ;}
.photogallery-area p{max-width: 600px; margin: 0 auto}


/* ソーシャルエリア */
.social-area{text-align: center}
.social-area h3{font-weight: normal; font-size: 1.6rem}
.social-area ul{ display: flex; justify-content:space-between; width: 100px; margin: 0 auto}
.social-area ul li{width: 50px}
.scl-btn li {
	position: relative;
	width: 50px;
	height: 80px;
	margin: 0 auto;
	display: block;
	border-radius: 12px;
	overflow: hidden;
	cursor: pointer;
}
.scl-btn li img {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%;
	display: block;
	-webkit-transition: .4s ease-in-out;
	transition: .4s ease-in-out;
}
.scl-btn li:hover img:nth-of-type(2) {
	opacity: 0;
}

/* 予約・問い合わせ */
.contact-area{ background: #eeeeee}
.contact-btn{ max-width: 1154px; margin: 0 auto 40px}
.contact-btn li{
    padding: 0 10px;width: 100%; margin: 0 auto 20px; box-sizing: border-box;}
.contact-btn li a{ display: block; padding: 20px; text-align: center; text-decoration: none;background:#ffe0c1; color: #000; font-size: 2.2rem }
.contact-btn li a div span{display: block;color: #000; font-size: 1.6rem  }

.contact-btn li a{ background:#ffe0c1 url("/img/arrow01.png") right 20px center no-repeat; background-size: 18px auto;  transition: all .3s; }
.contact-btn li a:hover{ background-position:  right}

.contact-area dl{ text-align: center; }
.contact-area dl dd.tel { font-size: 3rem; }
.contact-area dl dd.tel a{ text-decoration: none; color: #5f5e5e}
.contact-area dl dt,.contact-area dl dd{ font-weight: 100;color: #5f5e5e}

/* アクセス */
.topmap{margin: 30px 20px 80px 20px;position: relative;}
.topmap p {background: #1b4433;color: #fff;width: 280px;padding: 10px;margin: -100px auto 0 auto;position: absolute;left:0;right:0;}


/* footer */
footer{ background: #1b4433}
.footer-add { margin: 0; padding: 20px 0}
.footer-add dt{ width: 300px;}
.footer-add dd{padding: 8px 0 8px 20px; color:#fff;}
footer .tel a{color: #fff; text-decoration: none}
footer small{ display: block; padding: 20px 0; font-size: 1rem; color: #fff; text-align: center}
.footer-menu a{display: block; color: #fff; text-decoration: none}
.footer-menu ul{display: flex; flex-wrap: wrap; margin: 40px 0 0}
.footer-menu ul li{ margin-bottom: 20px}
.footer-menu ul li a{ padding: 0 20px; border-right: 1px solid #fff }
.footer-menu ul li:last-child a{border:none}
.footer-menu-title{ display: inline-block; margin: 40px 0 0 20px; background: #fff; color: #1b4433; font-size: 1.6rem; padding: 10px 20px}

/* 下層メイン画像 */
.main-bg{  width: 100%; height: 250px;}
.main-bg h1 {padding: 20px; margin: 0}
.main-bg h1 img{ width: auto; height: 80px; margin: 0}
.main-bg div{max-width: 1154px; margin: 0 auto}


.reserve01-area{ display: flex; justify-content: center;  border: 3px solid #1b4433;}  
.main section.reserve01-area{max-width: 800px;margin: 0 auto;padding-top: 10px; }
.main section.reserve01-area h2{padding-bottom: 0; margin-bottom: 0}
.main section.reserve01-area p{ padding:0 10px 15px}
.main section.reserve01-area h2 img{ width: 100%; max-width: 325px}


.reserve01-area2 { display: flex; justify-content: center; flex-wrap: wrap-reverse;}
.main section.reserve01-area2{max-width: 500px;margin: 0 auto;padding-top: 10px; }
.main section.reserve01-area2 h2{padding-bottom: 0; margin-bottom: 0}
.main section.reserve01-area2 p{ padding:0 10px 15px}
.main section.reserve01-area2 h2 img{ width: 100%; max-width: 325px}


.gallery01-wrap{padding: 0 10px; text-align: center}
.gallery01-wrap img{padding: 0 0 10px;vertical-align: bottom;}

.main section.about-area{max-width: 1154px; margin: 0 auto; padding: 10px;box-sizing: border-box}
.about-box{ position: relative; padding:0 20px;max-width: 620px; background: #ffffffc7;}
.about-box h3{ padding: 15px 0; font-size: 2.4rem; text-align: left}
.about-box p{line-height: 2.2}
.about-area{overflow: hidden;}

div.animation_box { animation: fadeIn 1s ease 1s 1 normal backwards; text-align: right;}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateX(100px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
div.animation_box2 { animation: fadeIn2 1s ease 1s 1 normal backwards;}
@keyframes fadeIn2 {
  from {
    opacity: 0;
    transform: translateX(-100px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
h1 img {width: 200px;margin: 10px;}

/* フェアー */
.fair {margin: 30px 20px;}
.fair h2 {font-size: 24px;color: #1b4433;text-align: center;font-family: 'Shippori Mincho', serif;}
.fair .titleline {margin: 20px auto 20px auto;width: 70%;}
.fair p {line-height: 180%;}

/* お問い合わせ */
.main section.contact{padding:20px;}
.ppcheck{ font-size: 1.6rem}
.thanks-contact{ max-width: 660px; margin: 0 auto; line-height: 2}

/* 会社案内 */
.history img{ width: 100%; height: auto;max-width: 400px}
.history-table{ width: 100%}
.history-table th,.history-table td{border-bottom: 1px solid #d8d8d8;text-align: left; font-size: 1.6rem; }
.history-table th{width: 80px; vertical-align: top; padding: 10px 0}
.history-table td{padding: 10px 0}
.about-company{max-width: 800px; margin: 80px auto 0}
.aboutBody .main .topmap{margin-bottom: 140px }	

/* ギャラリー */
.inline-block{background: #fff;padding: 50px 0 40px;box-sizing: border-box;  max-width: 900px;  margin: 0 auto;  position: relative; }
.inline-block-wrap{margin: 0 auto; max-width: 800px;  }
.inline-block .image{padding: 5px 5px 0}
.inline-block ul{display: flex;}
.inline-block ul li{width: 25%; max-width: 200px; padding: 10px 5px; box-sizing: border-box}
.inline-block-text{ padding:0 10px; line-height: 1.8; box-sizing: border-box}  

/* flexslider */
.inline-block .flexslider ul{display: block;}
.inline-block .flexslider ul li{width:auto; max-width:none; padding: 0px; box-sizing: border-box}


/* 証明写真 */
.table03{
    width: 100%; max-width: 800px; margin: 40px auto 80px; font-size: 1.4rem;border-left: 1px solid #ccc;border-top: 1px solid #ccc; border-collapse:collapse;}
.table03 th,
.table03 td{padding:10px;border-right: 1px solid #ccc;border-bottom: 1px solid #ccc; }
.table03 th{ font-weight: bold; background:#ecf2e9; color: #1b4433 }
.table03 td{ }

.reserve-box .center .btn01{ padding: 10px 80px; background: #ff8205}

@media screen and (max-width: 480px) {
	.reserveimg{display: none}
}


@media screen and (min-width: 481px) {
.campaign-area{}

	.campaign-area ul li{ width: 25%;}

.concept-box2 ul{display: flex;  justify-content: space-between;}
.concept-box2 ul li{ padding:0 10px}

.topmenu-area ul li{ width: 33.3%; padding: 0 10px 40px; }
.reservation table {width:400px;margin: 20px auto;}
.history-table th{width: 100px;}
.table02{ margin-top: 40px}
.table02  th{ width: 200px}
.topmenu-area ul li p{font-size: 1.4rem}
	.topmenu-wrap{position: relative; padding-bottom: 10px}

	.topmenu-wrap .center{ position: absolute; bottom: 15px; left: 0; right: 0}

}

@media screen and (min-width: 768px) {
	.concept-box{display: flex; max-width: 1154px; margin: 0 auto; padding: 40px 0}
	.concept-area-photo1{width: 90%; position: relative}
	.concept-area-photo1 img{position: absolute; top: -100px; left: 0}
	.concept-box2 .concept-text{padding-bottom: 40px}
	.contact-btn{ display: flex; justify-content: space-between; }
	.contact-btn li a{ font-size: 1.4rem}
	.contact-btn li{width: 30%;max-width: 340px;}
.tel a{pointer-events: none;}
footer small{font-size: 1.2rem; }
.main-bg{  height: 400px;}
.main section.reserve01-area{flex-wrap:nowrap}
.main section.reserve01-area2{flex-wrap:nowrap}
	.main section.reserve01-area2{ background: #ffffffeb; margin-top: -70px; padding: 20px 40px 60px; box-sizing: border-box}
	.main section.reserve01-area2 h2{margin-top: 30px}
.main section.reserve01-area2 p{ padding: 0 20px 20px; font-size: 1.8rem; line-height: 2; }
	.main section.reserve01-area{ background: #ffffffeb; margin-top: -70px; padding: 20px 40px 60px; box-sizing: border-box}
	.main section.reserve01-area h2{margin-top: 30px}
.main section.reserve01-area p{ padding: 0 20px 20px; font-size: 1.6rem; line-height: 2; }
	.gallery01-wrap{ display: flex}
	.gallery01-wrap-left{ width:33.33333333%}
	.gallery01-wrap-right{width:66.66666666%}
	.gallery01-wrap-right div{display: flex; width: 100%;max-width:764px;}
	.gallery01-wrap img{padding:0;}
h1 img {width: 300px;margin: 0;}
.reservation table {width:700px;margin: 20px auto;}
.topmenu-area ul li{ width: 25%; }

/* フェアー */
.fair .titleline {width: 200px;}
.fair p {width: 500px;margin: 0 auto;}

	
	
/* 会社案内 */	
.history{display: flex; max-width: 800px; margin:40px auto 0}
.history img{ margin: 0 40px 0 0}

.aboutBody .main .topmap{ padding-top: 200px;  margin-top:-110px; }	

}



@media screen and (max-width: 1153px){
	footer{padding-bottom: 80px;}

}


@media screen and (min-width: 1154px) {
	#contents{ margin-top: 118px}
	.no-topimg{margin: 200px 0}
	.no-topimg2{margin: 200px 0 100px}
	.no-topimg3{margin: 200px 0 0}
.outline2-1{ font-size: 3rem}
.titleline{ width:200px;}



.sp-only{ display: none}
a:hover{ opacity:.7}
header{ position: fixed;top: 0; width: 100%; background: #fff; z-index: 999}
.main section{ padding: 80px 0}
.main section h2 img{ width: 100%}
.outline1-1 { font-size: 3rem; }

.fixed-contact ul{ top: 0; right: 10px; bottom: auto; width: 420px}
.fixed-contact ul li a{padding: 10px 0}
.fixed-contact ul li:first-child a{border-bottom-left-radius: 10px;}
.fixed-contact ul li:last-child a{border-bottom-right-radius: 10px;}
.fixed-contact ul li:nth-child(2){border:none;}



.header-wrap{ display: flex;  align-items: center; width: 1154px; margin: 0 auto}
.campaign-area h2{ margin-top: 50px}
.campaign-area ul{width: 1154px; padding: 0; margin: 0 auto}
.campaign-area ul li p{font-size: 1.8rem}
.campaign-area ul li img{padding-bottom:10px }
.campaign-area ul li{ padding: 0 10px 0}

.main .concept-area{padding-bottom: 0}
.concept-area-photo2 p{ font-size: 1.8rem; padding-bottom: 0; padding-top: 30px }
.concept-box2 ul li{ padding:0 }
.concept-area-photo1 img{top: -130px;}


.topmenu-area ul li h3{ padding: 5px 0}
.topmenu-area ul li p{line-height: 2; padding-bottom: 20px}

.main section.photogallery-area { padding:50px 0 80px ;}

.contact-btn{ margin: 0 auto 60px}
.contact-btn li a{ padding: 30px 10px; font-size: 2.4rem}
.contact-btn li{ padding: 0}
.contact-area dl dt,
.contact-area dl dd{font-size: 2.4rem; }
.contact-area dl dd.tel{ font-size: 4.8rem; }

	.footer-flex{display: flex; justify-content: space-between; align-items: center; width: 1154px; margin: 0 auto}
	.footer-menu{margin-bottom: 40px}
	.footer-menu-title{margin-top: 60px}
	.footer-menu ul li{margin-bottom: 10px}
	.footer-add dt{ padding-bottom: 20px}
	.footer-add dd{padding-top: 3px}
.main-bg{  height: 660px;}
	.main-bg h1{padding: 190px 0 0 60px}
	.main-bg h1 img{height: 180px}
	.main section h2 img{}
	.main section.reserve01-area{ margin-top: -130px; }
	.main section.reserve01-area2{ margin-top: -130px; }

.gallery01-wrap-left{ max-width: 384px;width: 100%}
.gallery01-wrap-right{max-width:764px;width: 100% }

.about-box{  margin-top: -160px; padding:0 50px;}
.about-box h3{ padding-bottom: 20px; }
.reservation table {width:900px;margin: 20px auto;}
/* フェアー */
.fair p {width: 700px;}
.fair {margin: 200px 20px;}
.fair h2 {font-size: 30px;}
/* アクセス */
.topmap{margin: 30px auto 80px auto;width: 900px;}

	
/* お問い合わせ */	
.main section.contact{padding:0 20px;}

/* 共有 */
.main section.share-section{padding:0 20px;}

/* ギャラリー */
.inline-block{padding: 50px 0 40px;}




}
@media screen and (max-width: 767px) {}
@media screen and (max-width: 960px) {}
@media screen and (min-width: 961px) {}
@media screen and (max-width: 1000px) {}
@media screen and (min-width: 1001px) {}
@media screen and (min-width: 1201px) {}
@media screen and (min-width: 1480px) {}
@media all and (-ms-high-contrast:none){
*::-ms-backdrop,
.header-wrap h1,
.header-wrap h1 img{ width: 260px;}
*::-ms-backdrop,
.news-area h2{margin: 0 0 -2px 10px;}
}
@media screen and (min-width: 1480px) {}
@media all and (-ms-high-contrast:none){
}
