@import url(https://fonts.googleapis.com/css2?family=Barlow:wght@400;700&display=swap);



/* reset */




/* ヘッダー
------------------------------------------------------------*/
.Wrapper {
	width: 1280px;
	/* overflow: hidden; */
	margin: 0 auto;
}

#header2 {
	width: 100%;
	height: 610px;
	margin: 0 auto;
	position: relative;
	aspect-ratio: 16/9;
}

#home-video {
	object-fit: cover;
	position: absolute;
	width: 100%;
	height: 610px;
}

#header {
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 0;
	/* 表示画像の高さ ÷ 表示画像の幅 × 100 */
	padding-top: 42.4657534247%;
	background: url('../img/top/top.jpg') 0 0 no-repeat;
	background-size: contain;
}

#header img {
	position: absolute;
	width: 100%;
	height: auto;
}

@media only screen and (max-width: 768px) {
	#header2 {
		height: auto;
	}

	#home-video {
		height: auto;
	}
}

#slogan {
	position: absolute;
	top: 50%;
	width: 100%;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	color: #fff;
	line-height: 1.2;
	text-align: center;
}

#slogan h1 {
	font-size: 50px;
	font-family: "游ゴシック体", 'Yu Gothic Medium,sans-serif';
	margin-bottom: 20px;
	font-weight: bold;
	font-weight: bold;
}

#slogan h2 {
	font-size: 20px;
	font-weight: normal;
	pointer-events: auto;
	border-style: solid;
	border-color: #ffffff;
	border-width: 2px !important;
	font-family: "Barlow";
	font-size: 1.25rem;
	font-weight: 500;
	letter-spacing: 0.075em;
	line-height: 1;
	padding: 0.5rem 1.75rem;
	text-transform: uppercase;
	visibility: visible;
	display: table;
	margin: 100px auto 0 !important;
}


#slogan a:link {
	color: #ffffff !important;
}

#slogan a:hover {
	color: #FFF !important;
	opacity: 0.2 !important;

}

#slogan a:visited {
	color: #ffffff !important;
}

.news dl {
	text-align: center;
	border-right: 2px #000 solid;
	text-align: center;
	display: block;
	padding: 0 40px;
	min-height: 140px;
	line-height: 1.5;
}

.logo {
	width: 280px;
	position: relative;
	top: -14px;
	left: 20px;
}

/* フッター
------------------------------------------------------------*/
#footer {
	clear: both;
	padding: 50px 10px 50px 0;
	text-align: center;
	font-size: 12px;
}


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


section {
	clear: both;
}

section h2 {
	font-size: 22px;
	text-align: center;
	font-family: 'Barlow', sans-serif;
	font-weight: bold;
}

.inner {
	width: 94%;
	margin: 0 auto;
	padding-bottom: 50px;
}

.hiddenPc {
	visibility: hidden;
	display: none;
	width: 0px;
	height: 0px;
}

.innerWrap {
	width: 1280px;
	margin: 0 auto;
	position: relative;
}

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

/* SEC01 VISION スライダー
------------------------------------------------------------*/
/* 追記　ゆ */
.news {
	/* display: flex; */
	gap: 2rem;
	width: 90%;
	margin: 0 auto;
	align-items: center;
	overflow: hidden;
}

.news>p {
	font-size: 2rem;
	font-family: 'Barlow', sans-serif;
	font-weight: bold;
}

.news .swiper-custom-parent {
	width: auto;
	overflow: hidden;
	font-size: 1rem;
}

.news .post_type {
	background-color: #4C8D26;
	color: #fff;
	padding: 5px 8px;
	border-radius: 4px;
	margin: 0 5px;
}

.news .swiper-wrapper {
	align-items: center;
}

@media screen and (max-width: 768px) {
	.news>p {
		font-size: 1.6em;
		line-height: 1.0em;
	}

	.news .title {
		width: 100%;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
}

/* 追記　ゆ */
#NewsWrap {
	width: 100%;
	margin: 0% auto;
	padding: 5% 0;
	background: #ebebeb;
}

.news dl {
	text-align: center;
	border-right: 1.5px #000 solid;
	text-align: center;
	display: block;
	padding: 0 30px;
	min-height: 158px;
	line-height: 1.5;
}

.newsBox .date {
	font-size: 13px;
	display: inline-block;
	margin-bottom: 4px;
}

dl.newsBox .title {
	font-size: 13px;
	background-color: #FFF;
	display: block;
	margin-bottom: 10px;
	padding: 4px 10px;
}

dl.newsBox dd {
	font-size: 17px;
}

.swiper-custom-parent {
	width: 90%;
	margin: 0 auto;
	position: relative;
}

.swiper-button-next,
.swiper-container-rtl .swiper-button-prev {
	right: -50px !important;
	left: auto;
}

.swiper-button-prev,
.swiper-container-rtl .swiper-button-next {
	left: -50px !important;
	right: auto;
}


/* SEC02 FREAKS HOUSE
	 SEC03 ZERO CUBE
------------------------------------------------------------*/
#sec02 .wrap,
#sec03 .wrap {
	clear: both;
	width: 100%;
	z-index: 1;
	position: relative;
}

#sec02 .wrap,
#sec02 .wrap:after {
	background-color: #4c8d26?v=1;
}

#sec03 .wrap,
#sec03 .wrap:after {
	background-color: #FFAA00?v=1;
}

#sec02 .wrap:after,
#sec03 .wrap:after {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	transform: skewY(1deg);
	transform-origin: bottom left;
	z-index: -1;
	width: 100%;
	height: 100%;
}

#sec02 .bg,
#sec03 .bg {
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 100%;
	width: 100%;
	height: 0;
	padding-top: 53.75%;
	position: relative;
}

#sec02 .bg {
	background-image: url(../img/top/sec_02_bg.png)
}

#sec03 .bg {
	background-image: url(../img/top/sec_03_bg.png)
}

#sec02 .wrap .txt,
#sec03 .wrap .txt {
	text-align: center;
	color: #fff;
	font-size: 20px;
	line-height: 1.7;
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, sans-serif !important;
	font-weight: bold;
	font-feature-settings: "palt";
	width: 650px;
	position: absolute;
	top: 70%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 2;
}


.sec02_1 {
	position: relative;
	top: -55px;
	margin-bottom: -55px;
}

.sec03_1 {
	position: relative;
	top: -100px;
	margin-bottom: -100px;
}


.btn_01 {
	position: absolute;
	top: 50px;
	right: 30px;
	z-index: 4;
	line-height: 1.2;
}

.btn_02 {
	position: absolute;
	top: 40px;
	left: 30px;
	z-index: 4;
	line-height: 1.2;
}

.btn_03 {
	position: absolute;
	top: 0px;
	left: 10px;
	z-index: 4;
	line-height: 1.2;
}

.btn_04 {
	position: absolute;
	top: 50px;
	left: 20px;
	z-index: 4;
	line-height: 1.2;
}

.btn_05 {
	position: absolute;
	/*
	bottom: 20px;
	left: 20px;
*/
	bottom: 5%;
	left: 2%;
	z-index: 4;
	line-height: 1.2;
}

.btn_06 {
	position: absolute;
	top: 20px;
	right: 30px;
	z-index: 4;
	line-height: 1.2;
}


.flex-container {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	margin: 0 auto;
	box-sizing: border-box;
	width: 1280px;
}

.flex-item {
	/* 	width: calc((100% - 30px) / 3); */
	width: 410px;
	position: relative;
	box-sizing: border-box;
	margin-right: 10px;
	margin-bottom: 15px;
}

/* .flex-item :first-child {margin-left: -10px;} */
.flex-item:nth-child(3n) {
	margin-right: 0;
}

.flex-item img {
	display: block;
	height: auto;

}


/* モーダル */
.modaal-container {
	position: relative;
	display: inline-block;
	width: 100%;
	margin: 0 auto;
	text-align: center;
	color: #000;
	max-width: 700px !important;
	border-radius: 0px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
	cursor: auto;
}

.modalInner {
	padding: 2%;
	margin: 2%;
	font-size: 13px;
	text-align: center;
}

.modalGreen h3,
.modalOrange h3 {
	text-align: center;
	font-size: 28px;
	margin: 20px 0 10px 0;
}

.modalGreen {
	background-color: #dbe8d4 !important;
	text-align: center;
}

.modalGreenHeader {
	background-color: #4C8D26 !important;
	padding: 10px;
	color: #FFF;
	text-align: center;
	font-weight: 700;
	font-size: 20px;
}

.modalGreenHeader>span,
.modalOrangeHeader>span {
	top: 16px;
	position: relative;
	z-index: 3;
}

.modalOrange {
	background-color: #fff5df !important;
	text-align: center;
}

.modalOrangeHeader {
	background-color: #ffa000 !important;
	padding: 10px;
	color: #FFF;
	text-align: center;
	font-weight: 700;
	font-size: 20px;
}


.mGafter,
.mOafter {
	position: relative;
	z-index: 0;
}

.mGafter::after {
	content: '';
	position: absolute;
	left: 0;
	transform: skewY(-1.8deg);
	transform-origin: bottom left;
	z-index: -1;
	width: 100%;
	height: 100%;
	background: #4C8D26;
	padding: 0.5em 0;
}

.mOafter::after {
	content: '';
	position: absolute;
	left: 0;
	top: -10px;
	transform: skewY(-1.8deg);
	transform-origin: bottom left;
	z-index: -1;
	width: 100%;
	height: 100%;
	background: #ffa000;
	padding: 0.5em 0;
}


.modalImg {
	width: 100%;

}

.modalTxtBox {
	text-align: left;
	/*
	width: 100%;

	margin: 0px 20px 20px 20px;
	text-align: left;
	margin: 0 auto;
*/
}


/* contact 
------------------------------------------------------------*/
.ContactMainImg {
	width: 1280px;
	text-align: center;
}

.ContactMainImg .present {
	margin: 50px 0;
}

.ContactMainWrap dt span {
	font-weight: 600;
	color: #FFA000;
}


/* 商品画像を見る */
.btnRead {
	display: inline-block;
	margin: 2% auto 10% auto;
	padding: 5px !important;
	background: #fff;
	border: solid 2px #000;
	color: #000;
	font-size: 1em;
	font-weight: bold;
	text-align: center;
	position: relative;
	margin-bottom: 10px !important;

}





/* 汎用ページ用 */
.metaBox {}

.categoryNav {
	display: flex;
	justify-content: center;
	margin-bottom: 60px;
}

.categoryNav li {
	margin-left: 20px;
	list-style: none;
}

.categoryNav li .activez {
	position: relative;
	display: inline-block;
	text-decoration: none;
}

.categoryNav li .active::after {
	position: absolute;
	bottom: -4px;
	left: 0;
	content: '';
	width: 100%;
	height: 2px;
	background: #2ac5b3;
	transform: inherit;
	transform-origin: left top;
	transition: inherit;
}

.categoryNav li a {
	position: relative;
	display: inline-block;
	text-decoration: none;
}

.categoryNav li a::after {
	position: absolute;
	bottom: -4px;
	left: 0;
	content: '';
	width: 100%;
	height: 2px;
	background: #2ac5b3;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: transform .3s;
}

.categoryNav li a:hover::after {
	transform: scale(1, 1);
}


@media screen and (max-width: 800px) {
	.parent {
		flex-wrap: wrap;
	}

	.categoryNav {
		display: flex;
		justify-content: left;
		margin-bottom: 60px;
	}

	.categoryNav li {
		margin-left: 20px;
		margin-bottom: 20px;
		list-style: none;
	}

}


.estate-table table {
	width: 65%;
	margin: 0 auto;
	border: 2px solid #6c6c6c;
	border-collapse: collapse;
	font-size: 13px;
	line-height: 1.4rem;
}

.estate-table table tr {
	border-bottom: 1px solid #6c6c6c;
}

.estate-table table tr:last-child {
	border-bottom: 0px;
}

.estate-table table tr th {
	background: #f1f1f1;
	border-left: 1px solid #6c6c6c;
	padding: 10px 10px;
	text-align: left;
}

.estate-table table tr td {
	border-left: 1px solid #6c6c6c;
	padding: 10px 10px;
}

.estate-table.t1 th {
	width: 16.9%;
}

.estate-table.t1 td {
	width: 32.4%;
}

.estate-table.t2 th {
	width: 16.9%;
}

.estate-table.t2 td {
	width: 16%;
}

.estate-table2 table {
	width: 65%;
	margin: 0 auto;
	border: 2px solid #6c6c6c;
	border-collapse: collapse;
	font-size: 13px;
	line-height: 1.4rem;
}

.estate-table2 table tr {
	border-bottom: 1px solid #6c6c6c;
}

.estate-table table tr:last-child {
	border-bottom: 0px;
}

.estate-table2 table tr th {
	background: #f1f1f1;
	border-left: 1px solid #6c6c6c;
	padding: 10px 10px;
	text-align: left;
}

.estate-table2 table tr td {
	border-left: 1px solid #6c6c6c;
	padding: 10px 10px;
}

.estate-table2.t1 th {
	width: 10%;
}

.estate-table2.t1 td {
	width: 40%;
}

.estate-table2.t2 th {
	width: 16.9%;
}

.estate-table2.t2 td {
	width: 16%;
}

.estate-caution {
	margin: 20px;
	padding: 20px;
	border: 1px solid #6c6c6c;
}

.estate-caution h4 {
	font-weight: bold;
	font-size: 16px;
	margin: 0 0 10px 0;
}

.estate-caution ul {
	font-size: 14px;
	list-style-type: disc;
	margin: 0 0 0 20px;
}

.estate-caution ul li {
	line-height: 1.8;
}







@media (max-width: 768px) {
	.estate-table table {
		width: 100%;
	}

	.estate-table table tr th {
		background: #f1f1f1;
		border-left: 1px solid #6c6c6c;
		padding: 0px 10px;
		text-align: left;
	}

	.estate-table table tr td {
		border-left: 1px solid #6c6c6c;
		padding: 0px 10px;
	}



	.estate-table table th,
	.estate-table table td {
		display: table-cell;
		padding: 10px;
	}

	.estate-table2 table {
		width: 100%;
	}

	.estate-table2 table tr th {
		background: #f1f1f1;
		border-left: 1px solid #6c6c6c;
		padding: 0px 10px;
		text-align: left;
	}

	.estate-table2 table tr td {
		border-left: 1px solid #6c6c6c;
		padding: 0px 10px;
	}



	.estate-table2 table th,
	.estate-table2 table td {
		display: table-cell;
		padding: 10px;
	}

	.metaBox .date,
	.metaBox .category {
		display: block;
		text-align: left;
		font-size: x-small;
	}
}




/* ページャー */


/* その１  */

.pager ul.pagination {
	text-align: center;
	margin: 0;
	padding: 0;
	display: block;
}

.pager .pagination li {
	display: inline;
	margin: 0 2px;
	padding: 0;
	display: inline-block;
	background: #ccc;
	width: 50px;
	height: 50px;
	text-align: center;
	position: relative;
}

.pager .pagination li a {
	vertical-align: middle;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-align: center;
	display: table;
	color: #fff;
	text-decoration: none;
}

.pager .pagination li a span {
	display: table-cell;
	vertical-align: middle;
}

.pager .pagination li a:hover,
.pager .pagination li a.active {
	color: #000;
	background: #ccffd0;
}

@media only screen and (max-width: 767px) {
	.pager .pagination li {
		display: none;
	}

	.pager .pagination li.pre,
	.pager .pagination li.next {
		display: inline-block;
		width: 40%;
		height: 50px;
		text-align: center;
	}

	.pager .pagination li.pre a,
	.pager .pagination li.next a {
		width: 100%;
		text-align: center;
	}

	.pager .pagination li.pre span::after {
		content: "　前の10件へ";
	}

	.pager .pagination li.next span::before {
		content: "次の10件へ　";
	}

}






/* RESPONSIVE 設定
------------------------------------------------------------*/


/* 480pxからの幅の場合に適応される */
@media only screen and (min-width: 769px) {



	a#menu {
		display: none;
	}

	.panel {
		display: block !important;
		max-width: 1280px;
		margin: 0 auto;
	}

	.flex_test-box {
		display: flex;
		align-items: center;
	}

	.flex_test-item:first-child {
		margin-right: auto;
	}

}

/* @media only screen and (min-width: 769px) END */

/* 480pxまでの幅の場合に適応される */
@media only screen and (max-width: 768px) {


	@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP&display=swap');





	.hiddenSp {
		visibility: hidden;
		display: none;
		width: 0px;
		height: 0px;
	}

	.headerSp {
		padding: 12px 0;
		text-align: center;
		position: sticky;
		position: -webkit-sticky;
		top: 0;
		z-index: 500;
		display: inline-block;
		left: 50%;
		transform: translate(-50%, 0);
	}

	.headerSp .logo {
		width: 200px;
		position: relative;
		top: inherit;
		left: -2vw;
	}

	body {
		/* 	font-size:16px; */
		font-family: sans-serif;
	}

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

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

	#header3 {
		position: relative;

	}

	#header3 #home-video3 {
		width: 100%;
		object-fit: cover;
		vertical-align: top;
	}


	#slogan h1 {
		font-size: 20px;
		font-family: sans-serif;
		margin-bottom: 20px;
		font-weight: bold;
	}

	#slogan h2 {
		font-size: 16px;
	}


	.swiper-button-next,
	.swiper-container-rtl .swiper-button-prev {
		right: 0px !important;
		left: auto;
	}

	.swiper-button-prev,
	.swiper-container-rtl .swiper-button-next {
		left: 0px !important;
		right: auto;
	}


	.news dl {
		text-align: center;
		border-right: 0px #000 solid;
		text-align: center;
		display: block;
		padding: 0 40px;
		min-height: 140px;
		line-height: 1.5;
	}



	/* 	セクション */
	#sec02 .wrap,
	#sec03 .wrap {
		clear: both;
		width: 100%;
		z-index: 1;
		position: relative;
	}

	#sec02 .wrap,
	#sec02 .wrap:after {
		background-color: #FFF;
	}

	#sec03 .wrap,
	#sec03 .wrap:after {
		background-color: #FFF;
	}

	#sec02 .wrap:after,
	#sec03 .wrap:after {
		content: '';
		position: absolute;
		left: 0;
		top: 0;
		z-index: -1;
		width: 100%;
		height: 100%;
	}

	#sec02 .bg,
	#sec03 .bg {
		background-repeat: no-repeat;
		background-position: top center;
		background-size: 100% auto;
		width: 100%;
		height: 0;
		padding-top: 66.6666666667%;
		position: relative;
	}

	#sec02 .bg {
		background-image: url(../img/top/sec_02bg_s.png)
	}

	#sec03 .bg {
		background-image: url(../img/top/sec_03bg_s.png)
	}

	#sec02 .wrap .txt,
	#sec03 .wrap .txt {
		padding: 10px 20px;
		color: #333;
		font-size: 1rem;
		line-height: 1.5;
		width: 100%;
		position: inherit;
		top: inherit;
		left: inherit;
		transform: inherit;
		z-index: 2;
	}


	.sec02_1,
	.sec03_1 {
		position: relative;
		top: 0px;
		margin-bottom: 0px;
	}


	.sec02_1 {
		position: relative;
		top: 0px;
		margin-bottom: 0px;
	}

	.sec03_1 {
		position: relative;
		top: 0px;
		margin-bottom: 0px;
	}

	#sec02 .flex-item:nth-child(5) {
		order: 6
	}

	#sec02 .flex-item:nth-child(6) {
		order: 5
	}

	#sec03 .flex-item:nth-child(3) {
		order: 1
	}

	#sec03 .flex-item:nth-child(6) {
		order: 5
	}


	.flex-container {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		align-items: flex-start;
		align-content: space-around;
		margin: 0 auto;
		width: 100%;
		box-sizing: border-box;

	}

	.flex-item {
		/* 	width: calc((100% - 30px) / 2); */
		width: 100%;
		position: relative;
		box-sizing: border-box;
		margin-left: 10px;
		margin-bottom: 20px;
	}

	/* .flex-item:nth-child(2n+1) {margin-left: 15px;} */
	.flex-item :first-child {
		margin-left: 0px;
	}

	.flex-item:nth-child(3n) {
		margin-right: 10px;
	}

	.flex-item>img {
		display: block;
		width: 100%;
		max-width: 100%;
		height: auto;
	}

	/* モーダル */
	.modalGreen h3,
	.modalOrange h3 {
		text-align: center;
		font-size: 20px;
		margin: 20px 0 10px 0;
	}

	.modalGreenHeader {
		padding: 0px;
	}

	.modaal-inner-wrapper {
		padding: 0px !important;
	}

	.modaal-content-container {
		padding: 20px !important
	}

	.btn_01 {
		position: absolute;
		top: 30px;
		right: 20px;
		z-index: 4;
		line-height: 1.2;
	}

	.btn_02 {
		position: absolute;
		top: 40px;
		left: 30px;
		z-index: 4;
		line-height: 1.2;
	}

	.btn_03 {
		position: absolute;
		top: 0px;
		left: 10px;
		z-index: 4;
		line-height: 1.2;
	}

	.btn_04 {
		position: absolute;
		top: 50px;
		left: 20px;
		z-index: 4;
		line-height: 1.2;
	}

	.btn_05 {
		position: absolute;
		/*
	bottom: 20px;
	left: 20px;
*/
		bottom: 5%;
		left: 2%;
		z-index: 4;
		line-height: 1.2;
	}

	.btn_06 {
		position: absolute;
		top: 20px;
		right: 30px;
		z-index: 4;
		line-height: 1.2;
	}



	/* contact 
------------------------------------------------------------*/

	.ContactMainImg {
		width: 100%;
		text-align: center;
	}

	.ContactMainImg .present {
		margin: 50px 0;
	}

	.ContactMainImg .present img {
		width: 100%;
	}

	.readBox {

		margin-left: auto !important;
		margin-right: auto !important;
		margin-bottom: 10px !important;
	}

	.btnRead {
		display: table-cell;
		margin: 2% auto 10% auto;
		padding: 5px !important;
		background: #fff;
		border: solid 2px #000;
		color: #000;
		font-size: 1em;
		font-weight: bold;
		text-align: center;
		position: relative;
		left: 0px;
		top: 0px;
		margin-bottom: 10px;
	}
}

@media screen and (max-width: 768px) {
	.sp-panel .menu01 li:nth-child(11) {
		transition: all 0.8s 1.2s ease;
	}
}