@import url("./twentynineteen.css");
@import url("./html_lib/common.css");
@import url("./common_contents.css");
/*
Theme Name: マスカットプロジェクト
Version: 1.0
Description:This CSS for Beny Pong!, Twenty Fifteen customize. add CMB2.
Author:Seiki Nishijima

This theme has been based on the production of GPL of Twenty Fifteen.
Please diversion in self-responsibility in the copyleft.

	$Id: style.css,v1.0 $
*/
/*===========================================================================

  共通設定　ここから

===========================================================================*/
html{
	-webkit-text-size-adjust: none;/*
	background: #f56b45;*/
}
body {
	padding: 0 0 0 0;
	margin:0px auto 0px auto;/*
	text-align:center;*/
	color: #1a1a1a;
	background: #fff;
	min-width: 1200px;
}
.background {
	padding: 0 0 0 0;
	margin:0px auto 0px auto;
	text-align:center;
	width: 100%;
	min-width: 1200px;
	position: relative;
	background: #fff;
	font-size: 16px;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	body ,
	.background {
		min-width: 320px;
	}
}
/*-------------------------------------------------------------------------*/
.background a {
	color: #1a1a1a;
	text-decoration: none;
	filter: Alpha(opacity=100);
	opacity: 1;
	box-sizing: border-box;
}
.background a:hover {
	filter: Alpha(opacity=50);
	opacity: 0.5;
}
.background a[href^="tel:"] {
	pointer-events: none;
}
.background button {
	cursor: pointer;
	filter: Alpha(opacity=100);
	opacity: 1;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
	box-sizing: border-box;
}
.background button:hover {
	filter: Alpha(opacity=50);
	opacity: 0.5;
}
.background img {
	vertical-align: middle;
	box-sizing: border-box;
	width: 100%;
	height: auto;
}
.background .pcArea ,
.background .pcImage {
	display: block;
}
.background .spArea ,
.background .spImage {
	display: none;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	a:hover {
		filter: Alpha(opacity=100);
		opacity: 1;
	}
	.background a[href^="tel:"] {
		pointer-events: auto;
	}
	.background .pcArea ,
	.background .pcImage {
		display: none;
	}
	.background .spArea ,
	.background .spImage {
		display: block;
	}
	.background span.spNone {
		display: none;
	}
}
/*--------------------------------------------------------------------------
  共通レイアウト設定　ここから
---------------------------------------------------------------------------*/
.background header ,
.background footer ,
.background article {
	margin:0px auto 0px auto;
	text-align:center;
	width: 100%;
	min-width: 1200px;
}
.background section {
	margin:0px auto 0px auto;
	text-align:center;
	width: 1120px;
}
.background .naviMask {
	display: none;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background header ,
	.background footer ,
	.background article {
		min-width: initial;
		min-width: auto;
	}
	.background section {
		width: 100%;}
}
/*--------------------------------------------------------------------------
  共通テキスト設定　ここから
---------------------------------------------------------------------------*/
.background article h1 ,
.background article h2 ,
.background article h3 ,
.background article h4 ,
.background article h5 ,
.background article h6 ,
.background article p ,
.background article ul ,
.background article ol {
	margin: 0 auto 50px auto;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background article h1 ,
	.background article h2 ,
	.background article h3 ,
	.background article h4 ,
	.background article h5 ,
	.background article h6 ,
	.background article p ,
	.background article ul ,
	.background article ol {
		margin: 0 0 15px 0;
	}
}

/*===========================================================================

  共通ヘッダ設定　ここから

===========================================================================*/
.background header {
	background: #fff;
}
.background header section {
	padding: 0;
	width: 100%;
	min-width: 1200px;
	border-bottom: 4px solid #4fb648;
}
.background header h1 {
	width: 210px;
	padding: 15px;
	float: left;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background header section {
		width: 100%;
		min-width: 320px;
	}
	.background header h1 {
		width: 180px;
		padding: 10px;
	}
}
/*===========================================================================
-----------------------------------------------------------------------------
  PCメニューセット設定　ここから
-----------------------------------------------------------------------------
===========================================================================*/
.background header nav {
	float: right;
	text-align: right;
}
.background header nav p.menu {
	display: none;
}
/*--------------------------------------------------------------------------
  メインメニュー設定　ここから
---------------------------------------------------------------------------*/
.background header nav .mainMenu {
	margin: 0 0 0 auto;
}
.background header nav .mainMenu li {
	float: left;
	margin: 0;
}
.background header nav .mainMenu li a {
	display: block;
	font-size: 16px;
	font-weight: bold;
	line-height: 20px;
	padding: 35px 20px;
}
.background header nav .mainMenu li.active a {
	color: #4fb648;
}
.background header nav .mainMenu li.active a:before {
	content: "";
	display: block;
	position: absolute;
	width: calc(100% - 40px);
	height: 4px;
	background: #ffe100;
	left: 20px;
	bottom: -4px;
}
.background header nav .mainMenu li:last-of-type a {
	background: #4fb648;
	color: #fff;
}
.background header nav .mainMenu li:last-of-type.active a {
	background: #fff;
	color: #4fb648;
}/*
.background header nav .mainMenu li:last-of-type.active a:before {
	width: 100%;
	left: 0;
}*/

/*===========================================================================

  SPメニューセット設定　ここから

===========================================================================*/
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background header nav {
		padding: 15px;
		float: right;
	}
	/*--------------------------------------------------------------------------
	  メニューボタン設定　ここから
	---------------------------------------------------------------------------*/
	.background header nav p.menu {
		display: block;
		width: 48px;
		padding: 10px;
		border-radius: 4px;
	}
	.background header p.menu a {
		display: block;
		width: 100%;
		height: 24px;
		padding: 0 0 0 0;
		position: relative;
		background: transparent;
		overflow: hidden;
		text-indent: -10em;
	}
	.background header p.menu a span:before ,
	.background header p.menu a:after ,
	.background header p.menu a:before {
		display: block; content: " ";
		width: 28px; height: 2px;
		background: #4fb648;
		position: absolute;
		top: 11px; left: 0;
		transform: rotate(0deg);
		-webkit-transition: all 0.5s ease;
		-moz-transition: all 0.5s ease;
		-o-transition: all 0.5s ease;
		transition: all 0.5s ease;
	}
	.background header p.menu a:after {
		left: auto; right: 0;
		top: auto; bottom: 22px;}
	.background header p.menu a:before {
		top: auto; bottom: 0;}

	.background header p.menu.open a span:before {
		filter: Alpha(opacity=0);
		opacity: 0;}
	.background header p.menu.open a:after ,
	.background header p.menu.open a:before {
		top: auto; bottom: 50%;;
	}
	.background header p.menu.open a:after {
		transform: rotate(-45deg);}
	.background header p.menu.open a:before {
		transform: rotate(45deg);}
	/*--------------------------------------------------------------------------
	  メニューエリア設定　ここから
	---------------------------------------------------------------------------*/
	.background header nav ul {
		position: fixed;
		overflow: scroll;
		top: 0;
		right: calc(90px - 100vw);
		width: calc(100vw - 90px);
		height: 100vh;
		padding-top: 0;
		z-index: 150;
		padding: 10px 10px;
		background: #fff;
	}
	/*--------------------------------------------------------------------------
	  メニュー挙動設定　ここから
	---------------------------------------------------------------------------*/
	body {
		position: relative;
		left: 0;
		-webkit-transition: all 0.5s ease;
		-moz-transition: all 0.5s ease;
		-o-transition: all 0.5s ease;
		transition: all 0.5s ease;
	}
	body #wpadminbar {
		top: -46px;
	}
	.background {
		position: static;
	}
	body.openNavi {
		left: calc(90px - 100vw);
	}
	body .naviMask {
		display: none;
		content: "";
		position: absolute;
		height: 100%;
		width: 100%;
		z-index: 150;
		background: rgba(0,0,0,0);
		top: 0;
		left: 0;
		-webkit-transition: all 0.5s ease;
		-moz-transition: all 0.5s ease;
		-o-transition: all 0.5s ease;
		transition: all 0.5s ease;
	}
	body.openNavi .naviMask {
		display: block;
		background: rgba(0,0,0,0.4);
	}
	body.openNavi header nav ul {
		right: 0;
	}
	/*--------------------------------------------------------------------------
	  メインメニュー設定　ここから
	---------------------------------------------------------------------------*/
	.background header ul.mainMenu {
		display: block;
		margin: 0;
		padding: 0;
	}
	.background header nav .mainMenu li {
		float: none;
		margin: 0;
		border-bottom: 1px solid #bbb;
	}
	.background header nav .mainMenu li a {
		padding: 15px 20px;
	}
	.background header nav .mainMenu li.active a:before {
		width: 4px;
		height: 100%;
		left: 0;
		bottom: 0;
	}
	.background header nav .mainMenu li:last-of-type.active a:before {
		width: 4px;
		left: 0;
	}
}
/*===========================================================================

  フッターサイトマップ 設定　ここから

===========================================================================*/
.background #footerSitemap {
	padding: 80px 0 65px;
	background: #e8f0e4;
}
.background #footerSitemap h2 {
	position: absolute;
	display: block;
	width: 300px;
	margin: 0;
	left: calc(50% - 150px);
	top: -53px;
	z-index: 10;
}
.background #footerSitemap ul {
	width: 208px;
	margin: 0 20px 0 0;
	float: left;
}
.background #footerSitemap ul:last-of-type {
	margin-right: 0;
}
.background #footerSitemap ul a {
	display: block;
	position: relative;
	padding: 10px 5px;
	line-height: 1em;
	letter-spacing: 0;
	border: 1px solid #1a1a1a;
	margin-bottom: 15px;
	text-align: center;
}
.background #footerSitemap ul ul a {
	padding: 0 0 0 30px;
	border: none;
	text-align: left;
	font-size: 14px;
	line-height: 1.2em;
}
.background #footerSitemap ul ul a:before {
	display: block;
	content: " ";
	width: 20px;
	height: 20px;
	position: absolute;
	top: calc(50% - 10px);
	left: 5px;
	background: url(./images/icon02.svg) no-repeat 50% 50%;
	background-size: 20px 20px;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background #footerSitemap {
		display: none;
	}
}
/*===========================================================================
-----------------------------------------------------------------------------
  共通フッター設定　ここから
-----------------------------------------------------------------------------
===========================================================================*/
.background footer{
}

.background footer section {
	padding: 15px;
}
.background footer section.addressArea {
	padding: 80px 0 0 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.background footer .addressArea h2 {
	width: 330px;
	margin: 0 20px 40px 0;
}
.background footer .addressArea p {
	margin-bottom: 20px;
}
.background footer .addressArea p strong {
	display: block;
	font-size: 20px;
	letter-spacing: 0;
	margin-bottom: 10px;
}
.background footer .addressArea p a {
	margin-right: 20px;
}
.background footer .addressArea p.sns {
	width: 40px;
	margin: 0 auto 10px 0;
	padding-top: 25px;
}
.background footer .addressArea ul {
	width: 560px;
	margin: 0 0 0 auto;
}
.background footer .addressArea ul li {
	width: 270px;
	margin: 0 0 10px 10px;
	float: left;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background footer section ,
	.background footer section.addressArea {
		padding: 30px 15px 0;
		display: block;
	}
	.background footer .addressArea{
		border-top: 4px solid #4fb648;
	}
	.background footer .addressArea h2 {
		width: 200px;
		margin: 0 20px 30px 0;
		float: left;
	}
	.background footer .addressArea p {
		margin-bottom: 20px;
		font-size: 14px;
		text-align: center;
	}
	.background footer .addressArea p strong {
		font-size: 16px;
	}
	.background footer .addressArea p a {
		margin-right: 20px;
	}
	.background footer .addressArea p.sns {
		float: left;
		margin: 0 auto 10px 0;
		padding-top: 20px;
		width: 40px;
	}
	.background footer .addressArea ul {
		width: 100%;
		margin-bottom: 20px;
		clear: both;
	}
	.background footer .addressArea ul li {
		width: calc(50% - 5px);
		margin: 0 10px 10px 0;
	}
	.background footer .addressArea ul li:nth-of-type(2n) {
		margin: 0 0 10px 0;
	}
}


.background footer address {
	width: 100%;
	text-align: center;
	line-height: 1em;
	font-style: normal;
	color: #26991f;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background footer section.spArea {
		padding: 20px 15px 0;
		border-top: 1px solid #bbb;
	}
	.background footer section.spArea ul {
		display: flex;
		justify-content: center;
	}
	.background footer section.spArea li {
		display: block;
		margin: 0 10px;
		font-size: 14px;
		font-weight: bold;
	}
	.background footer address {
		margin-bottom: 15px;
		font-size: 14px;
	}
}
/*--------------------------------------------------------------------------
  共通トップへ設定　ここから
---------------------------------------------------------------------------*/
.background .go2top {
	display: none;
	position: fixed;
	width: 80px;
	min-width: initial;
	min-width: auto;
	height: 80px;
	right: 20px;
	bottom: 20px;
	z-index: 900;
	margin: 0 0 0 0;
}
.background .go2top section ,
.background .go2top section p {
	width: 80px;
	height: 80px;
	margin: 0 0 0 0;
	background: transparent;
}
.background .go2top section a {
	display: block;
	width: 80px;
	height: 80px;
	background: #4fb648;
	border-radius: 50%;
	color: #fff;
	line-height: 80px;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	position: relative;
	filter: Alpha(opacity=90);
	opacity: 0.9;
}
.background .go2top section a:hover {
	filter: Alpha(opacity=45);
	opacity: 0.45;
}
.background .go2top section a:before {
	display: block;
	content: " ";
	width: 20px;
	height: 20px;
	position: absolute;
	top: 10px;
	left: calc(50% - 10px);
	background: url(./images/icon01w.svg) no-repeat 50% 50%;
	background-size: cover;
	transform: rotate(-90deg);
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background .go2top {/*
		position: static;
		width: 100%;
		height: auto;
		display: block;*/
		display: none;
	}
	.background .go2top section ,
	.background .go2top section p {
		width: 100%;
		height: auto;
	}
	.background .go2top section a {
		width: 100%;
		height: auto;
		border-radius: 0;
		line-height: 1em;
		font-size: 16px;
		padding: 20px 50px 20px;
		filter: Alpha(opacity=100);
		opacity: 1;
	}
	.background .go2top section a:before {
		width: 20px;
		height: 20px;
		top: calc(50% - 10px);
		left: auto;
		right: 15px;
	}
}
/*===========================================================================
-----------------------------------------------------------------------------
  パンくず 設定　ここから
-----------------------------------------------------------------------------
===========================================================================*/
.background #breadcrumb {
	border-bottom: 1px solid #ccc;
}
.background #breadcrumb section {
	padding: 5px 0 10px;
}
.background #breadcrumb ul {
	margin: 0 0 0;
}
.background #breadcrumb ul li {
	margin: 5px 0 0;
	float: left;
	color: #4d4d4d;
}
.background #breadcrumb ul li a {
	color: #4d4d4d;
}
.background #breadcrumb ul li:before {
	content: ">";
	padding: 0 10px;
	display: inline;
}
.background #breadcrumb ul li:first-of-type:before {
	display: none;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background #breadcrumb {
		display: none;
	}
}

/*===========================================================================

  ページネーション 設定　ここから

===========================================================================*/
.background .navigation.pagination h2 {
	display: none;
}
.background .navigation.pagination .nav-links {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 1120px;
	margin: 0 auto;
}
.background .navigation.pagination .nav-links a ,
.background .navigation.pagination .nav-links span {
	display: block;
	font-size: 18px;
	line-height: 1em;
	padding: 15px 20px;
	margin: 0 5px 0 5px;
	border: 2px solid #1a1a1a;
	color: #1a1a1a;
	position: relative;
}
.background .navigation.pagination .nav-links span {
	border-color: #4fb648;
	background: #4fb648;
	color: #fff;
}
.background .navigation.pagination .nav-links a.prev ,
.background .navigation.pagination .nav-links a.next {
	min-width: 50px;
	overflow: hidden;
	text-indent: -10em;
	border-color: transparent;
}
.background .navigation.pagination .nav-links a.prev:before ,
.background .navigation.pagination .nav-links a.next:before {
	content: "";
	display: block;
	height: 30px;
	width: 30px;
	position: absolute;
	background: url(./images/icon03.svg) no-repeat 50% 50%;
	background-size: cover;
	top: calc(50% - 15px);
	right: calc(50% - 15px);
}
.background .navigation.pagination .nav-links a.prev:before {
	right: auto;
	left: calc(50% - 15px);
	transform: rotate(180deg);
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background .navigation.pagination .nav-links {
		width: 100%;
	}
	.background .navigation.pagination .nav-links a ,
	.background .navigation.pagination .nav-links span {
		font-size: 16px;
		padding: 10px 10px;
		margin: 0 3px 0;
	}
	.background .navigation.pagination .nav-links span.dots {
		font-size: 14px;
		padding: 10px 0;
		margin: 0 0 0;
		color: #1a1a1a;
		border-color: transparent;
		background-color: transparent;
	}
	.background .navigation.pagination .nav-links a.prev:before ,
	.background .navigation.pagination .nav-links a.next:before {
		height: 20px;
		width: 20px;
		top: calc(50% - 10px);
		right: calc(50% - 10px);
	}
	.background .navigation.pagination .nav-links a.prev:before {
		right: auto;
		left: calc(50% - 10px);
	}
}

/*===========================================================================
-----------------------------------------------------------------------------
  404エラー設定　ここから
-----------------------------------------------------------------------------
===========================================================================*/
.background #errorArea section{
	padding: 100px 0 100px 0;
	width: 900px;
}
.background #errorArea h3{
	font-size: 140px;
	color: #4fb648;
	line-height: 1em;
}
.background #errorArea h3 span{
	font-size: 42px;
}
.background #errorArea p span{
	display: block;
}
/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
	.background #errorArea section{
		padding: 30px 0 30px 0;
		width: 100%;
	}
	.background #errorArea h3{
		font-size: 40px;
		margin: 0 15px 15px 15px;
	}
	.background #errorArea h3 span{
		font-size: 20px;
		margin-left: 0.2em;
	}
	.background #errorArea p{
		margin: 0 15px 15px 15px;
		font-size: 14px;
	}
	.background #errorArea p span{
		display: inline;
	}
}

/*===========================================================================

  設定　ここから

===========================================================================*/

/*--------------------------------------------------------------------------
  設定　ここから
---------------------------------------------------------------------------*/

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

/** スマートフォン用カウンター **/
@media screen and (max-width: 769px) {
}