/*----------------------
1030px = 狭いPC
767px = sp/tab
480ox = sp
----------------------*/

/* ============================ 
header
============================ */
#indexhead_wrap{
	border-radius: 8px 8px 0 0;
	-moz-border-radius: 8px 8px 0 0;
	-webkit-border-radius: 8px 8px 0 0;
	position: relative;
}
#indexhead_wrap_inner{
	padding: 1.25rem 5% .75rem;
}
#index_gmenu{
	position: relative;
	padding: 0 5%;
}
	@media screen and (max-width: 1030px) {
		#indexhead_wrap{
			border-radius: 0;
			-moz-border-radius: 0;
			-webkit-border-radius: 0;
		}
	}
	@media screen and (max-width: 767px) {
		#indexhead_wrap_inner{
			padding-top:10px;
		}
	}
	@media screen and (max-width: 480px) {
		#indexhead_wrap_inner{
			padding: 1em 2% .5em;
		}
	}

/* firstview
------------------------------*/
#fv{
	position: relative;
	z-index: 0;
}
#fv .pc{
	display: block;
}
#fv .sp{
	display: none;
}
#fv a.btn-recruit{
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	width: 100px;
	height: 100px;
	display: block;
	z-index: 100!important;
	cursor: pointer;
	box-shadow: 0 8px 8px 0 rgba(0, 0, 0, .2);
	border-radius: 50%;
}
#fv a.btn-recruit:hover{
	box-shadow: 0 8px 8px 0 rgba(0, 0, 0, .5);
}
	@media screen and (max-width: 767px) {
		#fv a.btn-recruit{
			width: 70px;
			height: 70px;
		}
	}
	@media screen and (max-width: 480px) {
		#fv a.btn-recruit{
			top: auto;
			right: 1rem;
			bottom: 1.5rem;
		}
		#fv .pc{
			display: none;
		}
		#fv .sp{
			display: block;
		}
	}

/* ============================ 
contents
============================ */
#contents{
	margin-top: 3.75rem;
	background: #daeab3;
	position: relative;
}
#contents:before{
	width: 100%;
	height: 45px;
	border-radius: 50% / 100% 100% 0 0;
	background: #daeab3;
	position: absolute;
	top: calc(-45px + 1px);
	left: 0;
	content: "";
	z-index: 0;
}
	@media screen and (max-width: 650px) {
		#contents{
			margin-top: 45px;
		}
	}


/* おしらせ ↓↓↓↓↓↓　2026年1月切替たら削除OK*/
.oshisase{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	margin-top: 1.75rem;
	margin-left: 4.5%;
	margin-right: 4.5%;
}
.oshisase .oshirase-tit{
	width: 185px;
	color: #7f9100;
	font-size: 1.46666666667em;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 700;
  letter-spacing: 3px;
  line-height: 1.0;
	text-align: center;
}
.oshisase .entry{
	width: calc(100% - 185px);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.oshisase .entry li{
	width: calc((100% / 2) - .5em);
	background: #faf8e3;
	border-radius: .5em;
	padding: 1.25em 1.5em 1.75em;
	position: relative;
}
.oshisase .entry li div{
	color: #7f9100;
	font-family: 'Roboto', sans-serif;
}
.oshirase-tit .img{
	width: 64px;
	height: auto;
	margin: 0 auto;
}
	@media screen and (max-width: 767px) {
		.oshisase .oshirase-tit{
			width: 140px;
		}
		.oshisase .entry{
			width: calc(100% - 140px);
		}
	}
	@media screen and (max-width: 650px) {
		.oshisase {
			margin-left: 6.5%;
			margin-right: 6.5%;
		}
		.oshisase .oshirase-tit{
			width: 100%;
		}
		.oshisase .entry{
			width: 100%;
		}
		.oshisase .entry li{
			width: 100%;
			margin-top: .5em;
		}
		.oshisase .oshirase-tit{
			position: relative;
			font-size: 1.5rem;
			margin-bottom: .5rem;
			top: -.75em;
		}
		.oshirase-tit .img{
			display: none;
		}
	}
/* おしらせ ↑↑↑↑↑↑↑↑↑　2026年1月切替たら削除OK*/

/*　おしらせカレンダー　↓↓↓↓↓↓↓↓↓↓↓　*/
.news-calendar{
	margin-left: 4.5%;
	margin-right: 4.5%;
	padding-top: 1em;
	display: flex;
	justify-content: space-between;
}
.tit-oshirase{
	text-align: center;
	width: 130px;
	font-size: 1.4em;
	font-family: "Zen Maru Gothic", serif;
	font-weight: 700;
	color: #7f9100;
}
.bloglist{
	border-radius: 1em;
	width: calc(100% - 130px - 130px - 1em);
}
.link-calendar{
	width: 130px;
	font-family: "Zen Maru Gothic", serif;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	background-color: #9ec93b;
	background-image: url(../images/index/bg-calendar.png);
	background-repeat: no-repeat center;
	background-size: cover;
	border-radius: 1em;
	transition: .5s all;
}
.link-calendar:hover{
	background-color: #8fc01c;
}
	@media screen and (max-width: 650px) {
		.news-calendar{
			flex-wrap: wrap;
			padding-top: 0;
		}
		.tit-oshirase{
			display: none;
		}
		.bloglist{
			width: 100%;
			margin-top: .5em;
		}
		.link-calendar{
			width: 100%;
			max-width: 200px;
			margin: 1.25em auto 0;
		}
	}


/*装飾*/
.tit-oshirase img{
	display: block;
	margin: 0 auto;
	width: 4.75rem;
}
.link-calendar img{
	display: block;
	margin: 0 auto .25em;
	width: 2.75rem;
}
	@media screen and (max-width: 650px) {
		.tit-oshirase img{
			display: inline-block;
			width: 1em;
		}
		.link-calendar img{
			display: inline-block;
			width: 2em;
			margin-right: 1em;
		}
	}

.bloglist li{
	width: 100%;
	padding: 1em 1.5em;
	display: flex;
	flex-wrap: wrap;
	background: #faf8e3;
	border-radius: 1em;
	margin-top: 4px;
	line-height: 1.5;
}
.bloglist li div{
	width: 6em;
	font-size: 0.8666666em;
	font-family: 'Roboto', sans-serif;
	color: #7f9100;
	line-height: 2;
}
.bloglist li a{
	width: calc(100% - 6em);
}
.link-calendar a{
	width: 100%;
	display: block;
	font-size: 1.06666666667em;
	font-weight: 700;
	color: #fff;
	text-decoration: none;
}
	@media screen and (max-width: 650px) {
		.link-calendar a{
			display: flex;
			flex-wrap: wrap;
			align-items: center;
			padding: 1.25em 1em;
		}
	}

/*　おしらせカレンダー ↑↑↑↑↑↑↑↑↑　*/

.leaf-line{
	width: 100%;
	aspect-ratio: 86 / 7;
	background: url(../images/index/leaf-line.png) repeat-x center;
	background-size:auto 101%;
	margin-top: 2rem;
}
	@media screen and (max-width: 650px) {
		.leaf-line{
			aspect-ratio: 235 / 42;
			background-repeat: no-repeat;
			background-size: contain;
			margin-top: 2rem;
		}
	}

/*other*/
.other{
	margin: 0 4.5%;
	padding: 2rem 0 3rem;
}
.other a.btn_other{
	background: #2c6b50;
	color: #fff;
	padding: 1.25em .75em;
	display: block;
	font-size: 1.1333333333em;
	line-height: 1.3;
  font-family: "Zen Maru Gothic", serif;
	font-weight: 600;
	text-align: center;
	letter-spacing: .05em;
	border-radius: .45em;
	text-decoration: none;
	position: relative;
}
.other a.btn_other:before{
	position: absolute;
	top: 50%;
	left: 50%;
	width: calc(100% - .75rem);
	height: calc(100% - .75rem);
	border: 1px solid #87ab9c;
	border-radius: .25em;
	transform: translate(-50%,-50%);
	content: "";
}
.other a.btn_other:after {
  position: absolute;
  top: 50%;
  right: .35em;
  content: '';
  margin-top: -7px;
  border: 9px solid transparent;
  border-top-width: 7px;
  border-bottom-width: 7px;
  border-left-color: #fff;
  transition: all .2s;
}
.other a.btn_other:hover::after {
  right: -.05em;
}
.other a.btn_other span{
	font-weight: 600;
}
	@media screen and (max-width: 400px) {
		.other a.btn_other{
			font-size: 1.07em;
		}
		.other a.btn_other span{
			display: block;
		}
	}

/* img アニメーション */
	@keyframes infinity {
		from {
			transform: translateX(0);
		}
		to {
			transform: translateX(-100%);
		}
	}
.img-infinity {
	display: flex;
	overflow: hidden;
	margin-top: 1.5rem;
}
.img-infinity-list {
  display: flex;
  list-style: none;
  padding: 0;
  animation: infinity 45s infinite linear 0.5s both;
}
.img-infinity-list .item {
	width: 320px;
  aspect-ratio: 4 / 3;
  margin: 0 .325em;
}
.img-infinity-list .tate{
	width: 192px;
  aspect-ratio: 4 / 5;
}
.img-infinity-list img{
	border-radius: .5em;
}
	@media screen and (max-width: 480px) {
		.img-infinity-list .item {
			width: 240px;
		}
		.img-infinity-list .tate{
			width: 143px;
		}
	}
