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

p, a, h2, h3, h4, h5, h6, figcaption, li {
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	transform: rotate(0.03deg);
}

/*メニュー*/

@media screen and (min-width:961px) { /*PC*/
	.p-header-inner {
		background-color: #FFFFFF;
		width:100%;
		height: 120px;
		box-shadow: 0 0 10px rgba(0,0,0,0.15);
	}
	.p-header-wrap {
		width:100%;
		padding:0 3%;
		max-width:calc( 1200px + 6% );
		margin:0 auto 0;
		position: relative;
		box-sizing: border-box;
		display: flex;
		justify-content: space-between;
	}
	.p-header-logo {
		width: 140px;
		height: 200px;
		background-color: #fff;
		position: relative;
		z-index: 10;
	}
	.nav{
		width:calc(100% - 140px);
		max-width: 1000px;
		display: block!important;
	}
	.nav ul {
		display: flex;
		justify-content: space-between;
	}
	.nav ul li {
		width: calc(100% / 5);
		box-sizing: border-box;
	}
	.nav ul li:last-child {
	}
	.nav ul li a, .nav ul li em {
		display: block;
		width:114px;
		height: 120px;
		text-indent: -9999px;
		overflow: hidden;
		position: relative;
		margin:0 auto;
	}
	.nav ul li a:after {
		content: "";
		display: block;
		width:0;
		position: absolute;
		left:50%;
		bottom:10px;
		height: 4px;
		background-color:#71822b;
		transition: all 0.3s;
	}
	.nav ul li a:hover:after {
		width:100%;
		left:0;
	}
	.p-menu-01 a {background:url("../img/menu_01.webp") center center no-repeat;}
	.p-menu-02 a {background:url("../img/menu_02.webp") center center no-repeat;}
	.p-menu-03 a {background:url("../img/menu_03.webp") center center no-repeat;}
	.p-menu-04 a {background:url("../img/menu_04.webp") center center no-repeat;}
	.p-menu-05 a {background:url("../img/menu_05.webp") center center no-repeat;}
	.p-header-sp-nav{
		display: none;
	}
}
@media screen and (max-width:960px) { /*MB*/
	
/*外側クローズ用*/
	.p-main{
	}
	.p-main-cover{
		position: fixed;
		width: 100%;
		visibility: hidden;
		z-index: -1;  
		-webkit-transition: .3s;
		transition: .3s;
	}
	.p-main-cover.active{
		height:100%;
		visibility: visible;
		background:rgba(0,0,0,0.4);
		z-index:1000;
	}
	.p-head-space {
		width: 100%;
		height: 60px;
		background:#33452d;
	}
	.p-header-inner{
		width: 100%;
		height: 60px;
		position:fixed;
		top: 0;
		left: 0;
		z-index: 1000;
		background:#33452d;
	}
	.p-header-wrap{
		position:relative;
		width: 100%;
		height: 60px;
	}
	/*nav=====*/
	.p-header-logo {
		display: none;
	}
	.nav{
		display: none;
		position: relative;
		width: 100%;
		text-align: center;
		top: 0;
		left: 0;
		z-index: 950;
		padding-top:60px;
	}
	.nav li{
		background: #33452d;
		border-bottom: 1px solid #545454;
		text-align: left;
		text-indent: 12px;
	}
	.nav a, .nav span{
		color: #fff;
		display: block;
		height: 50px;
		line-height: 50px;
		font-size:2rem;
		font-family: "Noto Sans JP", sans-serif;
		font-optical-sizing: auto;
		font-style: normal;
		transform: rotate(0.03deg);
		font-weight: 700!important;
	}
	.nav a:hover{
		text-decoration: none;
	}
	/*ナビボタン*/
	.p-header-sp-nav{
		width: 30px;
		height: 26px;
		position: absolute;
		top: 0;
		bottom: 0;
		right: 10px;
		margin:auto;
		cursor: pointer;
		z-index: 1000;
		background:#33452d;
	}
	.p-header-sp-nav:before {
		content: "";
		display: block;
		width:50px;
		height:60px;
		background-color:#33452d;
		z-index: -1;
		position: absolute;
		right:-10px;
		top:-17px;
	}
	.p-header-sp-nav span {
		display: block;
		position: absolute;
		width: 30px;
		height: 2px;
		background: #fff;
		-webkit-transition: .3s;
		transition: .3s;
	}
	.p-header-sp-nav span:first-of-type {
		top: 0;
		bottom: auto;
		margin-bottom: 10px;
	}
	.p-header-sp-nav span:nth-of-type(2) {
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
	}
	.p-header-sp-nav span:last-of-type {
		bottom: 0;
		top: auto;
	}
	.p-header-sp-nav.active{
	}
	.p-header-sp-nav.active span:nth-of-type(2) {
		right: -60px;
		opacity: 0;
		visibility: hidden;
	}
	.p-header-sp-nav.active span:first-of-type{
		top: 0;
		bottom: 0;
		margin: auto;
		transform:rotate(45deg);
	}
	.p-header-sp-nav.active span:last-of-type{
		top: 0;
		bottom: 0;
		margin: auto;
		transform:rotate(-45deg);
	}
	
}

/*メインビジュアル*/

.p-mv-shadow {
	width:100%;
	height: 500px;
	position: relative;
	/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#000000+0,000000+100&0+0,0.65+100 */
	background: linear-gradient(to bottom,  rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
}

.p-mv-logo {
	width:100%;
	position: absolute;
	max-width: 704px;
	aspect-ratio:704 / 295;
	bottom: 20px;
	left: 0;
	right: 0;
	margin: 0 auto;
	z-index: 10;
}

/*メインページ*/

.p-head {
	border-bottom: 5px solid #dde2b7;
	width: 100%;
	max-width: 640px;
	margin: 0 auto 48px;
	padding-bottom: 16px;
}

/*概要*/

.p-about-head {
	background: url("../img/wi_biotope.webp") center top no-repeat;
	background-size: cover;
	width: 100%;
	max-width: 777px;
	aspect-ratio:777 / 232;
	margin: 0 auto 32px;
}

.p-about-list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap:32px;
	align-content: center;
	align-items: center;
}

.p-about-topics {
	background: url("../img/action.webp") center top no-repeat;
	width: 100%;
	max-width: 180px;
	aspect-ratio:18 / 17;
}

.p-about-list ul {
	text-align: left;
	list-style: disc;
	display: flex;
	flex-direction: column;
	gap:12px;
}

.p-about-list ul li {
	font-size: 1.6rem;
}

/*バナーエリア*/

ul.p-banner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap:24px;
}

ul.p-banner li {
	position: relative;
}

@media screen and (min-width:729px) { /*PC*/
	ul.p-banner li {
		width: calc((100% - 24px) / 2);
	}
}
@media screen and (max-width:728px) { /*MB*/
	ul.p-banner li {
		width: 100%;
	}
}

ul.p-banner a {
	width: 100%;
	margin:0 auto;
	font-weight: 700;
	text-decoration:none;
	color:#33452d;
	border-radius: 10px;
	font-size: 2.2rem;
	box-sizing: border-box;
	padding: 12px 8px;
	background: rgb(230,240,163); /* Old browsers */
	background: linear-gradient(to bottom, rgba(230,240,163,1) 0%,rgba(210,230,56,1) 50%,rgba(195,216,37,1) 51%,rgba(219,240,67,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e6f0a3', endColorstr='#dbf043',GradientType=0 ); /* IE6-9 */
	border:1px solid rgba(204,217,118,1.00);
	box-shadow:0 3px 0 rgba(219,224,188,1.00);
	transition: all 0.3s;
	display: inline-flex;
	align-items: center;
	text-align: center;
	justify-content: center;
}

ul.p-banner a span {
	font-size: 3.2rem;
}

ul.p-banner a:hover {
	transform: translateY(3px);
	opacity: 0.6;
	box-shadow:0 0 0 rgba(219,224,188,1.00);
}

/*フッター*/

.p-foot-logo a {
	display: block;
	background: url("../img/foot_logo.webp") center center no-repeat;
	width: 100%;
	max-width: 342px;
	aspect-ratio:342 / 124;
	margin: 0 auto 24px;
	transition: all 0.3s;
}

.p-foot-logo a:hover {
	opacity: 0.6;
}

.p-foot-text {
	font-size: 1.6rem;
	line-height: 1.5;
	color: #fff;
	margin-bottom: 24px;
}

.p-copyright {
	font-size: 1.4rem;
	color: #fff;
}

/*記事用*/

.oneday {
	width:100%;
	margin:0 auto 48px;
	background-color:#fff;
	box-shadow:0 0 5px rgba(0,0,0,0.2);
	box-sizing: border-box;
}

.diary_main {
	width:100%;
	box-sizing: border-box;
	padding:36px;
	text-align: left;
	color:#33452b;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap:24px;
}

.diary_head {
	display: block;
	width:100%;
	aspect-ratio:10 / 2;
	position: relative;
}

.diary_head img {
	width: 100%;
	
}

@media screen and (min-width:729px) { /*PC*/
	.diary_head figcaption {
		width:100%;
		background-color:rgba(58,115,32,0.75);
		box-sizing: border-box;
		padding: 8px 12px;
		position: absolute;
		left:0;
		bottom:0;
		text-align: left;
		font-size:2.2rem;
		font-weight: bold;
		color:#fff;
	}
}
@media screen and (max-width:728px) { /*MB*/
	.diary_head figcaption {
		width:100%;
		background-color:rgba(58,115,32,0.75);
		box-sizing: border-box;
		padding: 8px 12px;
		text-align: left;
		font-size:2.2rem;
		font-weight: bold;
		color:#fff;
	}
}

/*新記事用*/


.new .diary_main p {
	width: 100%;
	font-size:1.7rem;
	line-height: 1.8;
}

.new .diary_main h2 {
	font-size:2.7rem;
	width: 100%;
	box-sizing: border-box;
	padding: 8px 12px;
	border-radius: 8px;
	font-weight: 700!important;
	background-color: #C1DBB5;
	color: #33452b;
}

.new .diary_main h3 {
	font-size:2.4rem;
	width: 100%;
	font-weight: bold;
	border-bottom:1px dotted #33452b;
	padding-bottom: 8px;
}

.new .diary_main h4 {
	font-size:2rem;
	width: 100%;
	font-weight: bold;
	border:1px solid #33452b;
	padding: 6px;
}

.new .diary_main h5 {
	font-size:2rem;
	width: 100%;
	font-weight: bold;
	border-left:10px solid #33452b;
	padding: 6px;
	background-color: #EEF7EA;
}

.new .diary_main h6 {
	font-size:1.8rem;
	width: 100%;
	font-weight: bold;
	border-left:10px solid #33452b;
	border-bottom:1px solid #33452b;
	padding: 6px;
}

@media screen and (min-width:961px) { /*PC*/
	.diary_main h2 {
		font-size:2.7rem;
	}
	.diary_main h3 {
		font-size:2.4rem;
	}
	.diary_main h4 {
		font-size:2rem;
	}
	.diary_main h5 {
		font-size:2rem;
	}
	.diary_main h6 {
		font-size:1.8rem;
	}
}
@media screen and (max-width:960px) { /*MB*/
	.diary_main h2 {
		font-size:2.2rem;
	}
	.diary_main h3 {
		font-size:2.0rem;
	}
	.diary_main h4 {
		font-size:1.8rem;
	}
	.diary_main h5 {
		font-size:1.6rem;
	}
	.diary_main h6 {
		font-size:1.5rem;
	}
}


.new .diary_main figure {
	width: calc((100% - 24px) / 2);
	box-sizing: border-box;
	background:url("../img/photo_bg.webp") left top repeat;
	padding:10px;
	position: relative;
}

@media screen and (min-width:729px) { /*PC*/
	.new .diary_main figure {
		width: calc((100% - 24px) / 2);
	}
}
@media screen and (max-width:728px) { /*MB*/
	.new .diary_main figure {
		width: 100%;
	}
}

.new .diary_main figure img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

.new .diary_main figure figcaption {
	display: block;
	width:100%;
	line-height: 1.4;
	font-size:1.6rem;
	color:#33452b;
	padding: 5px 10px;
	font-style: normal;
	background-color:rgba(255,255,255,0.85);
}

/*過去記事用*/

.kako .diary_main h5 {
	font-size:2.4rem;
	width: 100%;
	font-weight: bold;
	border-bottom:1px dotted #33452b;
	padding-bottom: 8px;
}

.kako .diary_main p {
	font-size:1.7rem;
	line-height: 1.8;
}

.kako .diary_main ul {
	display: flex;
	justify-content: center;
	gap:24px;
	flex-wrap:wrap;
}

.kako .diary_main ul li {
	width: calc((100% - 24px) / 2);
	box-sizing: border-box;
	background:url("../img/photo_bg.webp") left top repeat;
	padding:10px;
	position: relative;
}

@media screen and (min-width:729px) { /*PC*/
	.kako .diary_main ul li {
		width: calc((100% - 24px) / 2);
	}
}
@media screen and (max-width:728px) { /*MB*/
	.kako .diary_main ul li {
		width: 100%;
	}
}

.kako .diary_main ul li img {
	width: 100%;
	margin: 0 auto;
}

.kako p {
	width: 100%;
}

.kako p img {
	display: block;
	width: 100%!important;
	max-width: 720px!important;
	margin: 0 auto!important;
}

.kako .diary_main ul li em {
	display: block;
	width:calc(100% - 20px);
	line-height: 1.4;
	font-size:1.6rem;
	position: absolute;
	color:#33452b;
	bottom:10px;
	padding: 5px 10px;
	font-style: normal;
	background-color:rgba(255,255,255,0.85);
}

.kako .diary_main hr {
	border:0;
	margin:0 auto 24px;
	display: block;
	width:100%;
	height:64px;
	position: relative;
}

.kako .diary_main hr:before {
	content:"●●●●●●●●";
	position: absolute;
	top:0;
	left:0;
	width:100%;
	display: block;
	line-height: 64px;
	text-align: center;
	letter-spacing:30px;
	color:#ddecce;
	font-size:1.8rem;
}

/*固定ページ共通*/

.p-pagewrap {
	width:100%;
	margin:0 auto;
	background-color:#fff;
	box-shadow:0 0 5px rgba(0,0,0,0.2);
	box-sizing: border-box;
	
	text-align: left;
	color:#33452b;
	display: flex;
	flex-direction: column;
	gap:24px;
}

@media screen and (min-width:961px) { /*PC*/
	.p-pagewrap {
		padding:36px;
	}
}
@media screen and (max-width:960px) { /*MB*/
	.p-pagewrap {
		padding:12px;
	}
}

.p-pagewrap h1 {
	padding: 12px 12px 12px 54px;
	font-weight: bold;
	background-color:#33452b;
	width:100%;
	border-radius: 15px;
	color:#fff;
	position: relative;
}

.p-pagewrap h1:before {
	content:"";
	display: block;
	width: 30px;
	height: 30px;
	border-radius: 15px;
	position: absolute;
	left:12px;
	top: 0;
	bottom: 0;
	margin: auto 0;
	background-color:#85977D;
}

.p-pagewrap h2 {
	width: 100%;
	box-sizing: border-box;
	padding: 8px 12px;
	border-radius: 8px;
	font-weight: 700!important;
	background-color: #C1DBB5;
	color: #33452b;
}

.p-pagewrap h3 {
	width: 100%;
	font-weight: bold;
	border-bottom:1px dotted #33452b;
	padding-bottom: 8px;
}

.p-pagewrap h4 {
	width: 100%;
	font-weight: bold;
	border:1px solid #33452b;
	padding: 6px;
}

.p-pagewrap h5 {
	width: 100%;
	font-weight: bold;
	border-left:10px solid #33452b;
	padding: 6px;
	background-color: #EEF7EA;
}

.p-pagewrap h6 {
	width: 100%;
	font-weight: bold;
	border-left:10px solid #33452b;
	border-bottom:1px solid #33452b;
	padding: 6px;
}

@media screen and (min-width:961px) { /*PC*/
	.p-pagewrap h1 {
		font-size:2.8rem;
	}
	.p-pagewrap h2 {
		font-size:2.7rem;
	}
	.p-pagewrap h3 {
		font-size:2.4rem;
	}
	.p-pagewrap h4 {
		font-size:2rem;
	}
	.p-pagewrap h5 {
		font-size:2rem;
	}
	.p-pagewrap h6 {
		font-size:1.8rem;
	}
}
@media screen and (max-width:960px) { /*MB*/
	.p-pagewrap h1 {
		font-size:2.2rem;
	}
	.p-pagewrap h2 {
		font-size:2.0rem;
	}
	.p-pagewrap h3 {
		font-size:1.9rem;
	}
	.p-pagewrap h4 {
		font-size:1.7rem;
	}
	.p-pagewrap h5 {
		font-size:1.5rem;
	}
	.p-pagewrap h6 {
		font-size:1.5rem;
	}
}



.p-pagewrap p {
	font-size:1.7rem;
	line-height: 1.8;
}

.p-pagewrap ul, .p-pagewrap ol {
	padding-left: 24px;
}

.p-pagewrap ul li {
	font-size:1.7rem;
	line-height: 1.8;
	list-style: disc;
}

.p-pagewrap ol li {
	font-size:1.7rem;
	line-height: 1.8;
	list-style:decimal;
}

/*地図*/

.p-map {
	width:100%;
	position: relative;
}

.p-map iframe {
	width:100%;
	height:500px;
}

/* 写真 */

.photoblock {
	display: flex;
	width:100%;
	justify-content:center;
	gap:24px;
	flex-wrap: wrap;
}

.pbox {
	background-color:#ECF4E9;
	box-sizing: border-box;
	border:1px solid #85977D;
	padding:10px;
	font-size:1.4rem;
	text-align: center;
}

@media screen and (min-width:961px) { /*PC*/
	.pbox {
		width: 100%;
		max-width:162px;
	}
}
@media screen and (max-width:960px) { /*MB*/
	.pbox {
		width: calc((100% - 24px) / 2);
		max-width:162px;
	}
}


.pbox a {
	width: 100%;
	max-width:120px;
	aspect-ratio: 1 / 1;
	margin:0 auto 16px;
	overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}

.pbox a img {
	width: 100%;
	display: block;
	margin:0 auto;
	transition: all 0.3s;
}

.pbox a:hover img {
	opacity: 0.6;
}

.pbox span {
	display: inline-block;
	width:140px;
	border-top:1px dotted #85977D;
	line-height: 22px;
	padding-top:8px;
}

/*たより*/

.p-report-wrap {
	display: flex;
	flex-direction: column;
	gap:32px;
}

.p-report-new {
	background-color: #ecf4ea;
	box-sizing: border-box;
	padding: 24px;
}

.p-report-new a {
	width: 100%;
	margin:0 auto;
	font-weight: 700;
	text-decoration:none;
	color:#33452d;
	border-radius: 10px;
	font-size: 2rem;
	box-sizing: border-box;
	padding: 12px 8px;
	background: rgb(230,240,163); /* Old browsers */
	background: linear-gradient(to bottom, rgba(230,240,163,1) 0%,rgba(210,230,56,1) 50%,rgba(195,216,37,1) 51%,rgba(219,240,67,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e6f0a3', endColorstr='#dbf043',GradientType=0 ); /* IE6-9 */
	border:1px solid rgba(204,217,118,1.00);
	box-shadow:0 3px 0 rgba(219,224,188,1.00);
	transition: all 0.3s;
	display: inline-flex;
	align-items: center;
	text-align: center;
	justify-content: center;
}

.p-report-new a:hover {
	transform: translateY(3px);
	opacity: 0.6;
	box-shadow:0 0 0 rgba(219,224,188,1.00);
	text-decoration: none;
}

.p-report-box {
	background-color: #ecf4ea;
	box-sizing: border-box;
	padding: 12px;
	display: flex;
	flex-wrap: wrap;
	gap:24px;
}

.p-report-title {
	background-color: #85977f;
	box-sizing: border-box;
	padding: 12px;
	color: #fff;
	height: auto;
	display: flex;
	align-items: center;
	position: relative;
}

.p-report-title p {
	font-weight:700;
}

.p-report-list {
	padding-left: 16px;
}

.p-report-list ol li {
	border-bottom: 1px dotted #33452b;
	font-size: 1.5rem;
}

.p-report-link {
	padding: 12px;
	display: flex;
	align-items: center;
}

@media screen and (min-width:961px) { /*PC*/
	.p-report-title {
		width: 20%;
	}
	.p-report-title:after {
		content: "";
		display: block;
		position: absolute;
		right: -17px;
		top: 0;
		bottom: 0;
		margin: auto 0;
		width: 0;
		height: 0;
		border-style: solid;
		border-top: 10px solid transparent;
		border-bottom: 10px solid transparent;
		border-left: 17px solid #85977f;
		border-right: 0;
	}
	.p-report-list {
		width: calc(60% - 48px);
	}
	.p-report-link {
		width: 20%;
	}
}
@media screen and (max-width:960px) { /*MB*/
	.p-report-title {
		width: 100%;
	}
	.p-report-list {
		width: 100%;
	}
	.p-report-link {
		width: 100%;
	}
}

.p-report-link a {
	width: 100%;
	margin:0 auto;
	font-weight: 700;
	text-decoration:none;
	color:#33452d;
	border-radius: 10px;
	font-size: 2rem;
	box-sizing: border-box;
	padding: 12px 8px;
	background: rgb(230,240,163); /* Old browsers */
	background: linear-gradient(to bottom, rgba(230,240,163,1) 0%,rgba(210,230,56,1) 50%,rgba(195,216,37,1) 51%,rgba(219,240,67,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e6f0a3', endColorstr='#dbf043',GradientType=0 ); /* IE6-9 */
	border:1px solid rgba(204,217,118,1.00);
	box-shadow:0 3px 0 rgba(219,224,188,1.00);
	transition: all 0.3s;
	display: inline-flex;
	align-items: center;
	text-align: center;
	justify-content: center;
}

.p-report-link a:hover {
	transform: translateY(3px);
	opacity: 0.6;
	box-shadow:0 0 0 rgba(219,224,188,1.00);
	text-decoration: none;
}

/* ナビ */

.wp-pagenavi {
	width: 100%;
	box-sizing: border-box;
	padding: 10px 20px !important;
	display: flex;
	justify-content: center;
	gap:8px;
	flex-wrap: wrap;
}
.wp-pagenavi a, .wp-pagenavi span.pages, .wp-pagenavi span.extend {
	display: inline-block;
	color:#707070 !important;
	background:#FFFFFF !important;
	border-radius:3px !important;	
	border:solid 1px #DCDCDC !important;
	padding:6px 9px 6px 9px !important;
	margin-right:3px !important;
	text-decoration:none !important;
	font-size:1.7rem !important;
	box-sizing: border-box;
}
.wp-pagenavi a:hover {
	border-color:#202020 !important;
	background:#525252 !important;
	color:#fff !important;
	background:-moz-linear-gradient(top,#9F9F9F 1px,#6C6C6C 1px,#525252) !important;
	background:-webkit-gradient(linear,0 0,0 100%,color-stop(0.02,#9F9F9F),color-stop(0.02,#6C6C6C),color-stop(1,#525252)) !important;

}
 .wp-pagenavi span.current{
	display: inline-block;
	font-size:1.7rem !important;
	padding:6px 9px 6px 9px !important;
	border:solid 1px #DCDCDC !important;
	border-color:#3390CA !important;
	border-radius:3px !important;	
	color:#fff !important;
	margin-right:3px !important;
	border-color:#202020 !important;
	background:#525252 !important;
	background:-moz-linear-gradient(top,#9F9F9F 1px,#6C6C6C 1px,#525252) !important;
	background:-webkit-gradient(linear,0 0,0 100%,color-stop(0.02,#9F9F9F),color-stop(0.02,#6C6C6C),color-stop(1,#525252)) !important;
}


/*お問い合わせ*/

.p-contact-form {
	width:100%;
}

.p-form_premise,
.p-form_acceptance {
	text-align: left;
	width:100%;
}

.p-contact-form dl {
	width:100%;
	display: flex;
	justify-content: space-between;
	margin-bottom:8px;
}

.p-contact-form dl dt {
	width:29%;
	color:#fff;
	background-color:#85977D;
	font-size:1.6rem;
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
	padding:16px;
}

.p-contact-form dl dt span {
	margin-left:8px;
	font-size: 90%;
	color:yellow;
	font-weight: bold;
}

.p-contact-form dl dd {
	width:70%;
	background-color:#F9F9F7;
	position: relative;
	display: flex;
	align-items: center;
	box-sizing: border-box;
	flex-direction: column;
	padding:16px;
	font-size:1.6rem;
}

@media screen and (min-width:1025px) {
	.p-contact-form dl {
		display: flex;
		justify-content: space-between;
	}
	.p-contact-form dl dt {
		width:29%;
	}
	.p-contact-form dl dd {
		width:70%;
	}
}
@media screen and (max-width:1024px) {
	.p-contact-form dl {
		display: flex;
		justify-content: space-between;
		flex-direction: column;
		flex-wrap: wrap;
	}
	.p-contact-form dl dt {
		width:100%;
	}
	.p-contact-form dl dd {
		width:100%;
	}
}

.p-contact-form dl dd div {
	width:100%;
	margin:0 auto;
	position: relative;
	text-align: left;
}

.p-contact-form dl dd input[type="text"],input[type="email"],input[type="tel"],input[type="url"] {
	width:100%;
	display: block;
	margin:0 auto;
    box-sizing: border-box;
    outline: none;
    border: 1px solid lightgray;
    border-radius: 3px;
    padding: 10px 10px 10px 10px;
    transition: all 0.1s ease-out;
	font-size:1.6rem;
	color:dimgray;
	position: relative;
}

span.check {color:dimgray; margin:8px 0;display: block;}

.p-contact-form select {
	width:100%;
	display: block;
    box-sizing: border-box;
    outline: none;
    border: 1px solid lightgray;
    border-radius: 3px;
    padding: 10px 10px 10px 10px;
    transition: all 0.1s ease-out;
	font-size:1.6rem;
	color:dimgray;
	position: relative;
}

.p-contact-form dl dd textarea {
	width:100%;
	display: block;
	margin:0 auto;
	box-sizing: border-box;
    outline: none;
    border: 1px solid lightgray;
    border-radius: 3px;
    padding: 10px 10px 10px 10px;
    transition: all 0.1s ease-out;
	font-size:1.6rem;
	color:dimgray;
	position: relative;
}

.wpcf7-form-control-wrap {
	display: block;
}

.wpcf7-form-control.wpcf7-checkbox {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap:10px;
}

.wpcf7-list-item-label {/*項目の色や文字サイズ*/
	cursor: pointer;
}

.p-form-label .wpcf7-list-item {
	display: block;
	
	line-height: 40px;
	height:40px;
	background-color:#FFF;
	box-sizing: border-box;
	padding:0 8px;
	border-radius: 5px;
	position: relative;
	margin:0!important;
}

/*PC*/
@media screen and (min-width:1025px) {
	.p-form-label .wpcf7-list-item {
		width:calc(calc(100% - 20px) / 3);
	}
}
/*MOB*/
@media screen and (max-width:1024px) {
	.p-form-label .wpcf7-list-item {
		width:calc(calc(100% - 20px) / 2);
	}
}

input[type="checkbox"] {
  position: absolute;
  opacity: 0;/*既存のチェックボックスを見えなくする*/
}

.wpcf7-list-item-label:before {/*チェックボックスの枠*/
  content: '';
  border: 1px solid #85977D;
  display: inline-block;
  width: 20px;
  height: 20px;
  position: relative;
  top: -3px;
  margin-right: 12px;
  vertical-align: middle;
  cursor: pointer;
  text-align: center;
}

input[type="checkbox"]:checked + .wpcf7-list-item-label:after {/*チェックアイコン*/
	content: "";
	display: block;
	position: absolute;
	top: 10px;
	left: 8px;
	width: 20px;
	height: 20px;
	background: url("../img/check-solid.svg") no-repeat center;
  background-size: contain;
}

.p-contact-check {
	width:100%;
	background-color:#F9F9F7;
	position: relative;
	display: flex;
	align-items: center;
	box-sizing: border-box;
	flex-direction: column;
	padding:16px;
	font-size:1.6rem;
}

.p-contact-check .wpcf7-list-item {
	display: block!important;
	width:100%;
	line-height: 40px;
	height:40px;
	background-color:#FFF;
	box-sizing: border-box;
	padding:0 8px;
	border-radius: 5px;
	position: relative;
	margin: 0!important;
}

.p-form-bt {
	width:100%;
	margin:0 auto;
}

.p-form-bt input[type="submit"],input[type="reset"] {
	display: block;
	width:200px;
	height:60px;
	color:#fff;
	background-color:#503989;
	outline: none;
	border:0;
	font-size: 1.6rem;
	font-weight: bold;
	cursor: pointer;
	margin:0 auto;
	text-align: center;
}

.p-form-bt input[type="submit"] {
	background-color:#85977D;
	transition: all 0.3s;
	border:5px solid #85977D;
}

.p-form-bt input[type="submit"]:hover {
	background-color:#fff;
	color:#85977D;
	border:5px solid #85977D;
}

.wpcf7 form .wpcf7-response-output {
	margin:0!important;
}

div.wpcf7-mail-sent-ok {
	width:100%;
border: 2px solid #85977D;
}
div.wpcf7-mail-sent-ng {
	width:100%;
border: 2px solid #ff0000;
}
div.wpcf7-spam-blocked {
	width:100%;
border: 2px solid #ffa500;
}
div.wpcf7-validation-errors {
	width:100%;
border: 2px solid #f7e700;
}


.wpcf7 form.sent .wpcf7-response-output {/* 送信ボタン下完了時 */
    border-color: #8cebe5;
	font-size: 1.8rem;
	box-sizing: border-box;
	padding:12px;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {/* 送信ボタン下未入力警告 */
    border-color: #f88;
	font-size: 1.8rem;
	box-sizing: border-box;
	padding:12px;
}
.wpcf7-not-valid-tip {/* 必須未入力項目下の文章 */
    color: #f88;
    font-size: 12px;
}

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="url"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
width: 100%!important
}

/*その他調整用*/

.wp-element-caption {
	margin: 0!important;
}

/*reCAPTCHA非表示*/

.grecaptcha-badge { visibility: hidden; }