@charset "utf-8";

* { color: #333; font-size: 16px; padding: 0; margin: 0; box-sizing: border-box; }
html, body { line-height: 2; width: 100%; height: 100%; }
a { text-decoration: none; }
ul { list-style: none; }
img { width: 100%; max-width: 100%; height: auto; }
#wrapper { overflow: hidden; width: 80%; margin: 0 auto; }

/* ヘッダー
------------------------------ */
header { overflow: hidden; width: 90%; margin: 10px auto; z-index: 1; }
header table { float: left; width: 70%; }
header table th { width: 80px; }
header table td { font-size: 1.6em; padding-left: 10px; }
header table td span { font-size: 1.2em; }
header #adress { float: right; width: 30%; line-height: 1.3; }

/* 左カラム
------------------------------ */
#leftColumn { float: left; width: 20%; padding: 1em; }

/* 右カラム
------------------------------ */
#rightColumn { float: right; width: 80%; padding: 1em; }
.contentsTitle { font-size: 1.5em; text-align: center; width: 90%; margin: 30px auto; padding: 10px 0; border-radius: 6px; background: #f0f0f0; }

/*お食事のお困りごとはありませんか？*/
#problem h2 { color: orange; font-size: 1.5em; font-weight: normal; text-align: center; /*margin: 0 0 30px;*/ }
#problem ul { padding: 10px; border-radius: 6px; width: 600px; margin: 0 auto; background: rgb(255,91,161); }
#problem ul li { font-size: 1.5em; padding: 10px; background: #f0f0f0; }
#problem ul ul li::before { content: "■ "; color: rgb(255,91,161); }
#solution img { display: block; width: 100px; margin: 20px auto 0; }
#solution p { color: #f00; font-size: 3em; font-weight: bold; text-align: center; }

/*ラインアップ*/
.lineUpTitle { font-size: 2em; text-align: center; width: 90%; margin: 30px auto 0;}
.lineUpTitle:before { content: "★ "; color: rgb(255,91,161); font-size: 1.2em; }
.lineUpTitle:after { content: " ★"; color: rgb(255,91,161); font-size: 1.2em; }
#lineUp #otameshi { text-align: center; line-height: 1.6; }
#lineUp #otameshi span { color: rgb(255,91,161); font-size: 2em; font-weight: bold; }
#lineUp #keiyaku { width: 550px; margin: 0 auto; }
#lineUp #keiyaku table { text-align: center; line-height: 1.6; width: 550px; margin: 20px 0 0; border: 2px solid rgb(255,91,161); border-collapse: collapse; }
#lineUp #keiyaku table th { width: 250px; background: rgb(255,91,161); }
#lineUp #keiyaku table td { width: 300px; background: #eee; }
#lineUp #keiyaku .otoku { font-size: 1.2em; }
#lineUp #keiyaku .otoku span { color: #f00; font-size: 1.5em; border-radius: 50%; background: rgba(254,243,12,0.6); }
.area th { padding: 10px; }
.order { width: 550px; margin-top: 30px; padding: 10px 0 10px 1em; border: 2px solid rgb(255,91,161); }
.order span { display: block; font-size: 0.8em; }
/*.order dt,
.order dd { padding: 10px 0 10px 1em; border: 2px solid rgb(255,91,161); }
.order dt { font-weight: bold; background: rgb(255,91,161); }*/
.otoiawase { width: 360px; margin: 30px auto; }
.otoiawase a { transition: 0.6s; opacity: 1; }
.otoiawase a:hover { opacity: 0.6; }
#lineUp .lineUpCatch { font-size: 1.3em; text-align: center; margin: 0 0 10px; }
#lineUp .lineUpCatch br { display: none; }
#lineUp ul { overflow: hidden; width: 90%; margin: 0 auto; }
#lineUp ul li { border-radius: 6px; border: 3px solid rgb(255,91,161); }
#lineUp ul li:nth-child(odd) { float: left; width: 49%; }
#lineUp ul li:nth-child(even) { float: right; width: 49%; }
#lineUp ul li:nth-child(1),
#lineUp ul li:nth-child(2) { margin-bottom: 20px; }
/*仕出し*/
#shidashiOutline { position: relative; margin: 100px 0; }
#shidashiPrice { position: absolute; top: -75px; left: 50px; width: 180px; height: 180px; }
#shidashi {  overflow: hidden; width: 906px; margin: 0 auto; border-radius: 6px; border: 3px solid rgb(255,91,161); }
#shidashi > img { float: left; width: 400px; }
#shidashi #detail { float: right; width: 500px; text-align: center; }
#shidashi #detail { font-size: 1.6em; }
#shidashi #detail span { font-size: 1.3em; }
#shidashi #detail a { display: block; width: 400px; margin: 10px auto 0; }

/*流れ*/
#flow table { width: 810px; margin: 0 auto; border-collapse: collapse; }
#flow table th { text-align: left; width: 120px; padding: 10px; border-bottom: 2px solid #fff; background: rgb(255,91,161); }
#flow table th span { font-size: 2em; }
#flow table td { line-height: 1.6; padding: 10px 0 10px 10px; border-bottom: 2px solid #f0f0f0; width: 500px; }
#flow table td:last-child { width: 150px; }

/*問い合わせ*/
#inquiry { margin: 50px auto; }
#inquiry td { vertical-align: middle; }
#inquiry a { display: block; }
#inquiry img { width: 400px; }

/* フッター
------------------------------ */
footer { text-align: center; padding: 22px 0 20px; background: rgb(255,91,161);; }

/* レスポンシブ
------------------------------ */
/* 1280px */
@media screen and (max-width:1280px) {
	/*ラインアップ*/
	#lineUp .titleOuter { width: 100%; }
	/*仕出し*/
	#shidashiOutline { position: relative; width: 76%; margin: 50px auto; }
	#shidashiPrice { top: 0; left: 20px; width: 130px; height: 130px; }
	#shidashi { overflow: visible; width: 96%; }
	#shidashi > img { display: block; float: none; width: 96%; margin: 0 auto; }
	#shidashi #detail { float: none; width: 100%; line-height: 1.6; }
	#shidashi #detail a { margin: 30px auto; }
	/*流れ*/
	#flow table { width: 70%; }
	#flow table th,
	#flow table td { display: inline-block; width: 100%; padding: 0; border: none; }
	#flow table th { border-radius: 6px; padding-left: 10px; }
	#flow table td { padding: 10px 0 0 10px; }
	#flow table td:last-child { width: 100%; }
	#flow table td img { display: block; width: 200px; margin: 0 auto 20px; }
}
/* 1024px */
@media screen and (max-width:1024px) {
	#wrapper { width: 96%; }
}

/* 812px */
@media screen and (max-width:812px) {
	#wrapper { overflow: visible; width: 100%; }
	/* ヘッダー
	------------------------------ */
	header { overflow: visible; width: 90%; }
	header table { float: none; width: 100%; }
	header #adress { float: none; display: none; }
	header table td { vertical-align: middle; }
	/*仕出し*/
	#shidashiOutline { width: 90%; }
	
	/* 左カラム
	------------------------------ */
	#leftColumn { float: none; width: auto; padding: 0; }

	/* 右カラム
	------------------------------ */
	#rightColumn { float: none; width: 90%; margin: 0 auto; }
}

/* 667px */
@media screen and (max-width:667px) {
	.contentsTitle { width: 96%; }
	/*仕出し*/
	#shidashiOutline { width: 96%; }
}

/* 414px */
@media screen and (max-width:414px) {
	#wrapper { width: 100%; }
	
	/* 右カラム
	------------------------------ */
	#rightColumn { width: 100%; padding: 0; }
	/*お食事のお困りごとはありませんか？*/
	#solution p { font-size: 2em; }
	/*ラインアップ*/
	.lineUpTitle { margin: 20px auto 0; }
	#lineUp #keiyaku .otoku { text-align: center; line-height: 1.6; margin: 0 0 50px; }
	#lineUp #keiyaku .otoku span { display: block; font-size: 1.2em; }
.order { width: 100%; margin: 30px auto 0; }
/*.order dt,
.order dd { padding: 10px 0 10px 1em; border: 2px solid rgb(255,91,161); }
.order dt { font-weight: bold; background: rgb(255,91,161); }*/
	/*仕出し*/
	#shidashiOutline { width: 90%; }
	#shidashiPrice { top: -50px; left: 0; }
	#shidashi #detail { font-size: 1em; }
	#shidashi #detail a { width: 96%; }
	/*流れ*/
	#flow table { width: 96%; }
	/* ヘッダー
	------------------------------ */
	header table th { width: 50px; }
	header table td { font-size: 1.5em; padding-left: 10px; }
	header table td span { font-size: 0.8em; }
	
	/* ヘッダー
	------------------------------ */
	
	/* 右カラム
	------------------------------ */
	
	/*問題点*/
	#problem h2 { font-size: 1.4em; }
	#problem ul { width: 400px; }
	#problem ul li { font-size: 1em; padding: 6px; }
	
	/*ラインアップ*/
	#lineUp #otameshi { margin-bottom: 20px; }
	#lineUp #keiyaku table th, #lineUp #keiyaku table td { display: block; width: 370px; padding: 10px 0; }
	#lineUp #keiyaku { width: 370px; }
	#lineUp #keiyaku table { width: 370px; margin: 0 0 10px; }
	#lineUp .lineUpCatch br { display: block; }
	#lineUp ul { overflow: visible; }
	#lineUp ul li:nth-child(odd) { float: none; width: 100%; }
	#lineUp ul li:nth-child(even) { float: none; width: 100%; }
	#lineUp ul li:nth-child(1),
	#lineUp ul li:nth-child(2) { margin-bottom: 0; }
	#lineUp ul li:not(:last-child) { margin-bottom: 10px; }
/*問い合わせ*/
#inquiry { width: 90%; margin: 50px auto; }
#inquiry td { display: block; width: 90%; }
	#inquiry td:last-child { margin-top: 20px; }

	/*フッター*/
	footer { font-size: 11px; }
}
@media screen and (max-width:375px) {
	/* 右カラム
	------------------------------ */
	
	/*問題点*/
	#problem h2 { font-size: 1.3em; }
	#problem ul { width: 370px; }
	#problem ul li { font-size: 0.9em; }
}