/*----------------------------------------------

共通スタイル設定

----------------------------------------------*/

body, div, span, h1, h2, h3, h4, h5, ul, ol, li, dl, dt, dd, table, td, tr, th, p, form {
	margin: 0;
	padding: 0;
}

body {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
	font-size: 90%;
	line-height: 1.5;
	color: #3F4445;
	text-align:center;
    -webkit-print-color-adjust: exact;/* infxxxxm add */
}
section, aside, nav, footer, small, figure {
	display: block;
	margin:0;
	padding:0;
}
a:link,
a:visited {
	color:#199EC5;
	text-decoration: underline;
}
a:hover {
	color:#199EC5;
	text-decoration: none;

}
a img {
	border: none;
}
li { list-style:none; }

/* 2019.12追加 ここから */
/* margin */
.mb0 { margin-bottom: 0px !important; }
.mb1 { margin-bottom: 1px !important; }
.mb2 { margin-bottom: 2px !important; }
.mb3 { margin-bottom: 3px !important; }
.mb4 { margin-bottom: 4px !important; }
.mb5 { margin-bottom: 5px !important; }
.mb6 { margin-bottom: 6px !important; }
.mb7 { margin-bottom: 7px !important; }
.mb8 { margin-bottom: 8px !important; }
.mb9 { margin-bottom: 9px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb11 { margin-bottom: 11px !important; }
.mb12 { margin-bottom: 12px !important; }
.mb13 { margin-bottom: 13px !important; }
.mb14 { margin-bottom: 14px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mt0 { margin-top: 0px !important; }
.mt1 { margin-top: 1px !important; }
.mt2 { margin-top: 2px !important; }
.mt3 { margin-top: 3px !important; }
.mt4 { margin-top: 4px !important; }
.mt5 { margin-top: 5px !important; }
.mt6 { margin-top: 6px !important; }
.mt7 { margin-top: 7px !important; }
.mt8 { margin-top: 8px !important; }
.mt9 { margin-top: 9px !important; }
.mt10 { margin-top: 10px !important; }
.mt11 { margin-top: 11px !important; }
.mt12 { margin-top: 12px !important; }
.mt13 { margin-top: 13px !important; }
.mt14 { margin-top: 14px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.ml0 { margin-left: 0px !important; }
.ml5 { margin-left: 5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.mr0 { margin-right: 0px !important; }
.mr5 { margin-right: 5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
/* padding */
.p0 { padding: 0px !important; }
.p1 { padding: 1px !important; }
.p2 { padding: 2px !important; }
.p3 { padding: 3px !important; }
.p4 { padding: 4px !important; }
.p5 { padding: 5px !important; }
.p6 { padding: 6px !important; }
.p7 { padding: 7px !important; }
.p8 { padding: 8px !important; }
.p9 { padding: 9px !important; }
.p10 { padding: 10px !important; }
.p15 { padding: 15px !important; }
.p20 { padding: 20px !important; }
.pb0 { padding-bottom: 0px !important; }
.pb1 { padding-bottom: 1px !important; }
.pb2 { padding-bottom: 2px !important; }
.pb3 { padding-bottom: 3px !important; }
.pb4 { padding-bottom: 4px !important; }
.pb5 { padding-bottom: 5px !important; }
.pb6 { padding-bottom: 6px !important; }
.pb7 { padding-bottom: 7px !important; }
.pb8 { padding-bottom: 8px !important; }
.pb9 { padding-bottom: 9px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb11 { padding-bottom: 11px !important; }
.pb12 { padding-bottom: 12px !important; }
.pb13 { padding-bottom: 13px !important; }
.pb14 { padding-bottom: 14px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pt0 { padding-top: 0px !important; }
.pt1 { padding-top: 1px !important; }
.pt2 { padding-top: 2px !important; }
.pt3 { padding-top: 3px !important; }
.pt4 { padding-top: 4px !important; }
.pt5 { padding-top: 5px !important; }
.pt6 { padding-top: 6px !important; }
.pt7 { padding-top: 7px !important; }
.pt8 { padding-top: 8px !important; }
.pt9 { padding-top: 9px !important; }
.pt10 { padding-top: 10px !important; }
.pt11 { padding-top: 11px !important; }
.pt12 { padding-top: 12px !important; }
.pt13 { padding-top: 13px !important; }
.pt14 { padding-top: 14px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pl0 { padding-left: 0px !important; }
.pl5 { padding-left: 5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }
.pl25 { padding-left: 25px !important; }
.pl30 { padding-left: 30px !important; }
.pr0 { padding-right: 0px !important; }
.pr5 { padding-right: 5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }
.pr25 { padding-right: 25px !important; }
.pr30 { padding-right: 30px !important; }
/* color */
.color-green {color: #71ac02;}
.color-blue {color: #199EC5;}
/* 2019.12追加 ここまで */

/* debug */
.cake-debug { text-align : left; margin-left: 50px;}

/*----------------------------------------------

ヘッダー　グローバルナビ以外の部分

----------------------------------------------*/

div#headerup {
	width: 950px;
	margin: 0 auto;
	display:-webkit-box;
	display:-ms-flexbox;
	display: flex;
}


div#headerup h1 {
	text-align: left;
	margin: 10px 0 5px;
}
/*infxxxxm add*/
div#headerup.notab h1 {
    margin: 34px 0 0px;
}
/*infxxxxm add*/
div#headerup.nologin h1 {
    margin: 20px 0px -5px 0px;
}
div#headerup h1 img {
	vertical-align: text-bottom;
}
div#headerup div#header-l {
	display: flex;
	display:-webkit-box;
	display:-ms-flexbox;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-ms-flex-item-align: end;
	align-self: flex-end;
	width: 330px;
}
div#headerup div#header-r {
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	width: 620px;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

/*　アラート表示　*/
div#headerup div#header-r p.hAlert {
	background: #00A0C9;
	padding: 10px 10px 14px;
	margin-right: 5px;
}
div#headerup div#header-r p#hAlertnon {
	background: #54AF2C;
}
div#headerup div#header-r p.hAlert a {
	color: #FFF;
	display: inline-block;
}
div#headerup div#header-r p.hAlert a span {
	color: #FFF;
	font-size: 12px;
	margin-left: 0;
}
div#headerup div#header-r p.hAlert:before {
	content:'';
	display: inline-block;
	width: 30px;
	height:27px;
	background:url(../../img/base/icon_alert.png) no-repeat;
	background-size:30px 27px;
	margin-right:10px;
}
div#headerup div#header-r p#hAlertnon:before {
	content:'';
	display: inline-block;
	width: 6px;
	height:10px;
	background:url(../../img/haccp/icon-linkw.png) no-repeat;
	background-size:6px 10px;
	margin-right:10px;
	vertical-align: top;
	margin-top: 15px;
}

/*　ログイン名表示　*/
div#headerup div#header-r p {
    max-width: 265px;
	text-align: left;
	background: #3F4445;
	font-weight: bold;
	color: #FFF;
	font-size: 90%;
	padding: 10px 20px;
	display: inline-block;
	vertical-align: top;
	-webkit-border-radius: 0px 0px 8px 8px;
    -moz-border-radius: 0px 0px 8px 8px;
    border-radius: 0px 0px 8px 8px;
	position: relative;
	behavior: url(/PIE.htc);
}
div#headerup div#header-r p span {
	font-size: 120%;
	margin-left: 10px;
}

/*　アカウント情報の編集・ログアウト　*/
div#headerup div#header-r div#btn-space {
    clear:both;
    padding-top: 8px;
    width: 620px;
}
div#headerup div#header-r div#btn-space p {
    background: none;
    float: right;
    padding: 0px;
}
/*infxxxxm add*/
div#headerup.notab div#header-r div#btn-space p {
    padding-bottom: 3px;
}
/*----------------------------------------------

ヘッダー　グローバルナビ

----------------------------------------------*/

#gnav {
	clear: both;
	text-align: left;
	background: url(../../img/base/nav-bg.gif) repeat-x left bottom;
    background-color: #6BAC43;
}
#gnav:after {
	content:".";
	display:block;
	height:0;
	clear:both;
	visibility:hidden;
}
/*infxxxxm add HOMEリンク*/
#gnav .home-link {
    padding-left: 32px;
    padding-right: 32px;
}

#nav-tab ul {
	display: flex;
	display:-webkit-box;
	display:-ms-flexbox;
	width: 950px;
	margin: 0 auto;
}
#nav-tab ul li {
	font-size: 80%;
	margin: 0 5px;
	padding: 3px 20px;
	background: #eee;
	cursor: pointer;
	border-radius: 4px 4px 0 0;
}
#nav-tab ul li.active,#nav-tab ul li:hover {
	background: #6BAC43;
	color: #fff;
}

.nav {
	width: 950px;
	margin: 0 auto;
	position: relative;
	text-align: left;
}
.nav li {
	list-style: none;
	float: left;
	position: relative;
	background: url(../../img/base/line-nav.gif) left center no-repeat;
}
.nav li#line-none {
	background: none;
}
.nav li a {
	font-size: 13px;
	padding: 10px 14px;
	display: block;
}
.nav li a.icon-plus:before {
	content: url(../../img/base/icon-plus.gif);
} 
.nav li a:link,
.nav li a:visited {
	color:#FFFFFF;
	text-decoration: none;
	display: block;
}

.nav li a#active:link,
.nav li a#active:visited,
.nav li a:hover,
.nav li a#active:hover {
	background: url(../../img/base/icon-nav.gif) no-repeat center 30px #49762E;
}

.nav ul {
	display: none;
	position: absolute;
	top: 39px;
	left: 0;
}
.nav ul li {
	float: none;
	background: none;
	width: 240px; 
}

.nav ul {
	width: 240px; 
	background-color: rgba(110,172,54,0.9);
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#FF6EAC36', endColorstr='#FF6EAC36')";
}
.nav ul a {
	display: block;
	background: none;
	color: #FFF;
	border-bottom: 1px dotted #FFF;
	padding: 6px 8px;
	zoom: 1;
}
.nav ul a:hover  {
    background: #49762E;
}
.disnon {
    display: none;
}
header#fsopContents {
	border-bottom: solid 5px #71ac02;
}
/*----------------------------------------------

ぱんくず

----------------------------------------------*/

p#pankuzu {
	width: 950px;
	clear: both;
	text-align: left;
	margin-right: auto;
	margin-left: auto;
	margin-top: 10px;
}
p#pankuzu img {
	vertical-align: bottom;
}


/*----------------------------------------------

コンテンツ

----------------------------------------------*/

div#contents {
	width: 950px;
	text-align: left;
	margin-right: auto;
	margin-left: auto;
	margin-top: 15px;
	display: box;
	display: -webkit-box;
	display: -moz-box;
	display: -ms-box;
	padding-bottom:30px;
}
div#contents:after {
	content:".";
	display:block;
	height:0;
	clear:both;
	visibility:hidden;
}

/*　大見出し　*/
h1#midashi {
	background: url(../../img/base/midashi-bg.gif) repeat-x left top;
	border-top: 1px solid #CCCCCC;
	border-bottom: 2px solid #BABABA;
	font-size: 130%;
	width: 940px;
	padding-top: 10px;
	padding-bottom: 8px;
	padding-left: 10px;
    word-break: break-all;
}

h1#midashi span {
	font-size:12px;
	font-weight: normal;
	margin-left: 15px;
}

/*　中見出し　*/
h1.chumidashi,
h2.chumidashi {
	padding-bottom: 4px;
	border-bottom: 1px solid #BABABA;
	font-size: 120%;
	padding-left: 30px;
	padding-top: 4px;
}

/*　小見出し　*/
h1.shomidashi,
h2.shomidashi,
h3.shomidashi {
	background: url(../../img/base/shomidashi-bg.gif) repeat-x left top;
	border-left: 8px solid #6C7276;
	font-size: 110%;
	padding-top: 5px;
	padding-bottom: 5px;
	padding-left: 5px;
	clear: both;
	margin-top: 15px;
}

/* 2019.12追加 ここから */
/* リスト */
.list-ul {list-style: disc;padding-left: 20px;}
.list-ul li {list-style: disc;margin-bottom: 10px;}
.list-ul li a {display: inline-block;margin-left: 10px;}
/* 2019.12追加 ここまで */

/*　店舗住所　*/
div#contents p#jusho {
	margin-top: 15px;
	padding-bottom: 15px;
	border-bottom: 1px solid #BABABA;
	padding-left: 10px;
}

/*----------------------------------------------

並び替え

----------------------------------------------*/
table thead tr th a.desc {
	background: url(../../img/base/icon-shitasankaku.gif) no-repeat right center;
    padding-right: 12px;
}
table thead tr th a.asc {
	background: url(../../img/base/icon-uesankaku.gif) no-repeat right center;
    padding-right: 12px;
}

/*----------------------------------------------

ページ切り替え

----------------------------------------------*/
p.page-link {
	text-align: center;
	font-size: 14px;
	clear: both;
}
p.page-link .current {
    font-weight: bold;
	margin-right: 5px;
	background: #DDF1F7;
	border: 1px solid #189EC5;
	padding: 4px 2px 2px;
}
p.page-link span {
	padding-right: 0px;
}
p.page-link span a {
    padding-right: 5px;
}
p.page-link .align-l {
	float: left;
	margin-right: 0px;
}
p.page-link .align-r {
	float: right;
}
/*p.page-link {
	text-align: center;
	font-size: 14px;
	clear: both;
}
p.page-link strong {
	margin-right: 5px;
	background: #DDF1F7;
	border: 1px solid #189EC5;
	padding: 4px 2px 2px;
}
p.page-link a {
	margin-right: 5px;
}
p.page-link a.align-l {
	float: left;
	margin-right: 0px;
}
p.page-link a.align-r {
	float: right;
}*/

/*----------------------------------------------

フッター

----------------------------------------------*/

footer {
	text-align: left;
	clear: both;
	margin-top: 20px;
}
footer div#footer-link p#pagetop {
	text-align: right;
	width: 950px;
	margin-right: auto;
	margin-left: auto;
}
footer div#footer-link {
	background: url(../../img/base/footerlink-bg.gif) repeat-x left 34px;
	font-size: 90%;
}
footer div#footer-link ul {
	width: 950px;
	margin-right: auto;
	margin-left: auto;
	padding-bottom: 4px;
}
footer div#footer-link ul:after,
footer div#footer-copyright div#copyright:after {
	content:".";
	display:block;
	height:0;
	clear:both;
	visibility:hidden;
}
footer div#footer-link ul li {
	float: left;
	margin-right: 10px;
	padding-top: 2px;
	padding-bottom: 2px;
	background: url(../../img/base/icon-footer.gif) no-repeat left center;
	padding-left: 10px;
} 
footer div#footer-link ul a:link,
footer div#footer-link ul a:visited {
	color:#FFFFFF;
	text-decoration: none;
}
footer div#footer-link ul a:hover {
	color:#FFFFFF;
	text-decoration: underline;

}
footer #footer-copyright {
	background: #D6D6D6 url(../../img/base/footer-bg.gif) repeat-x left top;
	clear: both;
}
footer div#footer-copyright div#copyright {
	width: 950px;
	margin-right: auto;
	margin-left: auto;
	padding-bottom: 50px;
}
footer div#footer-copyright div#copyright p {
	float: left;
	padding-top: 25px;
}
footer div#footer-copyright div#copyright p small {
	margin-left: 10px;
	margin-top: 15px;
}

/*----------------------------------------------

スマートフォン版サイトをみるボタン

----------------------------------------------*/

div#btn-sp {
	padding-bottom: 25px;
	clear: both;
}
div#btn-sp p {
	margin-right: 10px;
	margin-left: 10px;
	text-align: center;
}
div#btn-sp p a {
	display: block;
	background: #FFF;
	font-size: 300%;
	color: #3e4445;
	text-decoration: none;
	padding-top: 30px;
	padding-bottom: 30px;
	border: 1px solid #9F9F9F;
}
div#btn-sp p a img {
	margin-right: 10px;
	vertical-align: middle;
	width:37px;
	height:auto;
}

/* select2 */
.select2-container {
    text-align: left;
}
.select2-container--classic .select2-results__option[aria-disabled="true"] {
    background-color: #f4f4f4;
}
.select2-results__options[aria-multiselectable="true"] .select2-results__option[aria-selected="true"] {
    display: none;
}
