@charset "utf-8";
/* =Reset default browser CSS.
Based on work by Eric Meyer:http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}

:focus {
	outline: 0;
}

ol, ul {
	list-style: none;
}

table {
	border-collapse: separate;
	border-spacing: 0;
}

caption, th, td {
	font-weight: normal;
	text-align: left;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: "";
}

blockquote, q {
	quotes: "" "";
}

a img {
	border: 0;
}


figure {
	margin: 0
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}



.toggle-pc { display: block; }
.toggle-sp { display: none; }
@media only screen and (max-width: 640px) {
  .toggle-pc { display: none; }
  .toggle-sp { display: block; }
}


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

body {
	color: #555;
	font: 14px "ヒラギノ丸ゴ ProN W4", "Hiragino Maru Gothic ProN", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
	line-height: 1.5;
	background: #fffffff;
	-webkit-text-size-adjust: 100%;
}






/* menuボタン
------------------------------------------------------------*/

@charset "utf-8";
/* =Reset default browser CSS.
Based on work by Eric Meyer:http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}

:focus {
	outline: 0;
}

ol, ul {
	list-style: none;
}

table {
	border-collapse: separate;
	border-spacing: 0;
}

caption, th, td {
	font-weight: normal;
	text-align: left;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: "";
}

blockquote, q {
	quotes: "" "";
}

a img {
	border: 0;
}

figure {
	margin: 0
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}

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

/* リンク設定
------------------------------------------------------------*/

a {
	color: #358de0;
	text-decoration: none;
}

a:hover {
	color: #429bef;
}

a:active, a:focus {
	outline: 0;
}

/* 共通
------------------------------------------------------------*/

/* 全体
------------------------------------------------------------*/

#wrapper {
	margin: 20px auto 0;
	padding: 0 1%;
	width: 98%;
	position: relative;
}

.img-fluid {
	max-width: 100%;
	height: auto;
}

.inner {
	margin: 0 auto;
	width: 100%;
}

.text-center {
	text-align: center;
}

/* flex */

.flex-container {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
}

.flex-item75 {
	width: calc(75% - 20px);
	margin: 0 10px;
}

.flex-item60 {
	width: calc(60% - 20px);
	margin: 0 10px;
}

.flex-item50 {
	width: calc(50% - 20px);
	margin: 0 10px;
}

.flex-item40 {
	width: calc(40% - 20px);
	margin: 0 10px;
}

.flex-item25 {
	width: calc(25% - 20px);
	margin: 0 10px;
}

.mb-3 {
	margin-bottom: .75rem;
}

.movie-wrap {
	position: relative;
	padding-bottom: 56.25%;
	/*アスペクト比 16:9の場合の縦幅*/
	height: 0;
	overflow: hidden;
}

.movie-wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.tbl-w80 {
	width: 80%;
	margin: 0 auto;
}

@media only screen and (max-width: 960px) {
	.text-sm-center {
		text-align: center;
	}
	.flex-item75, .flex-item60, .flex-item50, .flex-item40, .flex-item25, .flex-item-img100 {
		width: 100%;
		margin: 0 10px;
	}
	.flex-item-img50 {
		width: calc(50% - 20px);
		margin: 0 10px;
	}
	.mt-sm-2 {
		margin-top: 0.5rem !important;
	}
	.mt-sm-4 {
		margin-top: 1.0rem !important;
	}
	.mt-sm-5 {
		margin-top: 2.0rem !important;
	}
	.tbl-w80 {
		width: 95%;
		margin: 0 auto;
	}
}

/*************
/* ヘッダー
*************/

#header {
	z-index: 100;
	margin: 20px 0 28px;
}

#header:after {
	content: "";
	display: block;
	clear: both;
	visibility: hidden;
}

#header h1 {
	font-size: 12px;
	font-weight: normal;
}

/*************
/* ロゴ
*************/

#header .logo {
	float: left;
	padding: 10px 0 0;
}

.logo a {
	font-size: 20px;
	color: #444;
	font-weight: bold;
	line-height: 1;
}

.logo span {
	font-size: 12px;
	font-weight: normal;
}

#header h1 {
	font-size: 11px;
	color: #444;
	margin: 10px 0 0;
}

/**************************
/* メイン画像（トップページ）
**************************/

#mainBanner {
	margin: 0 auto;
	padding: 0;
	width: 100%;
	line-height: 0;
}

#mainBanner .inner {
	position: relative;
}

#mainBanner img {
	max-width: 100%;
	height: auto;
}

.slogan {
	position: absolute;
	max-width: 100%;
	height: auto;
	bottom: 0;
	left: 0;
	padding: 5px 10px;
	line-height: 1.4;
	z-index: 100;
}

.slogan h2 {
	padding-bottom: 5px;
	color: #333;
	font-size: 20px;
}

.slogan h3 {
	font-size: 14px;
	color: #666;
}

/**************************
/* グリッド
**************************/

.gridWrapper {
	padding-bottom: 20px;
	clear: both;
	overflow: hidden;
}

h3 {
	padding: 13px 0;
	margin-bottom: 5px;
	font-weight: bold;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}

.top-h3 {
	padding-left: 20px;
}

.top-h3-text {
	max-width: 900px;
	margin: 0 auto;
}

.grid h3 {
	padding: 13px 0;
	margin-bottom: 5px;
	font-weight: bold;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}

.grid p {
	padding: 5px 0;
}

.grid p.img {
	float: left;
	margin: 3px 0 0 0;
}

.readmore {
	clear: both;
}

.readmore {
	padding: 3px 5px;
	border-radius: 3px;
	color: #fff;
	background: #999;
	margin: 10px 0;
	display: inline-block;
}

.readmore a:hover {
	background: #ccc;
}

/* フッター内のグリッド(3カラム) */

#footer .grid {
	border: 0;
	background: transparent;
}

#footer .grid p {
	padding: 0;
}

/*************
メイン コンテンツ
*************/

section.content {
	padding: 10px 0;
	margin-bottom: 20px;
	border-radius: 6px;
	overflow: hidden;
	font-size: 14px;
}

section.content p {
	margin-bottom: 5px;
}

/* アーカイブページ */

section.content .archive {
	padding: 20px 0 0;
	border-bottom: 1px dotted #ccc;
}

section.content p {
	margin-bottom: 5px;
}

h3.heading {
	margin-bottom: 30px;
	font-size: 16px;
	border-bottom: 2px solid #ccc;
}

section.content img {}

.alignleft {
	float: left;
	clear: left;
	margin: 3px 10px 10px 0;
}

.alignright {
	float: right;
	clear: right;
	margin: 3px 0 10px 10px;
}

.border, ul.list img {
	border: 4px solid #ebebeb;
}


/* オンラインショップ２ */

.online-shop2-under {
	height: 1px;

	max-width: 95%;
	margin: 20px auto 0;
	/* position: relative;
	left: 5%; */
}
.online-shop2-box {
	display: grid;
	gap: 4%;
	grid-template-columns: 1fr 1fr; 
	max-width: 900px;
	margin: 20px auto 0;
	padding: 0 5px;
}

.online-shop2-item {
	max-width: 400px;
}

.online-shop2-item  img {
	max-width: 100%;
}


/* オンラインショップ */

.online-shop-item {
	max-width: 720px;
	margin: 0 auto;
	padding: 12px 5px;
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.shop-list {
	width: 100%;
}

.shop-list div a img {
	width: 100%;
	height: 250px;
	object-fit: cover;
}

/*************
/* フッター
*************/

#footer {
	clear: both;
	padding: 20px 0;
	overflow: hidden;
}

.tel strong {
	font-size: 20px;
	font-weight: bold;
}

#footer .copyright {
	font-size: 11px;
}

/*************
サブ（フッター前）コンテンツ
*************/

#sub ul {
	padding: 10px;
}

#sub li {
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 1px dashed #ebebeb;
}

#sub li:last-child {
	border: 0;
	margin-bottom: 0;
}

#sub li a {
	color: #555;
	display: block;
}

#sub li a:hover {
	color: #a5a5a5;
}

#sub ul.list {
	padding-bottom: 7px;
}

#sub ul.list li {
	clear: both;
	margin-bottom: 5px;
	padding: 5px 0;
	overflow: hidden;
}

#sub ul.list li img {
	float: left;
	margin-right: 10px;
}

#sub ul.list li {
	font-size: 12px;
	line-height: 1.35;
}

#sub .grid h3 {
	border-radius: 0;
}

/* page navigation
------------------------------------------------------------*/

.pagenav {
	clear: both;
	width: 100%;
	height: 30px;
	margin: 5px 0 20px;
}

.pagenav a {
	color: #555;
}

.pagenav a:hover {
	color: #a5a5a5;
}

.prev {
	float: left
}

.next {
	float: right;
}

#pageLinks {
	clear: both;
	text-align: center;
}

/* タイポグラフィ
*****************************************************/

.dateLabel {
	margin: 0 0 10px;
	text-align: right;
	font: italic 1em "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.post p {
	padding-bottom: 15px;
}

.post ul {
	margin: 0 0 10px 10px;
}

.post ul li {
	margin-bottom: 5px;
	padding-left: 15px;
	background: url(images/bullet.png) no-repeat 0 8px;
}

.post ol {
	margin: 0 0 10px 30px;
}

.post ol li {
	list-style: decimal;
}

.post h1 {
	margin: 20px 0;
	padding: 5px 0;
	font-size: 150%;
	color: #000;
	border-bottom: 3px solid #f0f0f0;
}

.post h2 {
	margin: 10px 0;
	padding-bottom: 2px;
	font-size: 130%;
	font-weight: normal;
	color: #333;
	border-bottom: 2px solid #f0f0f0;
}

.post h3 {
	margin: 10px 0 30px;
	padding-bottom: 10px;
	font-size: 110%;
	font-weight: normal;
	color: #777;
	border-bottom: 2px solid #f0f0f0;
}

.post blockquote {
	clear: both;
	padding: 10px 0 10px 15px;
	margin: 10px 0 25px 30px;
	border-left: 5px solid #ccc;
}

.post blockquote p {
	padding: 5px 0;
}

.post table {
	border-collapse: collapse;
}

.post table th, .post table td {
	padding: 12px;
	border: 1px solid #ccc;
}

.post table th {
	text-align: right;
	font-weight: bold;
	letter-spacing: 1px;
	white-space: nowrap;
	background: #eee;
}

.post dt {
	font-weight: bold;
}

.post dd {
	padding-bottom: 10px;
}

.post img {
	max-width: 100%;
	height: auto;
}

img.aligncenter {
	display: block;
	margin: 5px auto;
}

img.alignright, img.alignleft {
	padding: 4px;
	margin: 0 0 2px 7px;
	display: inline;
}

img.alignleft {
	margin: 0 7px 2px 0;
}

.alignright {
	float: right;
}

.alignleft {
	float: left;
}

/* PC用
------------------------------------------------------------*/

@media only screen and (min-width:961px) {
	#wrapper, .inner {
		width: 940px;
		padding: 0;
	}
	#wrapper {
		padding-bottom: 20px;
	}
	/* グリッド全体 */
	.gridWrapper {
		display: table;
		border-collapse: separate;
		border-spacing: 20px;
		margin-left: -20px;
		width: 980px;
	}
	/* グリッド共通 ベース:トップページ4カラム */
	.grid {
		width: 220px;
		display: table-cell;
	}
	#sub.gridWrapper {
		width: 980px;
	}
	/* サブコンテンツ + フッター グリッド(3カラム) */
	#sub .grid, #footer .grid {
		width: 300px;
	}
	/* トップナビゲーション */
	nav div.panel {
		display: block !important;
	}
	a#menu {
		display: none;
	}
	#topnav {
		float: right;
		margin-top: -5px;
	}
	#topnav li {
		float: left;
		margin: 13px 5px 0;
		text-align: center;
		position: relative;
	}
	#topnav a {
		color: #555;
		font-size: 13px;
		display: block;
		padding: 25px 10px;
		line-height: 1.2;
	}
	#topnav span {
		font-size: 10px;
		color: #a5a5a5;
		display: block;
	}
	#topnav li.current-menu-item a, #topnav a:hover {
		background: #f5f5f5;
	}
	#topnav ul {
		width: 160px;
		display: none;
	}
	#topnav li:hover ul {
		display: block;
		position: absolute;
		top: 80px;
		left: 0;
		z-index: 500;
	}
	#topnav li li {
		margin: 0;
		float: none;
		width: 160px;
		text-align: left;
		background: #f4f4f4;
	}
	#topnav li li a {
		padding: 10px;
		border: 0;
	}
	#topnav li.current-menu-item li a, #topnav li li a {
		border-bottom-width: 1px;
	}
	#topnav li li.current-menu-item a, #topnav li li a:hover {
		padding-bottom: 10px;
		border-bottom-width: 3px;
		background: #eee;
	}
}

@media only screen and (max-width:960px) {
	* {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
	}
	#header h1 {
		text-align: center;
	}
	#header .logo, #footer .logo {
		float: none;
		text-align: center;
		padding: 10px 5px;
	}
	/* トップナビゲーション */
	nav#mainNav {
		clear: both;
		width: 100%;
		margin: 0 auto;
		padding: 0;
		background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #f4f4f4), color-stop(0.00, #f4f4f4));
		background: -webkit-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
		background: -moz-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
		background: -o-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
		background: -ms-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
		background: linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
	}
	nav#mainNav a.menu {
		width: 100%;
		display: block;
		height: 40px;
		line-height: 40px;
		font-weight: bold;
		text-align: left;
		color: #555;
	}
	nav#mainNav a#menu span {
		padding-left: 10px;
	}
	nav#mainNav a#menu span:before {
		/*		content: "≡ "; */
	}
	nav#mainNav a.menuOpen span:before {
		/*		content: "× "; */
	}
	nav#mainNav a#menu:hover {
		cursor: pointer;
	}
	nav .panel {
		display: none;
		width: 100%;
		position: relative;
		right: 0;
		top: 0;
		z-index: 1;
	}
	nav#mainNav ul {
		margin: 0;
		padding: 0;
	}
	nav#mainNav ul li {
		float: none;
		clear: both;
		width: 100%;
		height: auto;
		line-height: 1.2;
	}
	nav#mainNav ul li a {
		display: block;
		padding: 15px 10px;
		text-align: left;
		border-bottom: 1px dashed #e8e8e8;
		color: #555;
	}
	nav#mainNav ul li a span {
		padding-left: 10px;
		font-size: 80%;
		font-style: italic
	}
	nav#mainNav ul li a span:before {
		content: "=";
	}
	nav#mainNav ul li a span:after {
		content: "=";
	}
	nav#mainNav ul li:first-child a {
		border-top: 1px dashed #e8e8e8;
	}
	nav#mainNav ul li:last-child a {
		border: 0;
	}
	nav#mainNav ul li ul li:last-child a {
		border: 0;
	}
	nav#mainNav ul li ul li:last-child a {
		border-bottom: 1px dashed #e8e8e8;
	}
	nav#mainNav ul li.current-menu-item a, nav#mainNav ul li a:hover, nav#mainNav ul li.current-menu-item a, nav#mainNav ul li a:active, nav#mainNav ul li li.current-menu-item a, nav#mainNav ul li.current-menu-item li a:hover, nav#mainNav ul li.current-menu-item li a:active {
		background: #eee;
	}
	nav div.panel {
		float: none;
	}
	nav#mainNav ul li li {
		float: left;
		border: 0;
	}
	nav#mainNav ul li li a, nav#mainNav ul li.current-menu-item li a, nav#mainNav ul li li.current-menu-item a {
		padding-left: 40px;
		background: url(images/sub1.png) no-repeat 20px -62px;
	}
	nav#mainNav ul li li.current-menu-item a, nav#mainNav ul li li a:hover, nav#mainNav ul li.current-menu-item li a:hover {
		background: #eee url(images/sub1.png) no-repeat 20px -62px;
	}
	nav#mainNav ul li li:last-child a {
		background: #f4f4f4 url(images/subLast.png) no-repeat 20px -65px;
	}
	nav#mainNav ul li li:last-child.current-menu-item a, nav#mainNav ul li li:last-child a:hover, nav#mainNav ul li.current-menu-item li:last-child a:hover {
		background: #eee url(images/subLast.png) no-repeat 20px -65px;
	}
	.grid {
		float: left;
		width: 48%;
		margin: 10px 2% 0 0;
	}
	.grid img {
		float: left;
		margin-right: 5px;
	}
	#sub .grid {
		width: 32%;
		margin: 10px 1%;
	}
	#sub .grid:first-child {
		margin-left: 0;
	}
	#sub .grid:last-child {
		margin-right: 0;
	}
	#footer .grid, #footer .grid p {
		float: none;
		width: 100%;
		text-align: center;
		border: 0;
	}
	#footer .grid:last-child {
		padding-top: 20px;
	}
}

@media only screen and (max-width:960px) {
	#header {
		padding-bottom: 0;
	}
	#header h1 {
		text-align: center;
	}
	#header .logo {
		float: none;
		text-align: center;
		padding: 10px 5px 20px;
	}
	#sub ul.list {
		padding: 10px 10px 11px;
	}
	#sub ul.list li {
		padding-bottom: 10px;
		margin-bottom: 8px;
	}
}

@media only screen and (max-width:960px) {
	#footer .grid p {
		text-align: center;
	}
	.grid img {
		float: none;
		margin: 20px auto 10px;
		max-width: 100%;
		height: auto;
	}
	.grid p, #sub .grid li {
		text-align: left;
	}
	.alignleft, .alignright {
		float: none;
		display: block;
		margin: 0 auto 10px;
	}
}

@media only screen and (max-width:960px) {
	#mainBanner h2, #mainBanner h3 {
		font-size: 80%;
	}
	#sub .grid {
		float: none;
		width: 98%;
	}
	#sub .grid h3 {
		padding: 10px 5px;
	}
}

/* リンク設定
------------------------------------------------------------*/

a {
	color: #358de0;
	text-decoration: none;
}

a:hover {
	color: #429bef;
}

a:active, a:focus {
	outline: 0;
}

/* 全体
------------------------------------------------------------*/

#wrapper {
	margin: 20px auto 0;
	padding: 0 1%;
	width: 98%;
	position: relative;
}

.inner {
	margin: 0 auto;
	width: 100%;
}

/*************
/* ヘッダー
*************/

#header {
	z-index: 100;
	margin: 20px 0 28px;
}

#header:after {
	content: "";
	display: block;
	clear: both;
	visibility: hidden;
}

#header h1 {
	font-size: 12px;
	font-weight: normal;
}

/*************
/* ロゴ
*************/

#header .logo {
	float: left;
	padding: 10px 0 0;
}

.logo a {
	font-size: 20px;
	color: #444;
	font-weight: bold;
	line-height: 1;
}

.logo {
	width: 300px
	height: 75px;
	max-width: 300px;
}

.logo a img {
	width: 20vw;
	height: 75px;
	/* object-fit: cover; */
}

.logo span {
	font-size: 12px;
	font-weight: normal;
}

#header h1 {
	font-size: 11px;
	color: #444;
	margin: 10px 0 0;
}

/**************************
/* メイン画像（トップページ）
**************************/

#mainBanner {
	margin: 0 auto;
	padding: 0;
	width: 100%;
	line-height: 0;
}

#mainBanner .inner {
	position: relative;
}

#mainBanner img {
	max-width: 100%;
	height: auto;
}

.slogan {
	position: absolute;
	max-width: 100%;
	height: auto;
	bottom: 0;
	left: 0;
	padding: 5px 10px;
	line-height: 1.4;
	z-index: 100;
}

.slogan h2 {
	padding-bottom: 5px;
	color: #333;
	font-size: 20px;
}

.slogan h3 {
	font-size: 14px;
	color: #666;
}

/* フッター内のグリッド(3カラム) */

#footer .grid {
	border: 0;
	background: transparent;
}

#footer .grid p {
	padding: 0;
}

/*************
/* フッター
*************/

#footer {
	clear: both;
	padding: 20px 0;
	overflow: hidden;
}

.tel strong {
	font-size: 20px;
	font-weight: bold;
}

#footer .copyright {
	font-size: 11px;
}

/*************
サブ（フッター前）コンテンツ
*************/

#sub ul {
	padding: 10px;
}

#sub li {
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 1px dashed #ebebeb;
}

#sub li:last-child {
	border: 0;
	margin-bottom: 0;
}

#sub li a {
	color: #555;
	display: block;
}

#sub li a:hover {
	color: #a5a5a5;
}

#sub ul.list {
	padding-bottom: 7px;
}

#sub ul.list li {
	clear: both;
	margin-bottom: 5px;
	padding: 5px 0;
	overflow: hidden;
}

#sub ul.list li img {
	float: left;
	margin-right: 10px;
}

#sub ul.list li {
	font-size: 12px;
	line-height: 1.35;
}

#sub .grid h3 {
	border-radius: 0;
}

/* page navigation
------------------------------------------------------------*/

.pagenav {
	clear: both;
	width: 100%;
	height: 30px;
	max-width: 900px;
	margin: 5px auto 20px;
	padding: 0 10px;
}

.pagenav a {
	color: #555;
}

.pagenav a:hover {
	color: #a5a5a5;
}

.prev {
	float: left
}

.next {
	float: right;
}

#pageLinks {
	clear: both;
	text-align: center;
}

/* PC用
------------------------------------------------------------*/

@media only screen and (min-width:961px) {
	#wrapper, .inner {
		width: 940px;
		padding: 0;
	}
	#wrapper {
		padding-bottom: 20px;
	}
	
	/* グリッド全体 */
	.gridWrapper {
		display: table;
		border-collapse: separate;
		border-spacing: 20px;
		margin-left: -20px;
		width: 980px;
	}
	/* グリッド共通 ベース:トップページ4カラム */
	.grid {
		width: 220px;
		display: table-cell;
	}
	#sub.gridWrapper {
		width: 980px;
	}
	/* サブコンテンツ + フッター グリッド(3カラム) */
	#sub .grid, #footer .grid {
		width: 300px;
	}
	/* トップナビゲーション */
	nav div.panel {
		display: block !important;
	}
	a#menu {
		display: none;
	}
	#topnav {
		float: right;
		margin-top: -5px;
	}
	#topnav li {
		float: left;
		margin: 13px 5px 0;
		text-align: center;
		position: relative;
	}
	#topnav a {
		color: #555;
		font-size: 13px;
		display: block;
		padding: 25px 10px;
		line-height: 1.2;
	}
	#topnav span {
		font-size: 10px;
		color: #a5a5a5;
	}
	#topnav li.current-menu-item a, #topnav a:hover {
		background: #f5f5f5;
	}
	#topnav ul {
		width: 160px;
		display: none;
	}
	#topnav li:hover ul {
		display: block;
		position: absolute;
		top: 80px;
		left: 0;
		z-index: 500;
	}
	#topnav li li {
		margin: 0;
		float: none;
		width: 160px;
		text-align: left;
		background: #f4f4f4;
	}
	#topnav li li a {
		padding: 10px;
		border: 0;
	}
	#topnav li.current-menu-item li a, #topnav li li a {
		border-bottom-width: 1px;
	}
	#topnav li li.current-menu-item a, #topnav li li a:hover {
		padding-bottom: 10px;
		border-bottom-width: 3px;
		background: #eee;
	}
}

@media only screen and (max-width:960px) {
	* {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
	}
	#header h1 {
		text-align: center;
	}
	#header .logo, #footer .logo {
		float: none;
		text-align: center;
		padding: 10px 5px;
	}
	.logo a img {
		width: 75px;
		height: 75px;
		/* object-fit: cover; */
	}
	#sub .grid {
		width: 32%;
		margin: 10px 1%;
	}
	#sub .grid:first-child {
		margin-left: 0;
	}
	#sub .grid:last-child {
		margin-right: 0;
	}
	#footer .grid, #footer .grid p {
		float: none;
		width: 100%;
		text-align: center;
		border: 0;
	}
	#footer .grid:last-child {
		padding-top: 20px;
	}
}

@media only screen and (max-width:960px) {
	#header {
		padding-bottom: 0;
	}
	#header h1 {
		text-align: center;
	}
	#header .logo {
		float: none;
		text-align: center;
		padding: 10px 5px 20px;
	}
	#sub ul.list {
		padding: 10px 10px 11px;
	}
	#sub ul.list li {
		padding-bottom: 10px;
		margin-bottom: 8px;
	}
}

@media only screen and (max-width:960px) {
	#footer .grid p {
		text-align: center;
	}
	.grid img {
		float: none;
		margin: 20px auto 10px;
		max-width: 100%;
		height: auto;
	}
	.grid p, #sub .grid li {
		text-align: left;
	}
	.alignleft, .alignright {
		float: none;
		display: block;
		margin: 0 auto 10px;
	}
}

@media only screen and (max-width:960px) {
	#mainBanner h2, #mainBanner h3 {
		font-size: 80%;
	}
	#sub .grid {
		float: none;
		width: 98%;
	}
	#sub .grid h3 {
		padding: 10px 5px;
	}
}





/*----------------------------------
共通設定（全体）
------------------------------------*/

#chglanguage {
    position: absolute;
    right: 50px;
    top: 50px;
    font-size: 85%;
    z-index: 10000;
}

#chglanguage a {
    border: 1px #f0f0f0 solid;
    padding: 3px 10px;
    color: #ffffff;
}

#chglanguage a.eng {
    background-color: #ad5f77
}

#chglanguage a.eng:hover {
    background-color: #573841
}

#chglanguage a.jpn {
    background-color: #5f7bad
}

#chglanguage a.jpn:hover {
    background-color: #475d83
}

@media only screen and (max-width: 960px) {
    #chglanguage {
        left: 70px;
        top: 20px;
        width: 50%;
    }
}

.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-rigth {
    text-align: right;
}

table.tbl-half {
    width: 70%;
}

/* スライドショーの幅などもこちらでどうぞ */

.slider {
    margin: 50px auto;
    /*    width: 90%; */
    width: 100%;
}

.slider img {
    height: auto;
    width: 100%;
}

/*slick setting*/

.slick-prev:before, .slick-next:before {
    color: #000;
}

.slick-prev {
    left: 15px;
    z-index: 99;
}

.slick-next {
    right: 15px;
    z-index: 99;
}

@media only screen and (min-width: 961px) {
    .sp-only {
        display: none;
    }
}

@media only screen and (max-width: 960px) {
    .slider {
        margin: 50px auto;
        /*        width: 90%; */
        width: 100%;
    }
    .sp-none {
        display: none;
    }
    .sp-only {
        display: block;
    }
    #header {
        padding-top: 0;
        padding-bottom: 0;
        margin-top: 0;
    }
    #navBox {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 9999;
    }
    nav#mainNav {
        background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #f4f4f4), color-stop(0.00, #f4f4f4));
        background: -webkit-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
        background: -moz-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
        background: -o-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
        background: -ms-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
        background: linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
    }
    nav#mainNav .parent {
        padding: 5px;
        position: relative;
    }
    nav#mainNav .parent {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    nav#mainNav .parent .child1 {
        margin-left: 10px
    }
    nav#mainNav .parent .child2 {
        margin-right: 10px;
    }
    nav#mainNav a.menu {
        display: inline;
        width: inherit;
        line-height: inherit;
        height: 28px;
    }
    nav#mainNav img.icon_logo {
        width: 48px;
    }
    #wrapper {
        padding-top: 50px;
        margin-top: 0;
    }
    table.tbl-half {
        width: 100%;
    }
    table.tbl-half tr th, table.tbl-half tr td {
        display: block;
        width: 100%;
    }
    table.tbl-half tr th {
        text-align: left;
    }
    nav#mainNav a.menu {}
    nav#mainNav a.menuOpen span:before {
        content: "× " !important;
    }
}

/* ここから */

:root {
    --hamburger-menu-size: 100px;
    /* メニューの大きさ */
    --hamburger-menu-padding: 12px;
    --hamburger-menu-border-px: 6px;
    /* 線の太さ */
    --hamburger-menu-border-color: #342534;
    /* 線の色 */
    --hamburger-menu-transition: 0.3s;
    /* アニメーション秒数 */
}

.hamburger-menu {
    margin: 0 auto;
    /* 中央寄せしたいだけ */
    cursor: pointer;
    position: relative;
    width: 100px;
    height: 100px;
    background-color: #fff;
}

.hamburger-menu-line {
    position: absolute;
    transition: var(--hamburger-menu-transition);
    width: calc(100% - var(--hamburger-menu-padding) * 2);
    height: var(--hamburger-menu-border-px);
    background-color: var(--hamburger-menu-border-color);
}

.line-top {
    top: var(--hamburger-menu-padding);
    left: var(--hamburger-menu-padding);
}

.line-middle {
    top: calc(50% - var(--hamburger-menu-border-px)/2);
    left: var(--hamburger-menu-padding);
}

.line-bottom {
    bottom: var(--hamburger-menu-padding);
    left: var(--hamburger-menu-padding);
}

.hamburger-menu-active>.line-top {
    top: calc(50% - var(--hamburger-menu-border-px)/2);
    transform: rotate(45deg);
}

.hamburger-menu-active>.line-middle {
    width: 0;
    height: 0;
    left: var(--hamburger-menu-padding);
}

.hamburger-menu-active>.line-bottom {
    top: calc(50% - var(--hamburger-menu-border-px)/2);
    transform: rotate(-45deg);
}

/* ここまで */

/*=============================
.btn-trigger
=============================*/

.btn-trigger {
    position: relative;
    width: 30px;
    height: 28px;
    cursor: pointer;
}

.btn-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: #000;
    border-radius: 4px;
}

.btn-trigger, .btn-trigger span {
    display: inline-block;
    transition: all .5s;
    box-sizing: border-box;
}

.btn-trigger span:nth-of-type(1) {
    top: 0;
}

.btn-trigger span:nth-of-type(2) {
    top: 12px;
}

.btn-trigger span:nth-of-type(3) {
    bottom: 0;
}

/*=============================
#btn08
=============================*/

#btn08.active span:nth-of-type(1) {
    -webkit-transform: translateY(12px) rotate(-315deg);
    transform: translateY(12px) rotate(-315deg);
}

#btn08.active span:nth-of-type(2) {
    opacity: 0;
}

#btn08.active span:nth-of-type(3) {
    -webkit-transform: translateY(-12px) rotate(315deg);
    transform: translateY(-12px) rotate(315deg);
}

.panel.active {
    display: block !important;
}

/********************************
フッター
*********************************/

#footer {
    font-size: 85%;
    text-align: center;
}












a.allow::after {
    content: "\0bb";
}

#chglanguage {
    position: absolute;
    right: 50px;
    top: 50px;
    font-size: 85%;
    z-index: 10000;
}

#chglanguage a {
    border: 1px #f0f0f0 solid;
    padding: 3px 10px;
    color: #ffffff;
}

#chglanguage a.eng {
    background-color: #ad5f77
}

#chglanguage a.eng:hover {
    background-color: #573841
}

#chglanguage a.jpn {
    background-color: #5f7bad
}

#chglanguage a.jpn:hover {
    background-color: #475d83
}

.mt-0 {
    margin-top: 0
}

.mt-1 {
    margin-top: .25rem
}

.mt-2 {
    margin-top: .5rem
}

.mt-3 {
    margin-top: .75rem
}

.mt-4 {
    margin-top: 1.0rem
}

.mt-5 {
    margin-top: 1.5rem
}

.mb-0 {
    margin-bottom: 0
}

.mb-1 {
    margin-bottom: .25rem
}

.mb-2 {
    margin-bottom: .5rem
}

.mb-3 {
    margin-bottom: .75rem
}

.mb-4 {
    margin-bottom: 1.0rem
}

.mb-5 {
    margin-bottom: 1.5rem
}

.ml-0 {
    margin-left: 0
}

.ml-1 {
    margin-left: .25rem
}

.ml-2 {
    margin-left: .5rem
}

.ml-3 {
    margin-left: .75rem
}

.ml-4 {
    margin-left: 1.0rem
}

.ml-5 {
    margin-left: 1.5rem
}

.mr-0 {
    margin-right: 0
}

.mr-1 {
    margin-right: .25rem
}

.mr-2 {
    margin-right: .5rem
}

.mr-3 {
    margin-right: .75rem
}

.mr-4 {
    margin-right: 1.0rem
}

.mr-5 {
    margin-right: 1.5rem
}

@media only screen and (max-width: 960px) {
    #chglanguage {
        left: 70px;
        top: 20px;
        width: 50%;
    }
}

.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-rigth {
    text-align: right;
}

table.tbl-half {
    width: 70%;
}

/* スライドショーの幅などもこちらでどうぞ */

.slider {
    margin: 50px auto;
    /*    width: 90%; */
    width: 100%;
}

.slider img {
    height: auto;
    width: 100%;
}

/*slick setting*/

.slick-prev:before, .slick-next:before {
    color: #000;
}

.slick-prev {
    left: 15px;
    z-index: 99;
}

.slick-next {
    right: 15px;
    z-index: 99;
}

@media only screen and (min-width: 961px) {
    .sp-only {
        display: none;
    }
}

@media only screen and (max-width: 960px) {
    .slider {
        margin: 50px auto;
        /*        width: 90%; */
        width: 100%;
    }
    .sp-none {
        display: none;
    }
    .sp-only {
        display: block;
    }
    #header {
        padding-top: 0;
        padding-bottom: 0;
        margin-top: 0;
    }
    #navBox {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 9999;
    }
    nav#mainNav {
        background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #f4f4f4), color-stop(0.00, #f4f4f4));
        background: -webkit-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
        background: -moz-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
        background: -o-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
        background: -ms-linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
        background: linear-gradient(top, #f4f4f4 0%, #f4f4f4 100%);
    }
    nav#mainNav .parent {
        padding: 5px;
        position: relative;
    }
    nav#mainNav .parent {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    nav#mainNav .parent .child1 {
        margin-left: 10px
    }
    nav#mainNav .parent .child2 {
        margin-right: 10px;
    }
    nav#mainNav a.menu {
        display: inline;
        width: inherit;
        line-height: inherit;
        height: 28px;
    }
    nav#mainNav img.icon_logo {
        width: 48px;
    }
    #wrapper {
        padding-top: 50px;
        margin-top: 0;
    }
    table.tbl-half {
        width: 100%;
    }
    table.tbl-half tr th, table.tbl-half tr td {
        display: block;
        width: 100%;
    }
    table.tbl-half tr th {
        text-align: left;
    }
    nav#mainNav a.menu {}
    nav#mainNav a.menuOpen span:before {
        content: "× " !important;
    }
}

/* ハンバーガーここから */

:root {
    --hamburger-menu-size: 100px;
    /* メニューの大きさ */
    --hamburger-menu-padding: 12px;
    --hamburger-menu-border-px: 6px;
    /* 線の太さ */
    --hamburger-menu-border-color: #342534;
    /* 線の色 */
    --hamburger-menu-transition: 0.3s;
    /* アニメーション秒数 */
}

.hamburger-menu {
    margin: 0 auto;
    /* 中央寄せしたいだけ */
    cursor: pointer;
    position: relative;
    width: 100px;
    height: 100px;
    background-color: #fff;
}

.hamburger-menu-line {
    position: absolute;
    transition: var(--hamburger-menu-transition);
    width: calc(100% - var(--hamburger-menu-padding) * 2);
    height: var(--hamburger-menu-border-px);
    background-color: var(--hamburger-menu-border-color);
}

.line-top {
    top: var(--hamburger-menu-padding);
    left: var(--hamburger-menu-padding);
}

.line-middle {
    top: calc(50% - var(--hamburger-menu-border-px)/2);
    left: var(--hamburger-menu-padding);
}

.line-bottom {
    bottom: var(--hamburger-menu-padding);
    left: var(--hamburger-menu-padding);
}

.hamburger-menu-active>.line-top {
    top: calc(50% - var(--hamburger-menu-border-px)/2);
    transform: rotate(45deg);
}

.hamburger-menu-active>.line-middle {
    width: 0;
    height: 0;
    left: var(--hamburger-menu-padding);
}

.hamburger-menu-active>.line-bottom {
    top: calc(50% - var(--hamburger-menu-border-px)/2);
    transform: rotate(-45deg);
}

/* ハンバーガーここまで */

/*=============================
.btn-trigger
=============================*/

.btn-trigger {
    position: relative;
    width: 30px;
    height: 28px;
    cursor: pointer;
}

.btn-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: #000;
    border-radius: 4px;
}

.btn-trigger, .btn-trigger span {
    display: inline-block;
    transition: all .5s;
    box-sizing: border-box;
}

.btn-trigger span:nth-of-type(1) {
    top: 0;
}

.btn-trigger span:nth-of-type(2) {
    top: 12px;
}

.btn-trigger span:nth-of-type(3) {
    bottom: 0;
}

/*=============================
#btn08
=============================*/

#btn08.active span:nth-of-type(1) {
    -webkit-transform: translateY(12px) rotate(-315deg);
    transform: translateY(12px) rotate(-315deg);
}

#btn08.active span:nth-of-type(2) {
    opacity: 0;
}

#btn08.active span:nth-of-type(3) {
    -webkit-transform: translateY(-12px) rotate(315deg);
    transform: translateY(-12px) rotate(315deg);
}

.panel.active {
    display: block !important;
}

/********************************
グリッド
*********************************/

.gridbox {
    display: flex;
    align-items: start;
    flex-wrap: wrap;
}

.griditem img {
    max-width: 100%;
    height: auto;
    margin: 10px 0 5px;
}

.griditem.griditemhead {
    width: 100%;
    padding: 0 10px;
}

.griditem.gridcenter {
    align-self: center;
}

.griditem.griditem2 {
    width: calc(50% - 20px);
    margin: 0 10px;
}
.freegrid {
    display: flex;
    align-items: start;
}

.freegrid .griditem{
    padding: 5px;
    width:100%;
}
.caption{
    margin-bottom: 1rem;
} 

@media only screen and (max-width: 960px) {
    .griditem {
        width: 90%;
        margin: 0 10%;
    }
    .freegrid .griditem{
        margin: 0;
    }
    .freegrid .griditem span{
        display: block;
    }
}

/********************************
フッター
*********************************/

#footer {
    margin-top: 50px;
    font-size: 90%;
    text-align: center;
    line-height: 250%;
}

#footer .copyright {
    margin-top: 30px;
    padding-top: 30px;
    margin-bottom: 50px;
    border-top: 2px #c0c0c0 solid;
    font-size: 100%;
}


/********************************
product
*********************************/
@media only screen and (max-width: 960px){
    .flex-item-img33 {
        width: calc(33.3333% - 20px);
        margin: 0 10px;
    }
}


