@charset "UTF-8";
/* CSS Document */
/* 仮index */
.og {
	text-align: center;
	padding-top: 10vh;
}
@media screen and (max-width: 767px) {
	/* 仮index */
	.og {
		padding-top: 25vh;
	}
	.og img {
		width: 100%;
	}
}

/* mainArea */
.mainArea {
	margin: 30px 0 40px;
}
.mainArea .main_top {
	position: relative;
}
.mainArea .main_top .inner {
	padding: 0 20px;
}
.slide01,
.slide02,
.slide03 {
	background-repeat: no-repeat;
	width: 100%;
	background-size: cover;
	background-position: center center;
	min-height: 500px;
}
.slide01 {
	background-image: url("../img/top/main_top01.jpg");
}
.slide02 {
	background-image: url(../img/top/main_top02.jpg);
}
.slide03 {
	background-image: url(../img/top/main_top03.jpg);
}
.swiper-container {
	border-radius: 25px;
}

.h1Area {
	width: 100%;
	position: absolute;
	z-index: 100;
	margin-top: -460px;
	display: flex;
	flex-direction: row-reverse;
}
.h1Area .desc {
	width: 100%;
	max-width: 1280px;
	padding: 0 20px;
	margin: 0 auto;
	display: inline-block;
	writing-mode: vertical-rl;
}
.h1Area .desc h1,
.h1Area .desc p {
	font-family: ten-mincho, serif;
	font-weight: 400;
	font-style: normal;
	color: #fff;
	text-shadow: #524842 1px 1px 6px, #524842 -1px 1px 6px, #524842 1px -1px 6px, #524842 -1px -1px 6px;
}
.h1Area .desc h1 {
	padding-right: 150px;
	font-size: 35px;
	line-height: 1.4;
}
.h1Area .desc p {
	padding-right: 20px;
	padding-top: 6px;
	font-size: 17px;
	letter-spacing: 0.15em;
}
.mainArea .main_bottom {
	max-width: 1280px;
	margin: 0 auto;
	padding: 25px 20px 30px;
}
.mainArea .main_bottom .inner {
	padding: 0 20px;
	background-image: url("../img/top/main_bottom.jpg");
	background-repeat: no-repeat;
	width: 100%;
	background-size: cover;
	background-position: center center;
	min-height: 224px;
	border-radius: 20px;
	display: flex;
	align-items: center;
}
.mainArea .main_bottom .inner .txtArea {
	width: 500px;
	height: 180px;
	padding: 20px;
	background-color: rgba(64,32,0,.3);
	display: flex;
	justify-content: center;
	flex-wrap: nowrap;
}
.mainArea .main_bottom .inner .txtArea .desc {
	display: inline-block;
	font-family: ten-mincho, serif;
	font-weight: 400;
	font-style: normal;
	color: #fff;
	writing-mode: vertical-rl;
}
.mainArea .main_bottom .inner .txtArea h2 {
	font-size: 20px;
	padding-left: 20px;
	line-height: 1.4;
	text-shadow: #524842 1px 1px 6px, #524842 -1px 1px 6px, #524842 1px -1px 6px, #524842 -1px -1px 6px;
}
.mainArea .main_bottom .inner .txtArea p {
	line-height: 1.8;
	text-shadow: #524842 1px 1px 6px, #524842 -1px 1px 6px, #524842 1px -1px 6px, #524842 -1px -1px 6px;
}

/* 共通 */
.btnArea .btn a img,
.btn02 a img,
.btn a img,
.btn img {
	width: 28px;
}
.btnArea .btn,
.btn02,
.btn {
	display: inline-block;
}
.btnArea .btn a,
.btn a {
	display: inline-block;
	padding-right: 15px;
	-webkit-transition: all 0.3s;
	-o-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
}
.btn02 a {
	display: inline-block;
	-webkit-transition: all 0.3s;
	-o-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
}
.btnArea .btn a:hover,
.btn a:hover {
	padding-right: 0;
	opacity: .7;
}
.btn02 a:hover {
	opacity: .7;
}

/* newsArea */
.newsArea {
	background-color: #d7d4ce;
}
.newsArea .news_bg {
	width: 100%;
	background-image: url("../img/top/tree.png"),url("../img/top/tree.png");
	background-repeat: no-repeat,no-repeat;
	background-position: right 10% bottom, left 10% bottom 0;
}
.newsArea .inner {
	max-width: 840px;
	margin: 0 auto;
	padding: 30px 20px;
}
.newsArea .inner h2 {
	font-family: ten-mincho, serif;
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	color: #524842;
	line-height: 1;
	padding: 13px 5px;
	position: relative;
}
.newsArea .inner h2:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #524842;
}
.newsArea .inner h2:after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #524842;
}
.newsArea .inner ul {
	padding: 15px 5px 0;
}
.newsArea .inner ul li {
	display: flex;
	justify-content: flex-start;
	flex-wrap: nowrap;
	margin-bottom: 15px;
}
.newsArea .inner ul li .data {
	font-size: 13px;
	padding-right: 15px;
}
.newsArea .inner ul li .label a {
	display: inline-block;
	text-align: center;
	font-size: 12px;
	line-height: 1;
	color: #fff;
	padding: 5px 2em;
	width: 90px;
}
.newsArea .inner ul li .label a:hover {
	background-color: #fff;
}
.newsArea .inner ul li .la01 a {
	background-color: #d36a4d;
	border: 1px solid #d36a4d;
}
.newsArea .inner ul li .la02 a {
	background-color: #d5b151;
	border: 1px solid #d5b151;
}
.newsArea .inner ul li .la04 a {
	background-color: #6bb99f;
	border: 1px solid #6bb99f;
}
.newsArea .inner ul li .la01 a:hover {
	color: #d36a4d;
}
.newsArea .inner ul li .la02 a:hover {
	color: #d5b151;
}
.newsArea .inner ul li .la04 a:hover {
	color: #6bb99f;
}
.newsArea .inner ul li .txt a {
	font-size: 13px;
	padding-left: 15px;
}
.newsArea .inner .btnArea {
	text-align: right;
}
/*hirayaArea*/
.hirayaBox01 .inner {
	padding: 100px 20px 0;
}
.hirayaBox01 .inner h1 {
	margin: 0 auto;
	text-align: center;
}
.hirayaBox01 .inner h1 img {
	max-width: 522px;
}
.hirayaBox01 .inner .desk {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}
.hirayaBox01 .inner .desk01 {
	max-width: 1100px;
	margin: 70px auto 80px;
}
.hirayaBox01 .inner .desk01 .txtBox {
	width: 52%;
}
.hirayaBox01 .inner .desk01 .txtBox p {
	font-size: 17px;
	line-height: 2;
}
.hirayaBox01 .inner .desk01 .imgBox {
	width: 44%;
	background-image: url("../img/top/hiraya_img01.webp");
	background-position: top center;
	background-repeat: no-repeat;
	background-size: cover;
  aspect-ratio: 1056 / 770;
}
.hirayaBox02 {
	padding: 0 20px;
}
.hirayaBox02 .inner {
	min-width: 90%;
	padding: 0 20px;
	background-color: #FFF;
}
.hirayaBox02 .inner .desk {
	max-width: 1100px;
	margin: 0 auto 80px;
	display: flex;
	justify-content: space-between;
  align-items: center;
	flex-wrap: wrap;
}
.hirayaBox02 .inner .desk .txtBox h2 {
	margin-bottom: 15px;
	font-size: min(4vw,18px);
	line-height: 2;
	position: relative;
}
.hirayaBox02 .inner .desk .txtBox h2:before {
	content: "";
	position: absolute;
	top: -25px;
	left: -5px;
	width: 193px;
	background-image: url("../img/top/hiraya_yane.svg");
	background-position: top left;
	background-repeat: no-repeat;
  aspect-ratio: 193 / 24;
}
.hirayaBox02 .inner .desk .txtBox p {
	font-size: 16px;
	line-height: 2;
}
.hirayaBox02 .inner .desk02 {
  flex-direction: row-reverse;
}
.hirayaBox02 .inner .desk02 .txtBox {
	width: 58%;
}
.hirayaBox02 .inner .desk02 .imgBox {
	width: 38%;
	background-image: url("../img/top/hiraya_img02.webp");
	background-position: top center;
	background-repeat: no-repeat;
	background-size: cover;
  aspect-ratio: 856 / 696;
}
.hirayaBox02 .inner .desk03 .txtBox {
	width: 51%;
}
.hirayaBox02 .inner .desk03 .imgBox {
	width: 45%;
	background-image: url("../img/top/hiraya_img03.webp");
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: cover;
  aspect-ratio: 1104 / 696;
}
.hirayaBox03 .inner {
	margin: 0 auto 80px;
	padding: 0 20px;
}
.hirayaBox03 .inner .desk {
	max-width: 1100px;
	margin: 0 auto 40px;
	display: flex;
	justify-content: space-between;
  align-items: center;
	flex-wrap: wrap;
}
.hirayaBox03 .inner .desk .txtBox p {
	font-size: 16px;
	line-height: 2;
}
.hirayaBox03 .inner .desk04 {
	padding-top: 50px;
}
.hirayaBox03 .inner .desk04 .txtBox {
	width: 100%;
	padding-top: 40px;
	text-align: center;
}
.hirayaBox03 .inner .desk04 .imgBox {
	width: 100%;
	background-image: url("../img/top/hiraya_img04.webp");
	background-position: top center;
	background-repeat: no-repeat;
	background-size: cover;
  aspect-ratio: 2204 / 556;
}
.hirayaBox03 .inner .btn {
	margin: 30px auto;
	text-align: center;
	display: block;
}
.hirayaBox03 .inner .btn a {
	min-width: 300px;
	display: inline-block;
	padding: 10px 2.5em;
	color: #FFF;
	border-radius: 25px;
	background-color: #F98000;
}

/* contentArea01 */
.contentArea01 .inner {
	padding: 60px 20px;
	background-image: url("../img/top/map.svg");
	background-repeat: no-repeat;
	background-position: left top -30px;
	background-size: 340px;
}
.contentArea01 .inner ul {
	display: flex;
	justify-content: center;
	gap: 30px;
	flex-wrap: nowrap;
}
.contentArea01 .inner ul li {
	width: 308px;
}
.contentArea01 .inner ul li a {
	display: block;
}
.contentArea01 .inner ul li a:hover {
	opacity: .7;
}
.contentArea01 .inner ul li a .h1Area02 {
	display: flex;
	justify-content: center;
}
.contentArea01 .inner ul li a .h1Area02 h1 {
	min-height: 210px;
	font-size: 20px;
	line-height: 1.4;
	display: inline-block;
	font-family: ten-mincho, serif;
	font-weight: 400;
	font-style: normal;
	writing-mode: vertical-rl;
}
.contentArea01 .inner ul li a .img {
	padding-bottom: 15px;
}
.contentArea01 .inner ul li a h2 {
	font-size: 16px;
	line-height: 1;
	font-weight: 600;
	padding-bottom: 10px;
}
.contentArea01 .inner ul li a .txt {
	min-height: 50px;
}
.contentArea01 .inner ul li a .btnArea {
	padding-top: 10px;
	text-align: right;
}

/* contentArea02 */
.contentArea02 {
	background-color: #d7d4ce;
}
.contentArea02 .inner {
	padding: 60px 20px;
}
.contentArea02 .inner .lifestyleArea .l_top .img {
	text-align: center;
}
.contentArea02 .inner .lifestyleArea .l_top .img img {
	width: 89px;
}
.contentArea02 .inner .lifestyleArea .l_bottom{
	margin: 50px auto 60px;
	background-image: url(../img/top/totonoe.jpg);
	background-repeat: no-repeat;
	background-position: top center;
	background-size: cover;
	border-radius:16px;
}
.contentArea02 .inner .lifestyleArea .l_bottom .l_box{
	padding: 0 20px;
	min-height: 750px;
	position: relative;
}
.contentArea02 .inner .lifestyleArea .l_bottom a {
	display: block;
}
.contentArea02 .inner .lifestyleArea .l_bottom a:hover {
	opacity: .7;
}
.contentArea02 .inner .lifestyleArea .l_bottom .desc {
	position: absolute;
	left: 22%;
	top: 20%;
}
.contentArea02 .inner .lifestyleArea .l_bottom .desc h1 {
	font-size: 26px;
	font-family: ten-mincho, serif;
	font-weight: 400;
	font-style: normal;
	writing-mode: vertical-rl;
	text-align: left;
	color: #fff;
	text-shadow: #524842 1px 1px 6px, #524842 -1px 1px 6px, #524842 1px -1px 6px, #524842 -1px -1px 6px;
}
.contentArea02 .inner .lifestyleArea .l_bottom .desc .btn {
	padding-top: 12px;
	padding-left: 8px;
}
.contentArea02 .inner ul {
	display: flex;
	justify-content: center;
	gap: 30px;
	flex-wrap: nowrap;
}
.contentArea02 .inner ul li {
	width: 308px;
}
.contentArea02 .inner ul li a {
	display: block;
}
.contentArea02 .inner ul li a:hover {
	opacity: .7;
}
.contentArea02 .inner ul li a .img {
	padding-bottom: 15px;
}
.contentArea02 .inner ul li a .txt {
	min-height: 50px;
}
.contentArea02 .inner ul li a h2 {
	font-size: 16px;
	line-height: 1;
	font-weight: 600;
	padding-bottom: 10px;
}
.contentArea02 .inner ul li a .btnArea {
	padding-top: 10px;
	text-align: right;
}
@media screen and (max-width: 1420px) {
/* hirayaArea */
	.hirayaBox02 .inner {
		min-width: 100%;
	}
}

@media screen and (max-width: 1000px) {
	.mainArea .main_top .inner {
		margin-top: 100px;
	}
	.h1Area .desc h1 {
		padding-right: 120px;
		font-size: 35px;
		line-height: 1.4;
	}
	.contentArea01 .inner ul li,
	.contentArea02 .inner ul li {
		width: 30%;
	}

/* hirayaArea */
.hirayaBox01 .inner {
		padding-top: 80px;
	}
	.hirayaBox01 .inner .desk01 {
		margin: 50px auto 60px;
	}
	.hirayaBox01 .inner .desk01 .txtBox p {
		font-size: min(3.5vw,15px);
	}
	.hirayaBox02 .inner .desk {
		margin: 0 auto 60px;
	}
	.hirayaBox02 .inner .desk .txtBox p {
		font-size: min(3.4vw,14px);
	}
	.hirayaBox03 .inner {
		margin: 0 auto 80px;
	}
	.hirayaBox03 .inner .desk .txtBox p {
		font-size: min(3.4vw,14px);
	}
	.hirayaBox03 .inner .desk04 {
		padding-top: 40px;
	}
	.hirayaBox03 .inner .desk04 .txtBox {
		padding-top: 30px;
	}
}

@media screen and (max-width: 767px) {
	.slide01,
	.slide02,
	.slide03,
	.slide04{
		min-height: 500px;
		background-position: bottom right;
	}
	.slide01 {
		background-image: url("../img/top/main_top01_sp.jpg");
	}
	.slide02 {
		background-image: url(../img/top/main_top02_sp.jpg);
	}
	.slide03 {
		background-image: url(../img/top/main_top03_sp.jpg);
	}
	.mainArea .main_top .inner {
		padding: 0 5vw;
	}
	.swiper-container {
		border-radius: 15px;
	}
	.mainArea .main_bottom {
		width: 100%;
		padding: 15px 5vw 20px;
	}
	.mainArea .main_bottom .inner {
		padding: 0 3vw;
		background-image: url("../img/top/main_bottom_sp.jpg");
		width: 100%;
		background-position: top right;
		min-height: 200px;
		border-radius: 12px;
		justify-content: center;
	}
	.h1Area .desc {
		width: inherit;
		max-width: inherit;
		padding: 0 0;
		margin: 0 auto;
		display: flex;
		writing-mode: vertical-rl;
		justify-content: center;
		align-items: center;
	}
	.h1Area .desc h1 {
		padding-right: 0;
		font-size: 22px;
		line-height: 1;
		font-weight: bold;
	}
	.h1Area .desc p {
		padding-right: 8px;
		padding-top: 3px;
		font-size: 15px;
		letter-spacing: 0.25em;
	}
	.mainArea .main_bottom .inner .txtArea {
		width: 100%;
	}
	.h1Area {
		margin-top: -410px;
		justify-content: center;
	}
	.newsArea .news_bg {
		background-image: url(../img/top/tree.png);
		background-repeat: no-repeat;
		background-position: right 10% bottom;
		background-size: 60%;;
	}
	.newsArea .inner {
		width: 100%;
		margin: 0 auto;
		padding: 30px 8vw;
	}
	.newsArea .inner ul li {
		display: block;
	}
	.newsArea .inner ul li .data {
		text-align: left;
		padding-right: 0;
		padding-bottom: 2px;
	}
	.newsArea .inner ul li .txt {
		line-height: 1.2;
		padding-top: 5px;
		text-align: left;
	}
	.newsArea .inner ul li .txt a {
		padding-left: 0;
	}
	.contentArea01 .inner {
		padding: 50px 8vw 10px;
		background-size: 300px;
	}
	.contentArea01 .inner ul {
		display: block;
	}
	.contentArea01 .inner ul li {
		width: 100%;
		margin-bottom: 40px;
	}
	.contentArea01 .inner ul li a .img {
		text-align: center;
		width: 270px;
		margin: 0 auto;
	}
	.contentArea01 .inner ul li a .h1Area02 h1 {
		min-height: inherit;
		font-size: 20px;
		line-height: 1.2;
		padding-bottom: 10px;
	}
	.contentArea01 .inner ul li a h2 {
		text-align: center;
	}
	.contentArea01 .inner ul li a .txt {
		min-height: inherit;
		width: 270px;
		margin: 0 auto;
	}
	.contentArea01 .inner ul li a .btnArea {
		width: 270px;
		margin: 0 auto;
	}
	.contentArea02 .inner {
		padding: 50px 8vw;
	}
	.contentArea02 .inner .lifestyleArea .l_top .img img {
		width: 70px;
	}
	.contentArea02 .inner .lifestyleArea .l_bottom .desc h1{
		font-size: 20px;
	}
	.contentArea02 .inner .lifestyleArea .l_bottom{
		background-image: url(../img/top/totonoe_sp.jpg);
		padding: 0;
		background-position: bottom right;
	}
	.contentArea02 .inner .lifestyleArea .l_bottom .l_box {
		width: 100%;
		min-height: 350px;
		padding: 0 0;
		position: static;
	}
	.contentArea02 .inner .lifestyleArea .l_bottom .desc {
		position: static;
		display: flex;
		align-items: center;
    justify-content: center;
    flex-direction: column;
		padding-top: 90px;
	}
	.contentArea02 .inner .lifestyleArea .l_bottom .desc .btn {
		padding-top: 8px;
    padding-left: 3px;
	}
	.contentArea02 .inner {
		padding: 50px 5vw 10px;
	}
	.contentArea02 .inner ul {
		display: block;
	}
	.contentArea02 .inner ul li {
		width: 100%;
		margin-bottom: 40px;
	}
	.contentArea02 .inner ul li a .img {
		text-align: center;
		width: 270px;
		margin: 0 auto;
	}
	.contentArea02 .inner ul li a .h1Area02 h1 {
		min-height: inherit;
		font-size: 20px;
		line-height: 1;
		padding-bottom: 10px;
	}
	.contentArea02 .inner ul li a h2 {
		text-align: center;
	}
	.contentArea02 .inner ul li a .txt {
		min-height: inherit;
		width: 270px;
		margin: 0 auto;
	}
	.contentArea02 .inner ul li a .btnArea {
		width: 270px;
		margin: 0 auto;
	}

/* hirayaArea */
	.hirayaBox01 .inner {
		padding: 60px 6vw 0;
	}
	.hirayaBox01 .inner h1 img {
		max-width: 400px;
	}
	.hirayaBox01 .inner .desk01 {
		margin: 30px auto 40px;
		display: block;
	}
	.hirayaBox01 .inner .desk01 .txtBox {
		width: 100%;
		max-width: 372px;
		margin: 0 auto;
		padding-bottom: 30px;
	}
	.hirayaBox01 .inner .desk01 .imgBox {
		max-width: 600px;
		width: 100%;
		margin: 0 auto;
	}
	.hirayaBox02 .inner .desk {
		margin: 0 auto 50px;
		padding-top: 50px;
		display: block;
	}
	.hirayaBox02 .inner .desk02 .txtBox {
		max-width: 460px;
		width: 100%;
		margin: 0 auto;
		padding-bottom: 30px;
	}
	.hirayaBox02 .inner .desk02 .imgBox {
		max-width: 460px;
		width: 100%;
		margin: 0 auto;
	}
	.hirayaBox02 .inner .desk03 .txtBox {
		max-width: 460px;
		width: 100%;
		margin: 0 auto;
		padding-bottom: 30px;
	}
	.hirayaBox02 .inner .desk03 .imgBox {
		max-width: 460px;
		width: 100%;
		margin: 0 auto;
	}
	.hirayaBox03 .inner .desk04 {
		padding-top: 20px;
	}
	.hirayaBox03 .inner .desk04 .imgBox {
		background-position: bottom center;
		aspect-ratio: 2204 / 624;
	}
	.hirayaBox03 .inner .desk .txtBox p {
		text-align: left;
	}
}

@media screen and (max-width: 500px) {
	.mainArea .main_bottom .inner .txtArea h2 {
		padding-left: 5px;
		line-height: 1;
	}
	.mainArea .main_bottom .inner .txtArea p {
		line-height: 1.3;
		font-size: 3.4vw;
	}
	.mainArea .main_bottom .inner .txtArea {
		padding: 25px 15px;
	}

/* hirayaArea */
.hirayaBox01 .inner h1 img {
		max-width: 270px;
	}
	.hirayaBox01 .inner .desk01 .txtBox p {
		letter-spacing: -0.02em;
	}
}

@media screen and (max-width: 380px) {
/* hirayaArea */
.hirayaBox01 .inner .desk01 .txtBox p {
		font-size: 3.4vw;
		letter-spacing: -0.02em;
	}
	.hirayaBox03 .inner .btn a {
		width: 100%;
		min-width: 100%;
}
	.contentArea01 .inner ul li a .img {
		width: 240px;
	}
	.contentArea01 .inner ul li a .txt {
		width: 240px;
	}
	.contentArea01 .inner ul li a .btnArea {
		width: 100%;
		margin: 0 auto;
	}
}



.mainArea .main_top .inner {
	position: relative;
}

.main_top_img {
	transition: 0.3s;
}

@media screen and (min-width: 768px) {
	.pc-none {
		display: none;
	}

	.sm-none {
		display: block;
	}

	img.main_top_img {
		position: absolute;
		bottom: 15px;
		right: 35px;
		z-index: 10;
		width: 450px;
	}

	.main_top_link:hover .main_top_img {
		opacity: 0.8;
	}
}

@media screen and (max-width: 767px) {
	.pc-none {
		display: block;
	}

	.sm-none {
		display: none;
	}

	img.main_top_img {
		position: relative;
		width: 90%;
		margin: 50px auto;
	}
}

@media screen and (min-width: 768px) {
	.hiraya-link {
		margin: 80px auto;
		text-align: center;
	}
}

.hiraya-link a {
	display: inline-block;
}