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

/* =box-sizing
-----------------------------------------------------------------------------*/
*, *::before, *::after { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }

/* =base 基本設定
-----------------------------------------------------------------------------*/
html { background-color: rgba(255,255,255,1.0); font-size: 62.5%; font-family: 'Noto Sans JP', sans-serif; scroll-behavior: smooth; } /* 初期値16pxの62.5%でルートが10px */
body { background-color: rgba(255,255,255,1.0); }
body { -webkit-text-size-adjust: 100%; } /* 端末横回転時の文字拡大防止 */
#wrapper, #header, #main, #footer { width: 100%; }
#wrapper, #main { background-color: rgba(255,255,255,1.0); }
#header { background: linear-gradient(90deg, rgba(250,220,70,1.0) 0%, rgba(250,220,70,1.0) 50%, rgba(225,35,55,1.0) 50%, rgba(225,35,55,1.0) 100%); }
#footer { background: rgba(250,220,70,1.0); margin-top: 15.0em; padding-bottom: 50px; }
img { width: 100%; max-width: 100%; height: auto; } /* 画像レスポンシブ対応 */
a.anchor { display: block; padding-top: 81px; margin-top: -81px; } /* スムーススクロール ズレ修正 */
#main a.anchor:hover { background-color: inherit; }

/* =IEバグ対応設定
-----------------------------------------------------------------------------*/
img[src$=".svg"] { max-width: 100%; height: auto; } /* SVGバグ対応 */
img { vertical-align: bottom; } /* 画像下余白バグ対応 */
table { table-layout: fixed; } /* テーブルバグ対応 */

/* =文字 基本設定
-----------------------------------------------------------------------------*/
h1, h2, h3, h4, h5, h6, p, li, th, td, dt, dd, address { letter-spacing: 0.10em; font-feature-settings: "palt" 1; }
strong { font-style: normal; font-weight: 500; }
#header a, #main a, #footer a { text-decoration: none; }
p { word-wrap: break-word; } /* テキストを折り返し指定 */
br.br-none { display: none; } /* 改行設定 */
#main a { text-decoration: none; color: rgba(0,80,180,1.0); }
#main a:hover { background-color: rgba(230,230,230,1.0); }

/* =ヘッダー＆フッター共通部分
-----------------------------------------------------------------------------*/
div.enclosure-box { max-width: 1000px; display: flex; margin: 0 auto; }
div.logo-box { width: 340px; background: rgba(250,220,70,1.0); display: flex; flex-direction: column; } /* ロゴ部分設定 */
div.logo-box figure { max-width: 120px; height: auto; margin: 0 auto; }
div.logo-box p { font-size: 1.5rem; font-weight: 400; color: rgba(95,50,0,1.0); line-height: 1.3; text-align: center; margin-top: 5px; }
div.logo-box span { font-size: 112.5%; font-weight: 500; }
div.title-box, div.shoplist-box { flex: 1; padding-left: 40px; }

/* =ヘッダー設定
-----------------------------------------------------------------------------*/
div.header-box > div { padding-top: 15px; padding-bottom: 15px; }
div.title-box { background: rgba(225,35,55,1.0); }
div.title-box > div:nth-of-type(1) { width: 100%; height: 100%; display: table; border-top: 1px dotted rgba(255,255,255,1.0); border-bottom: 1px dotted rgba(255,255,255,1.0); padding: 1.0em 0; }
div.title-box h1 { font-size: 1.7rem; font-weight: 400; color: rgba(255,255,255,1.0); line-height: 1.5; display: table-cell; vertical-align: middle; }

/* =フッター設定
-----------------------------------------------------------------------------*/
div.footer-box > div { padding-top: 25px; padding-bottom: 25px; }
div.shoplist-box { display: flex; justify-content: flex-end; flex: 1; padding-left: 40px; }
div.shoplist-box ul { list-style: none; column-count: 3; }
div.shoplist-box li a { isplay: block; text-align: left; page-break-inside: avoid; break-inside: avoid; transform: translateZ(0); padding: 0.3em 0.5em; }

/* =フッターその他ボタン設定
-----------------------------------------------------------------------------*/
div.footer-button div { width: 100%; display: flex; justify-content: space-between; align-items: center; border-top: 1px dotted rgba(95,50,0,1.0); padding: 1.5em 0; }
div.footer-button ul { list-style: none; display: flex; }
ul.snsbutton-box img { width: 50px; height: auto; margin-right: 5px; }
ul.otherbutton-box li a { white-space: nowrap; margin-left: 5px; padding: 0.3em 0.5em; }

/* =フッターコピーライト＆ページトップボタン設定
-----------------------------------------------------------------------------*/
div.footer-bottom { width: 100%; background-color: rgba(95,50,0,1.0); position: fixed; bottom: 0; padding: 1.3em 0; }
div.footer-bottom div { max-width: 1000px; height: 100%; color: rgba(250,220,70,1.0); display: flex; justify-content: space-between; align-items: center; margin: 0 auto; }
div.footer-bottom p { font-size: 1.3rem; font-weight: 500; line-height: 1.6; }
p.pagetop-button a { font-size: 1.3rem; font-weight: 500; line-height: 1.6; display: block; color: rgba(95,50,0,1.0); background-color: rgba(250,220,70,1.0); border-radius: 100vw; padding: 0 1.0em; }
p.pagetop-button a:hover { color: rgba(250,220,70,1.0); background-color: rgba(95,50,0,1.0); }

/* =メイン画像設定
-----------------------------------------------------------------------------*/
div.main-imgbox { width: 100%; background: linear-gradient(180deg, rgba(255,255,255,0.0) 0%, rgba(255,255,255,0.0) 50%, rgba(255,255,255,1.0) 50%, rgba(255,255,255,1.0) 100%); }
div.main-imgbox > div { max-width: 1000px; position: relative; background: rgba(255,255,255,1.0); border: 1px solid rgba(225,35,55,1.0); margin: 0 auto; }
div.main-imgbox h2 { font-size: 2.6rem; font-weight: 400; color: rgb(255,255,255,1.0); line-height: 1.2; text-align: right; position: absolute; top: 50%; right: 40px; transform: translateY(-50%); margin: 0; padding: 0; }
div.main-imgbox h2 { text-shadow: 0 0 4px rgba(0,0,0,1.0), 0 0 4px rgba(0,0,0,1.0), 0 0 7px rgba(0,0,0,0.5); } /* テキスト光彩設定 */
div.main-imgbox figure { max-width: 1000px; margin: 10px; }
figure.slide-box { position: relative; overflow: hidden; padding-top: 45%; }
figure.slide-box div { width: 1000px; }
figure.slide-box ul { list-style: none; }
figure.slide-box li:nth-of-type(1) { width: 120%; height: 100%; position: absolute; top: 0; right: -20%; }
figure.slide-box li:nth-of-type(2) { width: 100%; height: 100%; position: absolute; top: 0; bottom: -20%; }
figure.slide-box li:nth-of-type(3) { width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
figure.slide-box li:nth-of-type(4) { width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
figure.slide-box li:nth-of-type(5) { width: 120%; height: 100%; position: absolute; top: 0; left: -20%; }
figure.slide-box li:nth-of-type(6) { width: 100%; height: 100%; position: absolute; top: 0; top: -20%; }
figure.slide-box li img { width: 100%; min-height: auto; display: block; object-fit: cover; opacity: 0; animation: 20s infinite ease; }
figure.slide-box li:nth-of-type(1) img { animation-delay: 0s; animation-name: slideAnime-left; }
figure.slide-box li:nth-of-type(2) img { animation-delay: 5s; animation-name: slideAnime-top; }
figure.slide-box li:nth-of-type(3) img { animation-delay: 10s; animation-name: slideAnime-zoomin; }
figure.slide-box li:nth-of-type(4) img { animation-delay: 15s; animation-name: slideAnime-zoomout; }
figure.slide-box li:nth-of-type(5) img { animation-delay: 20s; animation-name: slideAnime-right; }
figure.slide-box li:nth-of-type(6) img { animation-delay: 25s; animation-name: slideAnime-bottom; }

@keyframes slideAnime-left {
	0% { opacity: 0; }
	16% { opacity: 1; }
	33% { opacity: 1; }
	49% { opacity: 0; }
	100% { opacity: 0; transform: translateX(-20%); }
}

@keyframes slideAnime-right {
	0% { opacity: 0; }
	16% { opacity: 1; }
	33% { opacity: 1; }
	49% { opacity: 0; }
	100% { opacity: 0; transform: translateX(20%); }
}

@keyframes slideAnime-top {
	0% { opacity: 0; }
	16% { opacity: 1; }
	33% { opacity: 1; }
	49% { opacity: 0; }
	100% { opacity: 0; transform: translateY(-20%); }
}

@keyframes slideAnime-bottom {
	0% { opacity: 0; }
	16% { opacity: 1; }
	33% { opacity: 1; }
	49% { opacity: 0; }
	100% { opacity: 0; transform: translateY(-20%); }
}

@keyframes slideAnime-zoomin {
	0% { opacity: 0; }
	16% { opacity: 1; }
	33% { opacity: 1; }
	49% { opacity: 0; }
	100% { opacity: 0; transform: scale(1.3); }
}

@keyframes slideAnime-zoomout {
	0% { opacity: 0; transform: scale(1.4); }
	16% { opacity: 1; }
	33% { opacity: 1; }
	49% { opacity: 0; }
	100% { opacity: 0; transform: scale(1.0); }
}

/* =メインメニューフォントサイズ共通設定
-----------------------------------------------------------------------------*/
ul.main-menu h2, ul.main-menu h3, ul.main-menu li, div.shoplist-box li, ul.otherbutton-box li { width: 100%; font-weight: 500; line-height: 1.0; }
ul.main-menu h3, ul.main-menu li, div.shoplist-box li, ul.otherbutton-box li { font-size: 1.5rem; }
ul.main-menu h2 { font-size: 1.8rem; color: rgba(95,50,0,1.0); text-align: center; }
ul.main-menu h3 { color: rgba(255,255,255,1.0); text-align: left; background-color: rgba(95,50,0,1.0); border-radius: 100vh; margin-bottom: 0.5em; padding: 0.3em 1.0em; }
ul.main-menu li a, div.shoplist-box li a, ul.otherbutton-box li a { color: rgba(95,50,0,1.0); display: block; }
ul.main-menu li a:hover, div.shoplist-box li a:hover, ul.otherbutton-box li a:hover { color: rgba(255,255,255,1.0); background-color: rgba(225,35,55,1.0); border-radius: 100vh; }

/* =メインメニュー設定
-----------------------------------------------------------------------------*/
nav.main-navbox, nav.footer-navbox { width: 100%; padding-top: 15px; }
nav.main-navbox { position: relative; background: rgba(255,255,255,1.0); }
ul.main-menu { width: 100%; max-width: 1000px; display: flex; justify-content: space-between; border-right: 1px solid rgba(95,50,0,1.0); margin: 0 auto; }
ul.main-menu > li { text-align: center; border-left: 1px solid rgba(95,50,0,1.0); padding: 0 0.5em; }
ul.main-menu > li a { text-align: center; padding: 0.3em 0.5em; }

/* =メインメニュー内サブ設定
-----------------------------------------------------------------------------*/
div.sub-menubox { width: 100%; max-width: 800px; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); visibility: hidden; opacity: 0; transition: 0.5s; padding: 15px 0 0; z-index: 1; }
div.sub-menubox > div { background-color: rgba(255,255,255,0.9); border: 1px solid rgba(225,35,55,1.0); border-radius: 0.6em; padding: 0 15px 20px 15px; }
li.sub-menu:hover div.sub-menubox { top: 100%; opacity: 1; visibility: visible; transition: 1.0s; }
div.open-menubox { display: flex; flex-wrap: wrap; }
div.open-menubox + div.open-menubox { margin-top: 1.5em; }
div.open-menubox > ul:nth-of-type(1) { width: 33.3%; padding-right: 0.5em; }
div.open-menubox > ul:nth-of-type(2) { width: 33.3%; padding-right: 0.5em; padding-left: 0.5em; }
div.open-menubox > ul:nth-of-type(3) { width: 33.4%; padding-left: 0.5em; }
div.open-menubox > div:nth-of-type(1) { width: 66.6%; padding-right: 0.5em; }
div.open-menubox > div:nth-of-type(2) { width: 33.4%; padding-right: 0.5em; padding-left: 0.5em; }
div.paragraph-ul01 h3 { width: 100%; }
div.paragraph-ul01 div { width: 100%; display: flex; }
div.paragraph-ul01 div > ul { width: 50%; }
div.paragraph-ul01 div > ul:nth-of-type(2) { padding-left: 0.7em; }

div.open-menubox > div:nth-of-type(3) { width: 33.4%; padding-left: 0.5em; }

div.open-menubo > div:nth-of-type(1) { width: 33.3%; padding-right: 0.5em; }
div.open-menubo > div:nth-of-type(2) { width: 33.3%; padding-right: 0.5em; padding-left: 0.5em; }
div.open-menubo > div:nth-of-type(3) { width: 33.4%; padding-left: 0.5em; }

div.open-menubox > div:nth-of-type(3) > h3:nth-of-type(2) { margin-top: 1.0em; }
div.open-menubox li a { text-align: left; padding: 0.3em 1.0em; }
.red { color: red!important; }

/* =メイン共通設定
-----------------------------------------------------------------------------*/
#main { padding-top: 15px; }
div.content-box { width: 100%; }
div.content-box > div, div.content-box article, div.content-box section { max-width: 767px; margin: 0 auto; }
div.content-box + div.content-box { margin-top: 100px; }
div.content-box article + article { margin-top: 100px; }
div.content-box section { margin-top: 50px; }
div.content-box section + div { margin-top: 50px; }

/* =メインフォントサイズ共通設定
-----------------------------------------------------------------------------*/
#main h2 { font-size: 2.8rem; font-weight: 500; font-family: 'Noto serif JP'; line-height: 1.4; margin-bottom: 1.0em; }
#main h3 { font-size: 2.2rem; font-weight: 400; line-height: 1.2; margin-bottom: 1.0em; }
#main h4 { font-size: 2.0rem; font-weight: 400; line-height: 1.2; margin-bottom: 1.0em; }
#main h2.main-title { color: rgba(95,50,0,1.0); display: inline-block; border-bottom: 2px solid rgba(225,35,55,1.0); padding: 0 1.0em 0.25em; }
#main h3.sub-title { color: rgba(250,220,70,1.0); background: rgba(95,50,0,1.0); border-radius: 100vh; padding: 6px 20px; }
#main h3.concept-title { font-size: 3.2rem; color: rgba(50,50,50,1.0); margin-bottom: 0.6em; }
#main h3.emphasize-title { color: rgba(255,255,255,1.0); display: inline-block; background: rgba(225,35,55,1.0); border-radius: 100vh;  padding: 6px 20px; }
#main p { font-size: 1.6rem; font-weight: 400; color: rgba(50,50,50,1.0); text-align: left; line-height: 1.8; }
#main ul li { font-size: 1.6rem; font-weight: 400; color: rgba(50,50,50,1.0); text-align: left; line-height: 1.6; }
#main ul.indent-ulbox { list-style: none; margin: 10px 0; padding-top: 5px; }
#main ul.indent-ulbox li { text-indent: -1.0em; padding-left: 1.0em; }
#main ul.list-decimal li { list-style-type: decimal; margin-left: 2.0em; }
#main ul.list-alphl li { list-style-type: lower-alpha; margin-left: 2.0em; }
span.caution-text { color: rgba(225,35,55,1.0); font-weight: 500; }
span.emphasize-size { font-size: 113%; ont-weight: 500; ont-family: 'Noto serif JP'; }
#main p + p { margin-top: 0.8em; }

/* =メイン内テーブル基本設定
-----------------------------------------------------------------------------*/
#main table { width: 100%; max-width: 767px; border-top: 1px solid rgba(180,180,180,1.0); margin: 0 auto; }
#main th { font-size: 1.5rem; font-weight: 400; text-align: left; line-height: 1.6; border-bottom: 1px solid rgba(180,180,180,1.0); padding-top: 1.0em; padding-bottom: 1.0em; padding-right: 1.0em; }
#main td { font-size: 1.5rem; font-weight: 400; text-align: left; line-height: 1.6; border-bottom: 1px solid rgba(180,180,180,1.0); padding-top: 1.0em; padding-bottom: 1.0em; padding-left: 1.0em; }

/* =パンクズリスト設定
-----------------------------------------------------------------------------*/
div.breadcrumb-box { width: 100%; margin-bottom: 10px; padding: 0.25em 0; }
div.breadcrumb-box ul { max-width: 1000px; list-style: none; display: flex; margin: 0 auto; }
div.breadcrumb-box li { font-size: 1.5rem!important; }
div.breadcrumb-box a { color: rgba(50,50,50,1.0)!important; text-decoration: none; }
div.breadcrumb-box li::after{ content: '\00bb'; display: inline-block; padding: 0 10px; }
div.breadcrumb-box li:last-child::after{ display: none; }

/* =アイキャッチ設定
-----------------------------------------------------------------------------*/
div.eyecatch-box { width: 100%; margin-bottom: 50px; }
div.eyecatch-box > div { max-width: 1000px; background: rgba(250,220,70,1.0); border-radius: 10px; margin: 0 auto; padding: 30px 20px; }
div.eyecatch-title, div.eyecatch-price { max-width: 767px; }
div.eyecatch-title { background: rgba(225,35,55,1.0); border-radius: 10px; margin: 0 auto 20px; padding: 10px 20px; }
div.eyecatch-title figure { max-width: 500px; margin: 0 auto; }
div.eyecatch-price { display: flex; justify-content: space-between; margin: 0 auto; }
div.eyecatch-price div:nth-of-type(1) { width: 34%; }
div.eyecatch-price div:nth-of-type(2) { width: 64%; display: flex; flex-flow: column; justify-content: space-between; }
div.eyecatch-price div:nth-of-type(2) figure { background: rgba(225,35,55,1.0); border-radius: 10px; padding: 10px 20px; }
div.eyecatch-price p { font-size: 2.2rem!important; text-align: center!important; font-family: 'Noto serif JP'; color: rgba(0,0,0,1.0); line-height: 1.3!important; margin-bottom: 15px; }
div.eyecatch-price span { font-size: 200%; }
div.eyecatch-price span.press-red { color: rgba(225,35,55,1.0); }

/* =ウェルカムボックス設定
-----------------------------------------------------------------------------*/
div.welcome-box article { text-align: center; }
div.welcome-box p { font-size: 1.8rem!important; }
div.welcome-box p + p { margin-top: 0.8em!important; }

/* =アテンションボックス設定
-----------------------------------------------------------------------------*/
div.attention-box { background: rgba(240,240,240,1.0); border-top: 1px solid rgba(190,190,190,1.0); border-bottom: 1px solid rgba(190,190,190,1.0); }
div.attention-box article { text-align: center; padding: 20px 0 30px; }
section.attention-section { background: rgba(255,255,255,1.0); border: 1px dashed rgba(180,180,180,1.0); border-radius: 16px; padding: 30px; } 

/* =新着情報設定
-----------------------------------------------------------------------------*/
article.information-box th { width: 20%; color: rgba(95,50,0,1.0); border-right: 1px dotted rgba(180,180,180,1.0); }
article.information-box td { width: 80%; color: rgba(50,50,50,1.0); }

/* =料金表設定
-----------------------------------------------------------------------------*/
section.tariff-box h3 { text-align: center; }
section.tariff-box table { border-left: 1px solid rgba(180,180,180,1.0); }
section.tariff-box table.tm20 { margin-top: 20px!important; }
section.tariff-box th { width: 50%; color: rgba(50,50,50,1.0); background: rgba(230,230,230,1.0);  border-right: 1px solid rgba(180,180,180,1.0); text-align: center!important; padding: 0.5em!important; }
section.tariff-box th.th-title { width: 100%; color: rgba(30,30,30,1.0); background: rgba(210,210,210,1.0); }
section.tariff-box td { color: rgba(50,50,50,1.0); border-right: 1px solid rgba(180,180,180,1.0); text-align: center!important; padding: 0.5em!important; }
section.tariff-box p { font-size: 1.5rem!important; text-align: right!important; }
section.tariff-box p.text-left { text-align: left!important; }
section.tariff-box p.text-bottom { margin-bottom: 0.5em; }

/* =店舗案内設定
-----------------------------------------------------------------------------*/
article.shop-box th { width: 20%; color: rgba(95,50,0,1.0); border-right: 1px dotted rgba(180,180,180,1.0); }
article.shop-box td { width: 80%; color: rgba(50,50,50,1.0); }
article.shop-box a.shop-button { display: inline-block; background: rgba(230,230,230,1.0); border: 1px solid rgba(180,180,180,1.0); border-radius: 3px; margin-top: 0.3em; padding: 0 1.0em; }
article.shop-box a.shop-button:hover { color: rgba(250,220,70,1.0)!important; background: rgba(95,50,0,1.0)!important; border: 1px solid rgba(95,50,0,1.0); }

/* =店舗情報設定
-----------------------------------------------------------------------------*/
article.shopinfo-box th { width: 20%; color: rgba(95,50,0,1.0); border-right: 1px dotted rgba(180,180,180,1.0); }
article.shopinfo-box td { width: 80%; color: rgba(50,50,50,1.0); }
div.googlemap-box { width: 100%; position: relative; padding-top: 56.25%; overflow: auto; -webkit-overflow-scrolling: touch; border: solid 1px rgba(180,180,180,1.0); margin-top: 20px; }
div.googlemap-box iframe { width: 100%; height: 100%; position: absolute; top: 0; left: 0; border: none; display: block; padding: 5px; }

/* =店舗情報内グリッドボックス設定
-----------------------------------------------------------------------------*/
ul.photo-gridbox { width: 100%; list-style: none; display: flex; justify-content: space-between; flex-wrap: wrap; margin-bottom: 20px; }
ul.photo-gridbox li { background-color: rgba(255,255,255,1.0); border: 1px solid rgba(180,180,180,1.0); padding: 5px; }
ul.threebox-gridbox li { width: calc( 33.3% - 5px); display: flex; flex-direction: column; } /* グリッドレイアウト三分割 */

/* =サイトマップ設定
-----------------------------------------------------------------------------*/
ul.sitemap-box { list-style: square; column-count: 3; margin-left: 2.0em; }
ul.sitemap-box li a { display: block; text-align: left; page-break-inside: avoid; break-inside: avoid; transform: translateZ(0); adding: 0.3em 0.5em; }



/* =tablet
----------------------------*/
@media only screen and (max-width: 1000px) {

/* =ヘッダー＆フッター共通部分
-----------------------------------------------------------------------------*/
div.logo-box p { font-size: 1.3rem; font-weight: 400; }

/* =ヘッダー設定
-----------------------------------------------------------------------------*/
div.header-box > div { padding-top: 15px; padding-bottom: 15px; }
div.title-box  { padding-left: 20px; padding-right: 20px; }

/* =フッター設定
-----------------------------------------------------------------------------*/
div.shoplist-box ul { padding-right: 10px; }

/* =フッターその他ボタン設定
-----------------------------------------------------------------------------*/
div.footer-button div { padding-left: 10px; padding-right: 10px; }

/* =フッターコピーライト＆ページトップボタン設定
-----------------------------------------------------------------------------*/
div.footer-bottom div { padding-left: 10px; padding-right: 10px; }

/* =メイン画像設定
-----------------------------------------------------------------------------*/
div.main-imgbox div { border-left: none; border-right: none; }
div.main-imgbox figure {  margin: 10px 0; }
div.main-imgbox h2 { right: 30px; }

/* =メインメニューフォントサイズ共通設定
-----------------------------------------------------------------------------*/
ul.main-menu h3, ul.main-menu li, div.shoplist-box li, ul.otherbutton-box li { font-size: 1.4rem; }

/* =メインメニュー設定
-----------------------------------------------------------------------------*/
ul.main-menu { border-right: none; }
ul.main-menu > li:first-child { border-left: none; }
ul.main-menu > li { padding: 0 1.0em; }

/* =メインメニュー内サブ設定
-----------------------------------------------------------------------------*/
div.sub-menubox { padding: 15px 10px; }

/* =パンクズリスト設定
-----------------------------------------------------------------------------*/
div.breadcrumb-box { padding: 0.25em 10px; }
div.breadcrumb-box li { font-size: 1.4rem!important; }

/* =アイキャッチ設定
-----------------------------------------------------------------------------*/
div.eyecatch-box > div { margin: 0 10px; }

}



/* =tablet
----------------------------*/
@media only screen and (max-width: 850px) {

/* =ヘッダー＆フッター共通部分
-----------------------------------------------------------------------------*/
div.logo-box { width: 300px; } /* ロゴ部分設定 */
div.logo-box figure { max-width: 100px; height: auto; }

/* =ヘッダー設定
-----------------------------------------------------------------------------*/
div.title-box h1 { font-size: 1.6rem; }

/* =アイキャッチ設定
-----------------------------------------------------------------------------*/
div.eyecatch-box > div { padding: 30px 20px; }

/* =メイン共通設定
-----------------------------------------------------------------------------*/
div.content-box { padding-left: 15px; padding-right: 15px; }

}



/* =tablet
----------------------------*/
@media only screen and (max-width: 767px) {

/* =ヘッダー＆フッター共通部分
-----------------------------------------------------------------------------*/
div.header-box > div.logo-box  { width: 100%; display: flex; flex-direction: row; } /* ロゴ部分設定 */
div.header-box > div.logo-box figure { width: 45px; min-width: 45px; height: auto; margin: 0 5px; }
div.header-box > div.logo-box p { font-size: 1.2rem; text-align: left; display: table-cell; vertical-align: middle; margin-top: 0; }

/* =ヘッダー設定
-----------------------------------------------------------------------------*/
div.header-box { width: 100%; display: flex; position: fixed; top: 0; z-index: 1; border-bottom: 1px solid rgba(225,35,55,1.0); }
div.header-box > div { padding-top: 5px; padding-bottom: 5px; }
div.title-box { flex: none; width: 46px; padding-left: 5px; }
div.title-box > div:nth-of-type(1) { display: none; }

/* =フッター設定
-----------------------------------------------------------------------------*/
nav.footer-navbox { display: none; padding: 10px 0; }
div.footer-box > div { padding-top: 20px; padding-bottom: 15px; }
div.footer-box > div.logo-box  { width: 100%; } 
div.shoplist-box { display: none; }

/* =フッターその他ボタン設定
-----------------------------------------------------------------------------*/
div.footer-button div { flex-direction: column; }
ul.snsbutton-box > li:nth-of-type(3) { margin-right: 0; }
ul.otherbutton-box { margin-top: 5px; }
ul.otherbutton-box li a:nth-of-type(1) { margin-left: 0; }

/* =フッターコピーライト＆ページトップボタン設定
-----------------------------------------------------------------------------*/
div.footer-bottom p, p.pagetop-button a { font-size: 1.2rem; }

/* =メイン画像設定
-----------------------------------------------------------------------------*/
div.main-imgbox { margin-top: 56px; }
div.main-imgbox div { border: none; }
div.main-imgbox h2 { font-size: 2.2rem; right: 20px; }
div.main-imgbox h2 { text-shadow: 0 0 3px rgba(0,0,0,1.0), 0 0 3px rgba(0,0,0,1.0), 0 0 5px rgba(0,0,0,0.5); } /* テキスト光彩設定 */
div.main-imgbox figure { margin: 10px 0 0; }

/* =メインメニュー設定
-----------------------------------------------------------------------------*/
nav.main-navbox { display: none; }

/* =メイン共通設定
-----------------------------------------------------------------------------*/
#main { padding-top: 10px; }

/* =メインフォントサイズ共通設定
-----------------------------------------------------------------------------*/
#main h2 { font-size: 2.4rem; }
#main h3 { font-size: 2.0rem; }
#main h4 { font-size: 1.8rem; }
#main h3.sub-title { border-radius: 8px; padding: 8px 15px; }
#main h3.concept-title { font-size: 2.7rem; }
#main h3.emphasize-title { border-radius: 8px; padding: 8px 15px; }

/* =メイン内テーブル基本設定
-----------------------------------------------------------------------------*/
#main th { font-size: 1.4rem; padding-top: 0.6em; padding-bottom: 0.6em; }
#main td { font-size: 1.4rem; padding-top: 0.6em; padding-bottom: 0.6em; }

/* =アイキャッチ設定
-----------------------------------------------------------------------------*/
div.eyecatch-box { margin-bottom: 10px; }
div.eyecatch-box > div { padding: 20px 20px; }
div.eyecatch-title figure { max-width: 400px; }
div.eyecatch-price p { font-size: 1.8rem!important;  }
div.eyecatch-price span { font-size: 170%; }

/* =アテンションボックス設定
-----------------------------------------------------------------------------*/
div.attention-box article { padding: 10px 0 30px; }
section.attention-section { padding: 20px; } 

}



/* =smart
----------------------------*/
@media only screen and (max-width: 599px) {

#footer { padding-bottom: 40px; }

/* =文字 基本設定
-----------------------------------------------------------------------------*/
br.br-none { display: block; } /* 改行設定 */

/* =メインフォントサイズ共通設定
-----------------------------------------------------------------------------*/
#main h2.main-title { text-align: left; padding: 0 0 0.25em; }
#main h3.concept-title { font-size: 2.4rem; text-align: left; }
#main h3.emphasize-title { text-align: left; line-height: 1.2; border-radius: 10px; padding: 6px 10px; }
span.emphasize-size { font-size: 100%; }

/* =メイン内テーブル基本設定
-----------------------------------------------------------------------------*/
#main th { display: block; font-size: 1.5rem; border-bottom: 1px dotted rgba(180,180,180,1.0); padding-right: 0; }
#main td { display: block; font-size: 1.5rem; padding-left: 0; }

/* =パンクズリスト設定
-----------------------------------------------------------------------------*/
div.breadcrumb-box { display: none; }

/* =アイキャッチ設定
-----------------------------------------------------------------------------*/
div.eyecatch-price div:nth-of-type(1) { display: none; }
div.eyecatch-price div:nth-of-type(2) { width: 100%; text-align: center; }
div.eyecatch-price div:nth-of-type(2) img { max-width: 400px; }

/* =ウェルカムボックス設定
-----------------------------------------------------------------------------*/
div.welcome-box p { font-size: 1.6rem!important; }

/* =アテンションボックス設定
-----------------------------------------------------------------------------*/
section.attention-section { padding: 15px 20px 25px; } 

/* =新着情報設定
-----------------------------------------------------------------------------*/
article.information-box th { width: 100%; border-right: none; }
article.information-box td { width: 100%; padding-bottom: 2.0em!important; }

/* =料金表設定
-----------------------------------------------------------------------------*/
section.tariff-box th { width: 50%; display: inline-block!important; border-bottom: 1px solid rgba(180,180,180,1.0)!important; }
section.tariff-box td { width: 50%!important; display: inline-block!important; }

/* =店舗案内設定
-----------------------------------------------------------------------------*/
article.shop-box th { width: 100%; border-right: none; }
article.shop-box td { width: 100%; }

/* =店舗情報設定
-----------------------------------------------------------------------------*/
article.shopinfo-box th { width: 100%; border-right: none; }
article.shopinfo-box td { width: 100%; }

/* =店舗情報内グリッドボックス設定
-----------------------------------------------------------------------------*/
ul.photo-gridbox li:nth-of-type(3) { display: none; }
ul.threebox-gridbox li { width: calc( 50% - 5px); } /* グリッドレイアウト三分割 */

/* =サイトマップ設定
-----------------------------------------------------------------------------*/
ul.sitemap-box { column-count: 2; }

}



/* =smart
----------------------------*/
@media screen and (max-width: 499px){

/* =メイン画像設定
-----------------------------------------------------------------------------*/
div.main-imgbox h2 { font-size: 2.0rem; right: 10px; }

/* =メインフォントサイズ共通設定
-----------------------------------------------------------------------------*/
#main h2 { font-size: 2.2rem; }
#main h3 { font-size: 1.8rem; }
#main h4 { font-size: 1.6rem; }
#main p { font-size: 1.5rem; }
#main ul li { font-size: 1.5rem; }

}



/* =smart
----------------------------*/
@media screen and (max-width: 399px){

/* =ヘッダー＆フッター共通部分
-----------------------------------------------------------------------------*/
div.header-box > div.logo-box figure { margin: 0 2px 0 5px; }
div.header-box > div.logo-box p { font-size: 1.1rem; line-height: 1.5; }

/* =メイン画像設定
-----------------------------------------------------------------------------*/
div.main-imgbox h2 { font-size: 1.8rem; }
div.main-imgbox h2 { text-shadow: 0 0 2px rgba(0,0,0,1.0), 0 0 2px rgba(0,0,0,1.0), 0 0 5px rgba(0,0,0,0.5); } /* テキスト光彩設定 */

/* =アイキャッチ設定
-----------------------------------------------------------------------------*/
div.eyecatch-box > div { padding: 10px 10px; }
div.eyecatch-price p { font-size: 1.5rem!important; }
div.eyecatch-price span { font-size: 140%; }

/* =店舗情報内グリッドボックス設定
-----------------------------------------------------------------------------*/
ul.photo-gridbox li:nth-of-type(2) { display: none; }
ul.threebox-gridbox li { width: 100%; } /* グリッドレイアウト三分割 */

/* =サイトマップ設定
-----------------------------------------------------------------------------*/
ul.sitemap-box { column-count: 1; }

}