@charset "UTF-8";
/* --------------------------------------------------------- slideshow */
#slideshow {
	position: relative;
}
.slider{
	opacity: 0;
	transition: 3s;
}
.slick-initialized{
	opacity: 1
}
#emergency {
	position: absolute;
	left: 50%;
	bottom: 8%;
	transform: translateX(-700px);
	width: 640px;
	height: 52px;
	border-radius: 26px;
	background-color: #057149;
	color: #fff;
	z-index: 999997;
	pointer-events: none;
	transition: all .3s ease;
}
#emergency:hover {
	background-color: #5cc596;
	transition: all .3s ease;
}
#emergency dl {
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-align: center;
	-webkit-align-items: center;
	align-items: center;
	width: 100%;
}
#emergency dt {
	font-size: 0.75rem;
	line-height: 28px;
	margin: 12px 25px;
	border-right: 1px solid #548e72;
	box-sizing: border-box;
	width: 146px;
	font-weight: bold;
	letter-spacing: 0.135em;
	white-space: nowrap;
}
#emergency dd {
	font-size: 1rem;
	line-height: 52px;
	padding: 0 0 0 25px;
	box-sizing: border-box;
	width: calc(100% - 146px);
}
#emergency dd a {
	color: #fff;
	display: block;
	pointer-events: auto;
	transition: all .3s ease;
	padding-right: 49px;
	position: relative;
}
#emergency dd a:after {
	position: absolute;
	top: 50%;
	right: 30px;
	transform: translateY(-50%);
	content: url(../images/icon_arrow.png);
	transition: all .3s ease;
}
#emergency dd a:hover:after {
	right: 20px;
	transition: all .3s ease;
}
#slideshow figure {
	position: absolute;
	right: 0;
	top: 0;
	width: 33.75%;
	z-index: 99997;
	pointer-events: none;
}
@media screen and (max-width: 1399px) {
	#emergency {
		left: 5%;
		transform: translateX(0px);
	}
}
@media screen and (max-width: 767px) {
	#slideshow figure {
		display: none;
	}
	#emergency {
		position: relative;
		left: auto;
		bottom: auto;
		transform: translateX(0);
		width: 100%;
		height: auto;
		border-radius: 0;
	}
	#emergency dl {
		-ms-flex-align: start;
		-webkit-align-items: flex-start;
		align-items: flex-start;
		padding: 10px 0;
	}
	#emergency dt {
		line-height: 24px;
		padding: 0 25px;
		margin: 0;
		border-right: 0;
		box-sizing: border-box;
		width: 146px;
		font-weight: bold;
		letter-spacing: 0.135em;
		white-space: nowrap;
	}
	#emergency dd {
		line-height: 1.5em;
		border-left: 1px solid #548e72;
	}
	#emergency dd a:after {
		right: 10px;
	}
	#emergency dd a:hover:after {
		right: 10px;
	}
}
@media screen and (max-width: 479px) {
	#slideshow img {
		width: 100%;
		height: 120vw;
		object-fit: cover;
	}
	#emergency dl {
		display: block;
	}
	#emergency dt {
		width: 100%;
	}
	#emergency dd {
		width: 100%;
		border-left: 0;
	}
}

/* --------------------------------------------------------- intro */
#intro {
	position: relative;
}
#intro .inner {
	position: relative;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-pack: end;
	-webkit-justify-content: flex-end;
	justify-content: flex-end;
}
#intro .intro_leaf01 {
	position: absolute;
	top: 0;
	width: 100%;
	height: 525px;
	overflow: hidden;
	pointer-events: none;
	background-image: url(../images/intro_leaves.png);
	background-position: left top;
	background-repeat: no-repeat;
	z-index: -1;
}
#intro .left {
	position: absolute;
	top: 125px;
	left: 0;
	z-index: 50;
	width: 60%;
	max-width: 750%;
}
#intro .left h2 {
	font-family: "kosugimaru", sans-serif;
	color: #444;
	font-size: 1.625rem;
	font-weight: normal;
	color: #5CC596;
}
#intro .left h3 {
	margin-bottom: 45px;
	font-weight: bold;
	font-size: 1rem;
}
#intro .left p {
	letter-spacing: 0.05em;
	line-height: 2.25em;
}
#intro figure {
	position: relative;
	width: 650px;
	right: -100px;
}
#intro svg {
	position: relative;
	z-index: 2;
}
#intro .leaf01 {
	position: absolute;
	top: 5px;
	right: 0;
	width: 319px;
	height: 602px;
	z-index: 1;
}
#intro .leaf02 {
	position: absolute;
	top: 410px;
	left: 200px;
	width: 283px;
	height: 375px;
	z-index: 3;
}
@media screen and (max-width: 1924px) {
	#intro .intro_leaf01 {
		background-position: calc(50% - 850px) top;
	}
}
@media screen and (max-width: 1599px) {
	#intro .inner {
		width: 95%;
		margin: 0 0 0 auto;
	}
	#intro .left {
		width: calc(100% - 650px);
		position: relative;
		top: auto;
		padding-top: 125px;
	}
	#intro figure {
		right: auto;
	}
}
@media screen and (max-width: 1199px) {
	#intro .left {
		width: 50%;
		margin-bottom: 100px;
	}
	#intro figure {
		width: 50%;
	}
	#intro .leaf01 {
		width: 49%;
		height: auto;
	}
	#intro .img_intro {
		width: 89%;
	}
	#intro .leaf02 {
		width: 43.5%;
		height: auto;
		top: 43%;
		left: 30%;
	}
}
@media screen and (max-width: 999px) {
	#intro .inner {
		display: block;
		width: 90%;
		margin: 0 auto;
	}
	#intro .left {
		width: 100%;
		margin-bottom: 0;
	}
	#intro figure {
		width: 100%;
		max-width: 650px;
		margin-left: auto;
	}
	#intro .leaf02 {
		width: 30%;
		top: 60%;
		left: 50%;
	}
}
@media screen and (max-width: 479px) {
	#intro svg {
		z-index: 3;
	}
	#intro .leaf02 {
		z-index: 2;
	}
}

/* --------------------------------------------------------- news */
#top_news {
	position: relative;
	z-index: 10;
	margin-bottom: 115px;
	top: -20px;
}
#top_news .leaf {
	position: absolute;
	bottom: -120px;
	left: calc(50% - 858px);
	width: 252px;
	height: 298px;
	background: url(../images/news_leaf.png) center center no-repeat;
}
#top_news .inner {
	position: relative;
	background: #fff;
	border-radius: 40px;
	border: 1px solid #E8F1EB;
	z-index: 2;
}
#top_news h2 {
	font-weight: normal;
	text-align: center;
	font-family: "kosugimaru", sans-serif;
	letter-spacing: 0.1em;
	font-size: 1.625rem;
	margin-bottom: 65px;
}
#top_news h2 figure {
	width: 50px;
	height: 45px;
	margin: 0 auto;
	transform: translateY(-20px);
}
#top_news h2 figure img {
	vertical-align: top;
}
#top_news h2 span {
	font-family: "Anago-Thin", sans-serif;
	font-weight: 100;
	color: #057149;
	font-size: 0.75rem;
	display: block;
	letter-spacing: 0.2em;
}
#top_news ul {
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	padding: 0 35px 35px 35px;
}
#top_news li {
	width: calc(100% / 3);
	box-sizing: border-box;
}
#top_news li:first-of-type,
#top_news li:nth-of-type(2) {
	border-right: 1px solid #E8F1EB;
}
#top_news li.nolink {
	color: #444;
	padding: 30px 50px;
	letter-spacing: 0.05em;
	position: relative;
}
#top_news li a {
	display: block;
	color: #444;
	padding: 30px 50px;
	letter-spacing: 0.05em;
	position: relative;
}
#top_news li a:hover {
	background-color: #EEFFF3;
}
#top_news li a:after {
	content: url(../images/arrow_green.svg);
	width: 28.5px;
	height: 6px;
	position: absolute;
	bottom: 30px;
	right: 20px;
	vertical-align: top;
	transition: all .3s ease;
}
#top_news li a:hover:after {
	right: 10px;
	transition: all .3s ease;
}
#top_news li time {
	display: block;
	color: #5CC596;
	font-size: 0.875rem;
	font-weight: bold;
	font-family: "Anago-Thin", sans-serif;
}
@media screen and (max-width: 1399px) {
	#top_news ul {
		padding: 0 25px 25px 25px;
	}
	#top_news li a {
		padding: 20px 30px;
	}
}
@media screen and (max-width: 999px) {
	#top_news h2 {
		margin-bottom: 40px;
	}
}
@media screen and (max-width: 767px) {
	#top_news ul {
		display: block;
	}
	#top_news li {
		width: 100%;
	}
	#top_news li:first-of-type,
	#top_news li:nth-of-type(2) {
		border-bottom: 1px solid #E8F1EB;
		border-right: 0;
	}
}
@media screen and (max-width: 479px) {
	#top_news ul {
		padding: 0 15px 15px 15px;
	}
	#top_news li a {
		padding: 20px 20px;
	}
}
/* --------------------------------------------------------- bringup */
#top_bringup {
	padding: 100px 0 0 0;
	background: url(../images/bg.png);
}
#top_bringup h2 {
	font-weight: normal;
	text-align: center;
	font-family: "kosugimaru", sans-serif;
	letter-spacing: 0.1em;
	font-size: 1.625rem;
	margin-bottom: 95px;
	transform: translateY(-100px);
}
#top_bringup h2 figure {
	width: 55px;
	height: 40px;
	margin: 0 auto;
	transform: translateY(-20px);
}
#top_bringup h2 figure img {
	vertical-align: top;
}
#top_bringup h2 span {
	font-family: "Anago-Thin", sans-serif;
	font-weight: 100;
	color: #057149;
	font-size: 0.75rem;
	display: block;
	letter-spacing: 0.2em;
}
#top_bringup section {
	transform: translateY(-100px);
	background-color: #fff;
	border-radius: 40px;
	width: 90%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 50px 60px;
	box-sizing: border-box;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-pack:justify;
	-webkit-justify-content: space-between;
	justify-content:space-between;
}
#top_bringup section figure {
	width: 55%;
	margin-left: -150px;
}
#top_bringup section figure img {
	border-radius: 40px;
}
#top_bringup section div {
	width: 55%;
	letter-spacing: 0.05em;
	line-height: 2.25em;
}
#top_bringup div h3 {
	color: #5CC596;
	font-size: 1.5rem;
	margin-bottom: 20px;
}
#top_bringup section .btn {
	width: 100%;
}
#top_bringup section .btn a {
	display: block;
	width: 204px;
	height: 50px;
	background-color: #5cc596;
	margin: 0 0 0 auto;
	line-height: 50px;
	color: #fff;
	font-family: "kosugimaru", sans-serif;
	border-radius: 25px;
	text-align: center;
	transition: all .3s ease;
	background: url(../images/icon_arrow.png) no-repeat #5cc596;
	background-position: 155px center;
}
#top_bringup section .btn a:hover {
	background: url(../images/icon_arrow.png) no-repeat #9cd10b;
	background-position: 165px center;
}
@media screen and (max-width: 1399px) {
	#top_bringup section figure {
		width: 53%;
		margin-left: -10%;
	}
	#top_bringup section div {
		width: 53%;
	}	
}
@media screen and (max-width: 999px) {
	#top_bringup h2 {
		margin-bottom: 40px;
	}
	#top_bringup section {
		display: block;
	}
	#top_bringup section figure {
		width: 100%;
		max-width: 600px;
		margin: 0 auto 50px auto;
	}
	#top_bringup section div {
		width: 100%;
	}	
}
@media screen and (max-width: 767px) {
	#top_bringup section {
		padding: 30px 40px;
		width: 96%;
	}
}
@media screen and (max-width: 479px) {
	#top_bringup section .btn a {
		margin: 0 auto;
	}
}
/* --------------------------------------------------------- support */
#top_support {
	background: url(../images/support_leaf02.png) right top no-repeat;
	position: relative;
	margin-bottom: 150px;
}
#top_support .support_leaf01 {
	width: 266px;
	height: 270px;
	position: absolute;
	top: 0;
	left: calc(50% - 735px);
	background: url(../images/support_leaf01.png) center center no-repeat;
	z-index: 50;
}
#top_support h2 {
	font-weight: normal;
	text-align: center;
	font-family: "kosugimaru", sans-serif;
	letter-spacing: 0.1em;
	font-size: 1.625rem;
	margin-bottom: 95px;
}
#top_support h2 figure {
	width: 55px;
	height: 40px;
	margin: 0 auto;
	transform: translateY(-20px);
}
#top_support h2 figure img {
	vertical-align: top;
}
#top_support h2 span {
	font-family: "Anago-Thin", sans-serif;
	font-weight: 100;
	color: #057149;
	font-size: 0.75rem;
	display: block;
	letter-spacing: 0.2em;
}
#top_support .slider02 {
	margin-bottom: 50px;
}
#top_support .slider02:after {
	position: absolute;
	right: 0;
	bottom: -220px;
	content: url(../images/support_leaf03.png);
	width: 176px;
	height: 292px;
	z-index: 50;
}
#top_support section {
	width: 90%;
	max-width: 800px;
	margin: 0 auto;
	letter-spacing: 0.05em;
	line-height: 2.25em;
	font-size: 1.125rem;
	position: relative;
	z-index: 51;
}
#top_support section .btn {
	width: 100%;
	margin-top: 20px;
}
#top_support section .btn a {
	display: block;
	width: 204px;
	height: 50px;
	background-color: #5cc596;
	margin: 0 0 0 auto;
	line-height: 50px;
	color: #fff;
	font-family: "kosugimaru", sans-serif;
	border-radius: 25px;
	text-align: center;
	transition: all .3s ease;
	background: url(../images/icon_arrow.png) no-repeat #5cc596;
	background-position: 155px center;
}
#top_support section .btn a:hover {
	background: url(../images/icon_arrow.png) no-repeat #9cd10b;
	background-position: 165px center;
}
@media screen and (max-width: 999px) {
	#top_support {
		background: none;
	}
	#top_support h2 {
		margin-bottom: 40px;
	}
	#top_support .slider02:after {
		display: none;
	}
}
@media screen and (max-width: 767px) {
	#top_support section {
		width: 96%;
	}
}
@media screen and (max-width: 479px) {
	#top_support section .btn a {
		margin: 0 auto;
	}
}

/* --------------------------------------------------------- office */
#top_office {
	background-color: #E8F1EB;
	padding: 100px 0;
	background-image: url(../images/office_leaf01.png),url(../images/office_leaf02.png);
	background-repeat: no-repeat,no-repeat;
	background-position: calc(50% - 730px) top,calc(50% + 670px) top;
}
#top_office section {
	width: 90%;
	max-width: 1200px;
	margin: 0 auto;
}
#top_office ul {
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}
#top_office li {
	width: 19.5%;
	height: 175px;
	margin-right: calc(2.5% / 4);
	margin-bottom: 6px;
	background-color: #fff;
	box-sizing: border-box;
	padding: 10px 20px;
	pointer-events: none;
	transition: all .3s ease;
}
#top_office li:hover {
	background-color: #9CD10B;
	background-color: #EEFFF3;
	transition: all .3s ease;
}
#top_office li:nth-of-type(5n) {
	margin-right: 0;
}
#top_office li a {
	height: 155px;
	color: #057149;
	display: block;
	position: relative;
	pointer-events: auto;
	background: url(../images/bg_office.png) left top no-repeat;
}
#top_office li a:after {
	position: absolute;
	right: 0;
	bottom: 25px;
	content: url(../images/arrow_green02.svg);
	width: 28.5px;
	height: 6px;
	transition: all .3s ease;
}
#top_office li a:hover:after {
	right: -10px;
	transition: all .3s ease;
}
#top_office li span {
	position: absolute;
	left: 0;
	bottom: 28%;
	display: block;
	width: 100%;
	font-size: 1.25rem;
	font-family: "kosugimaru", sans-serif;
	letter-spacing: 0.1em;
	line-height: 1.5em;
}
#top_office li ins {
	display: block;
	border-bottom: 1px solid #ddd;
	width: 100%;
	font-size: 0.8125rem;
	color: #666;
	line-height: 1.2em;
	letter-spacing: 0.05em;
	padding-bottom: 3px;
	padding-left: 16px;
	position: relative;
}
#top_office li ins:before {
	position: absolute;
	bottom: 5px;
	left: 0;
	content: "";
	width: 9px;
	height: 15px;
	background: url(../images/listicon_office.png) center center no-repeat;
}
#top_office .headline {
	background-color: #5CC596;
	padding: 0;
	position: relative;
}
#top_office .headline figure {
	width: 50px;
	height: 40px;
	margin: 0 auto;
	transform: translateY(-20px);
}
#top_office .headline h2 {
	position: absolute;
	left: 50%;
	bottom: 40px;
	transform: translateX(-50%);
	font-weight: normal;
	text-align: center;
	font-family: "kosugimaru", sans-serif;
	letter-spacing: 0.1em;
	font-size: 1.625rem;
	color: #fff;
	white-space: nowrap;
}
#top_office .headline img {
	vertical-align: top;
}
#top_office .headline span {
	font-family: "Anago-Thin", sans-serif;
	font-weight: 100;
	font-size: 0.75rem;
	display: block;
	letter-spacing: 0.2em;
	text-align: center;
	position: relative;
	bottom: auto;
}
@media screen and (max-width: 1299px) {
	#top_office li {
		width: 24.5%;
		margin-right: calc(2% / 3);
	}
	#top_office li:nth-of-type(5n) {
		margin-right: calc(2% / 3);
	}
	#top_office li:nth-of-type(4n) {
		margin-right: 0;
	}
}
@media screen and (max-width: 999px) {
	#top_office li {
		width: 32.5%;
		margin-right: calc(2.5% / 2);
	}
	#top_office li:nth-of-type(5n) {
		margin-right: calc(2.5% / 2);
	}
	#top_office li:nth-of-type(4n) {
		margin-right: calc(2.5% / 2);
	}
	#top_office li:nth-of-type(3n) {
		margin-right: 0;
	}
}
@media screen and (max-width: 767px) {
	#top_office li {
		width: 49%;
		margin-right: 2%;
	}
	#top_office li:nth-of-type(5n) {
		margin-right: 2%;
	}
	#top_office li:nth-of-type(4n) {
		margin-right: 2%;
	}
	#top_office li:nth-of-type(3n) {
		margin-right: 2%;
	}
	#top_office li:nth-of-type(2n) {
		margin-right: 0;
	}
}
@media screen and (max-width: 575px) {
	#top_office li {
		width: 100%;
		margin-right: 0;
		height: 135px;
	}
	#top_office li:nth-of-type(5n) {
		margin-right: 0;
	}
	#top_office li:nth-of-type(4n) {
		margin-right: 0;
	}
	#top_office li:nth-of-type(3n) {
		margin-right: 0;
	}
	#top_office li:nth-of-type(2n) {
		margin-right: 0;
	}
	#top_office li a {
		height: 115px;
	}
}