﻿html.is-menu-open {
	overflow: hidden;
}

header {
	border-bottom: none;
	box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
	margin: 0;
	z-index: 300;
}

@media screen and (max-width: 1000px) {
	.c-header {
		border-bottom: 1px solid #000;
	}
}
.c-header-group {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 15px;
	align-items: center;
	min-height: var(--header);
}
@media (max-width: 1355px) {
	.c-header-group {
		margin-right: 15px !important;
	}
}
@media screen and (min-width: 1001px) {
	.c-header-logo {
		margin-left: 30px;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-logo {
		margin-left: 15px;
	}
}
.c-header-logo a {
	display: grid;
	vertical-align: middle;
}
@media screen and (max-width: 1000px) {
	.c-header-logo img {
		width: 216px;
	}
}
.c-header-recruit {
	height: 100%;
}
@media screen and (max-width: 1000px) {
	.c-header-recruit {
		display: none;
	}
}
.c-header-recruit-wrap {
	height: 100%;
	justify-self: end;
	display: grid;
	grid-template-columns: repeat(3, auto);
	gap: 15px;
}
@media screen and (min-width: 1001px) {
	.c-header-nav-wrap > .c-header-recruit {
		display: none;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-nav-wrap > .c-header-recruit {
		display: block;
		padding-block: 20px;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-nav-wrap > .c-header-recruit .c-header-recruit-link {
		width: min(500px, 100% - 40px);
		height: 65px;
		font-size: 2.2rem;
		border: none;
		margin-inline: auto;
	}
}
.c-header-recruit-link {
	height: 100%;
	background: linear-gradient(163deg, #5aaa46 50.31%, #00590e 50.31%);
	border: 10px solid #fff;
	font-size: clamp(2.8rem, 2.8vw, 2.8rem);
	font-weight: 100;
	color: #fff !important;
	display: grid;
	place-content: center;
	letter-spacing: 0.05em;
	position: relative;
	text-align: center;
	box-sizing: border-box;
}
.c-header-recruit-link.is-humac {
	background: linear-gradient(163deg, #86c53d 50.31%, #6c9f32 50.31%);
	padding-right: 9px;
}
.c-header-recruit-link.is-humac span {
	font-size: clamp(1.2rem, 1.2vw, 1.2rem);
	line-height: 1.2;
	position: relative;
	top: -2px;
}
.c-header-recruit-link.is-humac::before {
	width: 40px;
	height: 40px;
	right: 0.2em;
	background: url("../images/common/icon_humac.png") no-repeat center/contain;
}
@media (max-width: 1000px) {
	.c-header-recruit-link + .c-header-recruit-link {
		margin-top: 12px;
	}
}
@media (min-width: 1101px) {
	.c-header-recruit-link {
		width: 220px !important;
	}
}
@media (max-width: 1100px) and (min-width: 1001px) {
	.c-header-recruit-link {
		width: 200px !important;
	}
}
.c-header-recruit-link span {
	font-size: clamp(1.4rem, 1.4vw, 1.4rem);
	text-align: center;
	line-height: 1;
	padding-bottom: 0.2em;
}
.c-header-recruit-link::before {
	content: "";
	position: absolute;
	right: 0.5em;
	top: 50%;
	width: 20px;
	height: 20px;
	background: url("../images/common/icon_right_arrow.svg") no-repeat center;
	translate: 0 -50%;
	background-size: contain;
}
nav.submenu {
	margin: 0;
	background-color: rgba(0, 0, 0, 0);
}
.c-header-nav {
	height: 100%;
	max-width: 1440px;
	margin-inline: auto;
}
.c-header-nav-wrap {
	background-color: #f8f8f8;
}
@media screen and (max-width: 1000px) {
	.c-header-nav-wrap {
		border-bottom: 1px solid #5aaa46;
	}
}
.c-header-nav-input {
	display: none;
}
@media screen and (min-width: 1001px) {
	.c-header-nav {
		display: flex;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-nav {
		width: calc(100% - 40px);
		overflow-y: scroll;
		max-height: calc(100vh - (var(--header) + 122px));
	}
	.c-header-nav::-webkit-scrollbar {
		display: none;
	}
}
.c-header-nav-item {
	flex: 1;
}
@media screen and (max-width: 1000px) {
	.c-header-nav-item {
		overflow: hidden;
	}
}
.c-header-nav-item + .c-header-nav-item .c-header-nav-link {
	position: relative;
}
@media screen and (min-width: 1001px) {
	.c-header-nav-item + .c-header-nav-item .c-header-nav-link::before {
		content: "";
		position: absolute;
		height: 100%;
		width: 2px;
		background-color: #fff;
		left: 0;
		top: 0;
		translate: 0 -0.5px;
	}
}
.c-header-nav-link {
	display: grid;
	position: relative;
	min-height: 50px;
	cursor: pointer;
	transition: all 0.6s;
}
.c-header-nav-link:hover {
	opacity: 0.6;
}
@media screen and (min-width: 1001px) {
	.c-header-nav-link {
		font-size: clamp(1.6rem, 1.6vw, 1.6rem);
		place-content: center;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-nav-link {
		border-bottom: 1px solid #5aaa46;
		place-content: center left;
		position: relative;
	}
}
.c-header-nav-input:checked + .c-header-nav-label .c-header-nav-link {
	color: #5aaa46;
	font-weight: 700;
}
@media screen and (max-width: 1000px) {
	.c-header-nav-link::before {
		content: "";
		position: absolute;
		right: 1.3em;
		width: 8px;
		height: 8px;
		border-right: 1px solid #000;
		border-top: 1px solid #000;
		rotate: 45deg;
		top: 50%;
		translate: 0 -50%;
	}
}
.c-header-nav-label > .c-header-nav-link::before {
	content: none;
}
.c-header-nav-link.is-icon {
	position: relative;
}
.c-header-nav-link.is-icon::after {
	content: "";
	position: absolute;
	width: 8px;
	height: 8px;
	border-bottom: 1px solid #000;
	border-right: 1px solid #000;
	rotate: 45deg;
	top: 50%;
	translate: 0 -50%;
	transform-origin: top center;
	right: 1.5em;
}
@media screen and (max-width: 1000px) {
	.c-header-nav-link.is-icon::after {
		right: 1em;
	}
}
.c-header-nav-input:checked + .c-header-nav-label .c-header-nav-link.is-icon::after {
	border-top: 1px solid #000;
	border-left: 1px solid #000;
	border-right: none;
	border-bottom: none;
	top: 55%;
	border-color: #5aaa46;
}
nav.submenu > div.container {
	border-bottom: none;
}
nav.submenu > div.container > ul {
	width: min(1276px, 100% - 20px);
	max-width: 100%;
}
nav.submenu > div.container > ul > li > a {
	font-size: clamp(1.4rem, 1.4vw, 1.4rem);
}
nav.submenu > div.container > ul > li,
nav.submenu > div.container > ul > li > a {
	margin-right: 12px;
}
nav.submenu {
	margin-bottom: 0 !important;
}
.c-megamenu {
	left: 0;
	width: 100%;
	opacity: 0;
	pointer-events: none;
	top: var(--header-group);
	bottom: 0;
	z-index: 10;
}
@media screen and (min-width: 1001px) {
	.c-megamenu {
		height: calc(100vh - var(--header-group));
		position: absolute;
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu {
		height: 0;
		opacity: 0;
	}
}
.c-header-nav-input:checked ~ .c-megamenu {
	opacity: 1;
	pointer-events: all;
}
@media screen and (max-width: 1000px) {
	.c-header-nav-input:checked ~ .c-megamenu {
		height: 100%;
	}
}
.c-megamenu-wrap {
	z-index: 2;
	position: relative;
}
@media screen and (min-width: 1001px) {
	.c-megamenu-wrap {
		background: linear-gradient(130deg, #5aaa46 60%, #a4d389);
		padding: 0 !important;
	}
}
.c-megamenu-inner {
	width: min(1000px, 100%);
	margin-inline: auto;
	position: relative;
}
@media screen and (min-width: 1001px) {
	.c-megamenu-inner {
		padding-block: 25px 45px;
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-inner.is-service {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-inner.is-service .c-megamenu-title {
		grid-column: 1/3;
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-inner.is-service .c-megamenu-list {
		grid-column: 1/2;
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-inner.is-service .c-megamenu-list + .c-megamenu-list {
		grid-column: 2/3;
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-title {
		font-weight: 700;
		padding-bottom: 5px;
		border-bottom: 1px solid #fff;
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu-title {
		padding-top: 20px;
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-title-sp {
		display: none;
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-title-link {
		max-inline-size: max-content;
		display: grid;
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu-title-link {
		display: block;
		padding: 10px 0;
		position: relative;
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu-title-link::after {
		content: "";
		position: absolute;
		width: 6px;
		height: 6px;
		border-right: 1px solid #000;
		border-top: 1px solid #000;
		rotate: 45deg;
		top: 50%;
		translate: 0 -50%;
		right: 1.5em;
		transform-origin: left;
	}
}
.c-megamenu-title-em {
	color: #fff;
}
@media screen and (min-width: 1001px) {
	.c-megamenu-title-em {
		font-size: clamp(2.5rem, 2.5vw, 2.5rem);
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu-title-em {
		color: #000;
	}
}
.c-megamenu-title-en {
	font-size: clamp(1.4rem, 1.4vw, 1.4rem);
	color: #fff;
	font-weight: 400;
	text-align: center;
	translate: 0 -5px;
	text-transform: lowercase;
	display: none;
}
.c-megamenu-list {
	display: grid;
}
@media screen and (min-width: 1001px) {
	.c-megamenu-list {
		row-gap: 15px;
		margin-top: 20px;
		grid-template-columns: repeat(4, 1fr);
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu-list {
		padding-block: 0 20px;
		grid-template-columns: minmax(0, 1fr);
	}
}
.c-megamenu-link {
	color: #fff !important;
	font-weight: 400;
	position: relative;
	padding-right: 1em;
	line-height: 1.2em;
}
@media screen and (min-width: 1001px) {
	.c-megamenu-link {
		display: inline-block;
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu-link {
		display: block;
		color: #000 !important;
		padding: 10px 0;
	}
}
.c-megamenu-link::before {
	content: "";
	position: absolute;
	right: 0;
	width: 6px;
	height: 6px;
	border-right: 1px solid #fff;
	border-top: 1px solid #fff;
	rotate: 45deg;
	top: 0.2em;
	right: 1px;
	transform-origin: left;
}
@media screen and (max-width: 1000px) {
	.c-megamenu-link::before {
		border-color: #000;
		top: 50%;
		translate: 0 -50%;
		right: 1.5em;
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-child-list {
		width: 1000px;
		margin-top: 15px;
		display: flex;
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu-child-list {
		width: 100%;
	}
}
.c-megamenu-child-link {
	color: #fff !important;
	font-weight: 400;
	position: relative;
	line-height: 1.2em;
	padding-right: 1em;
}
@media screen and (min-width: 1001px) {
	.c-megamenu-child-link {
		display: inline-block;
		margin-right: 2em;
	}
}
@media screen and (max-width: 1000px) {
	.c-megamenu-child-link {
		display: block;
		color: #000 !important;
		padding: 10px 0;
	}
}
.c-megamenu-child-link::before {
	content: "";
	position: absolute;
	right: 0;
	width: 6px;
	height: 6px;
	border-right: 1px solid #fff;
	border-top: 1px solid #fff;
	rotate: 45deg;
	top: 0.3em;
	transform-origin: left;
}
@media screen and (max-width: 1000px) {
	.c-megamenu-child-link::before {
		border-color: #000;
		top: 50%;
		translate: 0 -50%;
		right: 1.5em;
	}
}
@media screen and (min-width: 1001px) {
	.c-megamenu-close-area {
		position: absolute;
		inset: 0 0 0 0;
		z-index: 1;
	}
}
.c-icon-close,
.c-icon-close--white {
	position: absolute;
	right: 7px;
	top: 36px;
	width: 20px;
	height: 20px;
	cursor: pointer;
	z-index: 1;
}
@media screen and (max-width: 1000px) {
	.c-icon-close,
	.c-icon-close--white {
		display: none;
	}
}
.c-icon-close::before,
.c-icon-close--white::before,
.c-icon-close::after,
.c-icon-close--white::after {
	position: absolute;
	content: "";
	top: 0;
	width: 30px;
	height: 2px;
	top: 50%;
}
.c-icon-close::before,
.c-icon-close--white::before {
	transform: rotate(45deg);
}
.c-icon-close::after,
.c-icon-close--white::after {
	transform: rotate(-45deg);
}
.c-icon-close--white::before,
.c-icon-close--white::after {
	background-color: #fff;
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button {
		position: absolute;
		display: flex;
		flex-direction: column;
		right: 0;
		top: 45%;
		transform: translateY(-50%);
		height: var(--header);
		align-items: center;
		justify-content: center;
		width: 50px;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button-line {
		appearance: none;
		border: none;
		position: relative;
		width: 25px;
		height: 16px;
		cursor: pointer;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button-line span {
		position: absolute;
		left: 0;
		width: 100%;
		height: 2px;
		background-color: #5aaa46;
		transition: all 0.3s;
		transform-origin: center;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button-line span:nth-child(1) {
		top: 0;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button-line span:nth-child(2) {
		top: 50%;
		transform: translateY(-50%) scale(1);
		opacity: 1;
		transition: all 0.7s;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button-line span:nth-child(3) {
		bottom: 0;
	}
}
.c-header-mobile-button.is-active ~ .c-global-menu {
	transform: scaleX(1) translateX(0);
	opacity: 1;
	visibility: visible;
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button.is-active span:nth-child(1) {
		rotate: 45deg;
		top: 50%;
		transform: translateY(-50%);
		transition-delay: 70ms;
		left: -1px;
	}
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button.is-active span:nth-child(2) {
		transition-delay: 0ms;
		transition: 0s;
		transform: translateY(-50%) scaleX(0);
	}
}
@media screen and (max-width: 1000px) {
	.c-header-mobile-button.is-active span:nth-child(3) {
		rotate: -45deg;
		top: 50%;
		transition-delay: 140ms;
		transform: translateY(-50%);
	}
}
@media screen and (max-width: 1000px) {
	.c-header-nav-area {
		width: 100vw;
		position: fixed;
		left: 0;
		right: 0;
		z-index: 105;
		top: 0;
		visibility: hidden;
		transition: all 0.3s;
		height: 0;
		overflow: hidden;
	}
}
@media screen and (max-width: 1000px) {
	.is-menu-open .c-header-nav-area {
		visibility: visible;
		height: 100svh;
	}
}
@media screen and (max-width: 1000px) {
	.c-header nav {
		translate: 0 calc(var(--header) + 1px);
		transition: all 0.3s;
	}
}
.sp-header-nav-overlay {
	height: 100%;
	position: absolute;
	inset: 0 0 0 0;
	z-index: -1;
}
.c-megamenu-link.is-character {
	overflow: visible;
	padding-left: 40px;
	white-space: nowrap;
}
.c-megamenu-link.is-character::after {
	content: "";
	width: 34px;
	aspect-ratio: 1/1;
	background: url("../../character/img/chara-04s.png") no-repeat center;
	position: absolute;
	left: 0;
	top: 50%;
	translate: 0 -50%;
	border-radius: 50%;
}
@media screen and (max-width: 1000px) {
	.footer-link-level3::after,
	.footer-link-level2::after,
	.footer-link-level1::after,
	.footer-link-label::after {
		content: "";
		position: absolute;
		top: 50%;
		width: 10px;
		height: 10px;
		right: 1em;
		border-right: 2px solid #b9b9b9;
		border-top: 2px solid #b9b9b9;
		translate: 0 -50%;
		rotate: 45deg;
		transform-origin: top center;
	}
}
@media screen and (max-width: 640px) {
	.footer-banner ~ footer {
		margin-top: 0 !important;
	}
}
.footer-inner {
	margin-inline: auto;
}
@media screen and (min-width: 1001px) {
	.footer-inner {
		padding-block: 73px 84px;
		width: min(1000px, 100% - 30px);
	}
}
@media screen and (max-width: 1000px) {
	.footer-inner {
		padding-block: 0px 20px;
		width: 100%;
	}
}
.footer-iso {
	background-color: #fff;
	width: min(362px, 100% - 30px);
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 21px;
	padding: 20px 10px 14px 20px;
	align-items: center;
}
@media screen and (min-width: 1001px) {
	.footer-iso {
		margin-inline: auto 0;
	}
}
@media screen and (max-width: 1000px) {
	.footer-iso {
		margin-inline: auto;
		margin-top: 20px;
	}
}
.footer-iso-comment {
	font-size: clamp(1.2rem, 1.2vw, 1.2rem);
}
.footer-link {
	gap: 0 50px;
	margin-inline: auto;
}
@media screen and (min-width: 1001px) {
	.footer-link {
		display: grid;
		grid-template-columns: repeat(5, 1fr);
		grid-template-rows: auto auto;
	}
}
.footer-link-input {
	display: none;
}
.footer-link-item:nth-child(2) {
	grid-row: 2/3;
	grid-column: 1/2;
}
.footer-link-item:nth-child(4) {
	grid-row: 2/3;
	grid-column: 2/3;
}
.footer-link-item:nth-child(5) {
	grid-row: 1/3;
}
.footer-link-item:nth-child(7) {
	grid-row: 2/3;
	grid-column: 4/5;
}
.footer-link-item #footer-accordion2 ~ .footer-link-level1-list .footer-link-level1-item:nth-child(2) .footer-link-level2 {
	white-space: nowrap;
}
.footer-link-label {
	width: 100%;
	position: relative;
	display: block;
}
@media screen and (max-width: 1000px) {
	.footer-link-label::before {
		content: "";
		width: 40%;
		position: absolute;
		right: 0;
		height: 100%;
		z-index: 1;
		top: 0;
	}
}
.footer-link-label::after {
	border-bottom: 2px solid #b9b9b9;
	border-top: none;
}
.footer-link-input:checked + .footer-link-label::after {
	border-left: 2px solid #b9b9b9;
	border-right: none;
	border-top: 2px solid #b9b9b9;
	border-bottom: none;
	transform-origin: top;
	top: 55%;
}
.footer-link-label .footer-link-level1::after {
	content: none;
}
@media screen and (min-width: 1001px) {
	.footer-link-label span {
		padding-left: 0;
	}
}
@media screen and (min-width: 1001px) {
	.footer-link-label span::before {
		content: none;
	}
}
.footer-link-level1 {
	color: #fff !important;
	text-decoration: none !important;
	font-size: clamp(1.6rem, 1.6vw, 1.6rem);
	padding-bottom: 9px;
	display: block;
	position: relative;
	border-bottom: 1px solid #fff;
	font-weight: 600;
	position: relative;
}
@media screen and (min-width: 1001px) {
	.footer-link-level1 {
		margin-bottom: 11px;
		padding-left: 1.3em;
	}
}
@media screen and (max-width: 1000px) {
	.footer-link-level1 {
		border-color: #b9b9b9;
		font-weight: 400;
		padding: 15px 8px 15px 2.2em;
	}
}
.footer-link-level1::before {
	content: "";
	position: absolute;
	width: 10px;
	height: 1px;
	background-color: #fff;
	opacity: 1;
	left: 0;
	top: 0.8em;
}
@media screen and (max-width: 1000px) {
	.footer-link-level1::before {
		top: 50%;
		translate: 0 -50%;
		left: 1em;
	}
}
.footer-link-level1 ~ .footer-link-level1 {
	margin-top: 30px;
}
@media screen and (min-width: 1001px) {
	.footer-link-level1-item.is-margin {
		margin-top: 30px;
	}
}
.footer-link-level1-list {
	display: grid;
	row-gap: 3px;
}
@media screen and (max-width: 1000px) {
	.footer-link-input:checked + .footer-link-label + .footer-link-level1-list {
		display: block;
		border-bottom: 1px solid #b9b9b9;
		background-color: #3d7430;
	}
}
@media screen and (max-width: 1000px) {
	.footer-link-level1-list {
		display: none;
	}
}
.footer-link-level2 {
	color: #fff !important;
	position: relative;
	text-decoration: none !important;
	font-size: clamp(1.2rem, 1.2vw, 1.2rem);
	display: block;
}
@media screen and (min-width: 1001px) {
	.footer-link-level2 {
		padding-left: 1.5em;
	}
}
@media screen and (max-width: 1000px) {
	.footer-link-level2 {
		font-size: 1.4rem;
		padding-left: 1.8em;
	}
}
@media screen and (max-width: 1000px) {
	.footer-link-level1-item:not(:last-child) .footer-link-level2 {
		border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	}
}
@media screen and (max-width: 1000px) {
	#footer-accordion1 + .footer-link-label + .footer-link-level1-list .footer-link-level1-item:nth-child(2) .footer-link-level2 {
		border-top: 1px solid rgba(255, 255, 255, 0.3);
		border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	}
}
@media screen and (max-width: 1000px) {
	.footer-link-level2::after {
		width: 8px;
		height: 8px;
		right: 1.2em;
	}
}
@media screen and (max-width: 1000px) {
	.footer-link-level2 {
		padding-inline: 2.5em 8px;
		padding-block: 9px;
	}
}
.footer-link-level2 span.c-icon-blank::after {
	top: 0.6em;
}
@media screen and (min-width: 1001px) {
	.footer-link-level2-list {
		margin-top: 5px;
		margin-bottom: 20px;
	}
}
.footer-link-level2::before {
	content: "";
	position: absolute;
	width: 10px;
	height: 1px;
	background-color: #fff;
	opacity: 1;
	left: 0;
	top: 0.8em;
}
@media screen and (max-width: 1000px) {
	.footer-link-level2::before {
		top: 50%;
		translate: 0 -50%;
		left: 1em;
	}
}
.footer-link-level3 {
	color: #fff !important;
	position: relative;
	font-size: clamp(1.2rem, 1.2vw, 1.2rem);
	text-decoration: none !important;
	display: block;
	padding-left: 2.1em;
}
@media screen and (max-width: 1000px) {
	.footer-link-level2-item:not(:last-child) .footer-link-level3 {
		border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	}
}
@media screen and (max-width: 1000px) {
	.footer-link-level3::after {
		width: 8px;
		height: 8px;
		right: 1.2em;
	}
}
@media screen and (max-width: 1000px) {
	.footer-link-level3 {
		padding-inline: 2.5em 8px;
		padding-block: 9px;
		font-size: 1.4rem;
	}
}
.footer-link-level3::before {
	content: "";
	position: absolute;
	width: 10px;
	height: 1px;
	background-color: #fff;
	opacity: 1;
	left: 0;
	top: 0.8em;
}
@media screen and (max-width: 1000px) {
	.footer-link-level3::before {
		top: 50%;
		translate: 0 -50%;
		left: 1em;
	}
}
.footer-link-list {
	display: grid;
}
.footer-link-level2-list {
	display: grid;
}
.footer nav.footer ul > li > a {
	margin-bottom: 13px;
}
@media screen and (max-width: 1000px) {
	footer nav.footer > ul > li > a {
		margin-bottom: 0;
		font-weight: 400;
	}
}
.copyright {
	display: grid;
	place-content: center;
	padding-inline: 10px;
}
@media screen and (min-width: 1001px) {
	.copyright {
		min-height: 60px;
	}
}
@media screen and (max-width: 1000px) {
	.copyright {
		min-height: 40px;
	}
}
.copyright small {
	font-size: clamp(1.2rem, 1.2vw, 1.2rem);
}
@media screen and (max-width: 1000px) {
	.copyright small {
		line-height: 1.4em;
		display: block;
	}
}
footer div.information {
	border: none;
	margin-bottom: 0;
}
.pagetop {
	position: fixed;
	left: 50%;
	bottom: 15px;
	z-index: 101;
	left: 50%;
	translate: -50% 0;
	justify-content: end;
	width: min(1000px, 100% - 30px);
	pointer-events: none;
}
.pagetop.is-absolute {
	position: absolute;
}
.pagetop-item {
	width: 70px;
	aspect-ratio: 1/1;
	position: relative;
	display: block;
	margin-inline: auto 0;
	pointer-events: auto;
	opacity: 1 !important;
}
@media screen and (max-width: 1000px) {
	.pagetop-item {
		width: 60px;
	}
}
.pagetop-item::before {
	content: "";
	position: absolute;
	background-image: url("../images/common/totop.svg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	transition: background-image 0.3s;
}
.pagetop-item:hover::before {
	background-image: url("../images/common/totop_maincolor.svg");
}
@media screen and (max-width: 1000px) {
	.footer-iso {
		margin-top: 20px !important;
	}
}
.footer-link-level2.is-character {
	white-space: nowrap;
}
@media (max-width: 1000px) {
	#modal {
		z-index: 500;
	}
}
html {
	scroll-behavior: smooth;
	position: relative;
}
@media screen and (min-width: 1001px) {
	:root {
		--header: 90px;
	}
}
@media screen and (max-width: 1000px) {
	:root {
		--header: 70px;
	}
}
@media screen and (min-width: 1001px) {
	:root {
		--header-menu: 50px;
	}
}
@media screen and (min-width: 1001px) {
	:root {
		--header-group: calc(var(--header) + var(--header-menu));
	}
}
@media screen and (max-width: 1000px) {
	:root {
		--header-group: calc(var(--header));
	}
}
@media screen and (min-width: 1001px) {
	:root {
		scroll-padding-top: var(--header-group);
	}
}
@media screen and (min-width: 641px) {
	:root {
		--font-size: 16px;
	}
}
@media screen and (max-width: 640px) {
	:root {
		--font-size: 14px;
	}
}
body {
	font-family: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Arial", "Meiryo", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 400;
	font-size: var(--font-size);
	letter-spacing: 0.03em;
	color: #000;
}
.c-icon-blank {
	position: relative;
	padding-right: 1.3em;
}
.c-icon-blank::after {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	right: 0;
	top: 50%;
	background: url("../images/common/icon_blank.svg") no-repeat center;
	background-size: cover;
	translate: 0 -50%;
}
@media screen and (max-width: 1000px) {
	.c-icon-blank::after {
		width: 13px;
		height: 13px;
	}
}
header ul,
footer ul {
	list-style-type: none;
}
header a:link,
footer a:link {
	text-decoration: none;
}
header a:visited,
footer a:visited {
	text-decoration: none;
}
header a:hover,
footer a:hover,
header a:focus,
footer a:focus,
header a:active,
footer a:active {
	color: #000;
	text-decoration: none;
}
header *,
footer * {
	box-sizing: border-box;
}
header img,
footer img {
	max-width: 100%;
	height: auto;
}
header figure,
footer figure {
	margin: 0;
}
header a,
header button,
footer a,
footer button {
	cursor: pointer;
}
header,
footer {
	text-align: left;
}
#contents {
	font-size: 1em;
}
#main ul.photolist > li > div.comment > p {
	font-size: 1em;
}
body.corporate.history #main table > tbody > tr > th {
	width: 13%;
}
body.error h2 {
	margin-top: 2em;
}
table tr th,
table tr td {
	color: #000;
}
.paragraph .is-sp-img-width img {
	max-width: 100%;
}
.c-list-my-counter {
	list-style-type: none;
	counter-reset: my-counter;
}
#main ol.c-list-my-counter {
	margin-left: 0;
}
.c-list-my-counter li {
	counter-increment: my-counter;
	display: flex;
}
.c-list-my-counter li:before {
	content: "目標" counter(my-counter) "：";
	flex: 0 0 auto;
}
img {
	max-width: 100%;
	height: auto;
}
figure {
	margin: 0;
}
a,
button {
	cursor: pointer;
}
@media screen and (max-width: 640px) {
	.is-pc {
		display: none !important;
	}
}
@media screen and (min-width: 1001px) {
	.is-tb {
		display: none !important;
	}
}
@media screen and (min-width: 641px) {
	.is-sp {
		display: none !important;
	}
}
ul {
	list-style-type: none;
}
h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 400;
}
a:link {
	color: #000;
	text-decoration: none;
}
a:visited {
	color: #000;
	text-decoration: none;
}
a:hover {
	color: #000;
	text-decoration: none;
}
a:focus {
	color: #000;
	text-decoration: none;
}
a:active {
	color: #000;
	text-decoration: none;
}
.c-company-grid-figure,
.c-company-list-figure {
	overflow: hidden;
}
.c-company-grid-figure img,
.c-company-list-figure img {
	transition: all 0.3s;
}
a:hover .c-company-grid-figure img,
a:hover .c-company-list-figure img {
	scale: 1.03;
}
.c-link {
	border-bottom: all 0.3s;
}
.c-link:hover {
	border-bottom: rgba(0, 0, 0, 0);
}
* {
	box-sizing: border-box;
}
body {
	text-align: left;
}
.c-title-text,
.c-title-text--sp-left,
.sdgs-text {
	line-height: 2.4em;
}
@media screen and (min-width: 641px) {
	.mt0 {
		margin-top: 0px !important;
	}
	.mb0 {
		margin-bottom: 0px !important;
	}
	.pt0 {
		padding-top: 0px !important;
	}
	.pb0 {
		padding-bottom: 0px !important;
	}
	.mt5 {
		margin-top: 5px !important;
	}
	.mb5 {
		margin-bottom: 5px !important;
	}
	.pt5 {
		padding-top: 5px !important;
	}
	.pb5 {
		padding-bottom: 5px !important;
	}
	.mt10 {
		margin-top: 10px !important;
	}
	.mb10 {
		margin-bottom: 10px !important;
	}
	.pt10 {
		padding-top: 10px !important;
	}
	.pb10 {
		padding-bottom: 10px !important;
	}
	.mt15 {
		margin-top: 15px !important;
	}
	.mb15 {
		margin-bottom: 15px !important;
	}
	.pt15 {
		padding-top: 15px !important;
	}
	.pb15 {
		padding-bottom: 15px !important;
	}
	.mt20 {
		margin-top: 20px !important;
	}
	.mb20 {
		margin-bottom: 20px !important;
	}
	.pt20 {
		padding-top: 20px !important;
	}
	.pb20 {
		padding-bottom: 20px !important;
	}
	.mt25 {
		margin-top: 25px !important;
	}
	.mb25 {
		margin-bottom: 25px !important;
	}
	.pt25 {
		padding-top: 25px !important;
	}
	.pb25 {
		padding-bottom: 25px !important;
	}
	.mt30 {
		margin-top: 30px !important;
	}
	.mb30 {
		margin-bottom: 30px !important;
	}
	.pt30 {
		padding-top: 30px !important;
	}
	.pb30 {
		padding-bottom: 30px !important;
	}
	.mt35 {
		margin-top: 35px !important;
	}
	.mb35 {
		margin-bottom: 35px !important;
	}
	.pt35 {
		padding-top: 35px !important;
	}
	.pb35 {
		padding-bottom: 35px !important;
	}
	.mt40 {
		margin-top: 40px !important;
	}
	.mb40 {
		margin-bottom: 40px !important;
	}
	.pt40 {
		padding-top: 40px !important;
	}
	.pb40 {
		padding-bottom: 40px !important;
	}
	.mt45 {
		margin-top: 45px !important;
	}
	.mb45 {
		margin-bottom: 45px !important;
	}
	.pt45 {
		padding-top: 45px !important;
	}
	.pb45 {
		padding-bottom: 45px !important;
	}
	.mt50 {
		margin-top: 50px !important;
	}
	.mb50 {
		margin-bottom: 50px !important;
	}
	.pt50 {
		padding-top: 50px !important;
	}
	.pb50 {
		padding-bottom: 50px !important;
	}
	.mt55 {
		margin-top: 55px !important;
	}
	.mb55 {
		margin-bottom: 55px !important;
	}
	.pt55 {
		padding-top: 55px !important;
	}
	.pb55 {
		padding-bottom: 55px !important;
	}
	.mt60 {
		margin-top: 60px !important;
	}
	.mb60 {
		margin-bottom: 60px !important;
	}
	.pt60 {
		padding-top: 60px !important;
	}
	.pb60 {
		padding-bottom: 60px !important;
	}
	.mt65 {
		margin-top: 65px !important;
	}
	.mb65 {
		margin-bottom: 65px !important;
	}
	.pt65 {
		padding-top: 65px !important;
	}
	.pb65 {
		padding-bottom: 65px !important;
	}
	.mt70 {
		margin-top: 70px !important;
	}
	.mb70 {
		margin-bottom: 70px !important;
	}
	.pt70 {
		padding-top: 70px !important;
	}
	.pb70 {
		padding-bottom: 70px !important;
	}
	.mt75 {
		margin-top: 75px !important;
	}
	.mb75 {
		margin-bottom: 75px !important;
	}
	.pt75 {
		padding-top: 75px !important;
	}
	.pb75 {
		padding-bottom: 75px !important;
	}
	.mt80 {
		margin-top: 80px !important;
	}
	.mb80 {
		margin-bottom: 80px !important;
	}
	.pt80 {
		padding-top: 80px !important;
	}
	.pb80 {
		padding-bottom: 80px !important;
	}
	.mt85 {
		margin-top: 85px !important;
	}
	.mb85 {
		margin-bottom: 85px !important;
	}
	.pt85 {
		padding-top: 85px !important;
	}
	.pb85 {
		padding-bottom: 85px !important;
	}
	.mt90 {
		margin-top: 90px !important;
	}
	.mb90 {
		margin-bottom: 90px !important;
	}
	.pt90 {
		padding-top: 90px !important;
	}
	.pb90 {
		padding-bottom: 90px !important;
	}
	.mt95 {
		margin-top: 95px !important;
	}
	.mb95 {
		margin-bottom: 95px !important;
	}
	.pt95 {
		padding-top: 95px !important;
	}
	.pb95 {
		padding-bottom: 95px !important;
	}
	.mt100 {
		margin-top: 100px !important;
	}
	.mb100 {
		margin-bottom: 100px !important;
	}
	.pt100 {
		padding-top: 100px !important;
	}
	.pb100 {
		padding-bottom: 100px !important;
	}
	.mt105 {
		margin-top: 105px !important;
	}
	.mb105 {
		margin-bottom: 105px !important;
	}
	.pt105 {
		padding-top: 105px !important;
	}
	.pb105 {
		padding-bottom: 105px !important;
	}
	.mt110 {
		margin-top: 110px !important;
	}
	.mb110 {
		margin-bottom: 110px !important;
	}
	.pt110 {
		padding-top: 110px !important;
	}
	.pb110 {
		padding-bottom: 110px !important;
	}
	.mt115 {
		margin-top: 115px !important;
	}
	.mb115 {
		margin-bottom: 115px !important;
	}
	.pt115 {
		padding-top: 115px !important;
	}
	.pb115 {
		padding-bottom: 115px !important;
	}
	.mt120 {
		margin-top: 120px !important;
	}
	.mb120 {
		margin-bottom: 120px !important;
	}
	.pt120 {
		padding-top: 120px !important;
	}
	.pb120 {
		padding-bottom: 120px !important;
	}
	.mt125 {
		margin-top: 125px !important;
	}
	.mb125 {
		margin-bottom: 125px !important;
	}
	.pt125 {
		padding-top: 125px !important;
	}
	.pb125 {
		padding-bottom: 125px !important;
	}
	.mt130 {
		margin-top: 130px !important;
	}
	.mb130 {
		margin-bottom: 130px !important;
	}
	.pt130 {
		padding-top: 130px !important;
	}
	.pb130 {
		padding-bottom: 130px !important;
	}
	.mt135 {
		margin-top: 135px !important;
	}
	.mb135 {
		margin-bottom: 135px !important;
	}
	.pt135 {
		padding-top: 135px !important;
	}
	.pb135 {
		padding-bottom: 135px !important;
	}
	.mt140 {
		margin-top: 140px !important;
	}
	.mb140 {
		margin-bottom: 140px !important;
	}
	.pt140 {
		padding-top: 140px !important;
	}
	.pb140 {
		padding-bottom: 140px !important;
	}
	.mt145 {
		margin-top: 145px !important;
	}
	.mb145 {
		margin-bottom: 145px !important;
	}
	.pt145 {
		padding-top: 145px !important;
	}
	.pb145 {
		padding-bottom: 145px !important;
	}
	.mt150 {
		margin-top: 150px !important;
	}
	.mb150 {
		margin-bottom: 150px !important;
	}
	.pt150 {
		padding-top: 150px !important;
	}
	.pb150 {
		padding-bottom: 150px !important;
	}
	.mt155 {
		margin-top: 155px !important;
	}
	.mb155 {
		margin-bottom: 155px !important;
	}
	.pt155 {
		padding-top: 155px !important;
	}
	.pb155 {
		padding-bottom: 155px !important;
	}
	.mt160 {
		margin-top: 160px !important;
	}
	.mb160 {
		margin-bottom: 160px !important;
	}
	.pt160 {
		padding-top: 160px !important;
	}
	.pb160 {
		padding-bottom: 160px !important;
	}
	.mt165 {
		margin-top: 165px !important;
	}
	.mb165 {
		margin-bottom: 165px !important;
	}
	.pt165 {
		padding-top: 165px !important;
	}
	.pb165 {
		padding-bottom: 165px !important;
	}
	.mt170 {
		margin-top: 170px !important;
	}
	.mb170 {
		margin-bottom: 170px !important;
	}
	.pt170 {
		padding-top: 170px !important;
	}
	.pb170 {
		padding-bottom: 170px !important;
	}
	.mt175 {
		margin-top: 175px !important;
	}
	.mb175 {
		margin-bottom: 175px !important;
	}
	.pt175 {
		padding-top: 175px !important;
	}
	.pb175 {
		padding-bottom: 175px !important;
	}
	.mt180 {
		margin-top: 180px !important;
	}
	.mb180 {
		margin-bottom: 180px !important;
	}
	.pt180 {
		padding-top: 180px !important;
	}
	.pb180 {
		padding-bottom: 180px !important;
	}
	.mt185 {
		margin-top: 185px !important;
	}
	.mb185 {
		margin-bottom: 185px !important;
	}
	.pt185 {
		padding-top: 185px !important;
	}
	.pb185 {
		padding-bottom: 185px !important;
	}
	.mt190 {
		margin-top: 190px !important;
	}
	.mb190 {
		margin-bottom: 190px !important;
	}
	.pt190 {
		padding-top: 190px !important;
	}
	.pb190 {
		padding-bottom: 190px !important;
	}
	.mt195 {
		margin-top: 195px !important;
	}
	.mb195 {
		margin-bottom: 195px !important;
	}
	.pt195 {
		padding-top: 195px !important;
	}
	.pb195 {
		padding-bottom: 195px !important;
	}
	.mt200 {
		margin-top: 200px !important;
	}
	.mb200 {
		margin-bottom: 200px !important;
	}
	.pt200 {
		padding-top: 200px !important;
	}
	.pb200 {
		padding-bottom: 200px !important;
	}
}
@media screen and (max-width: 640px) {
	.mt-sp0 {
		margin-top: 0px !important;
	}
	.mb-sp0 {
		margin-bottom: 0px !important;
	}
	.pt-sp0 {
		padding-top: 0px !important;
	}
	.pb-sp0 {
		padding-bottom: 0px !important;
	}
	.mt-sp5 {
		margin-top: 5px !important;
	}
	.mb-sp5 {
		margin-bottom: 5px !important;
	}
	.pt-sp5 {
		padding-top: 5px !important;
	}
	.pb-sp5 {
		padding-bottom: 5px !important;
	}
	.mt-sp10 {
		margin-top: 10px !important;
	}
	.mb-sp10 {
		margin-bottom: 10px !important;
	}
	.pt-sp10 {
		padding-top: 10px !important;
	}
	.pb-sp10 {
		padding-bottom: 10px !important;
	}
	.mt-sp15 {
		margin-top: 15px !important;
	}
	.mb-sp15 {
		margin-bottom: 15px !important;
	}
	.pt-sp15 {
		padding-top: 15px !important;
	}
	.pb-sp15 {
		padding-bottom: 15px !important;
	}
	.mt-sp20 {
		margin-top: 20px !important;
	}
	.mb-sp20 {
		margin-bottom: 20px !important;
	}
	.pt-sp20 {
		padding-top: 20px !important;
	}
	.pb-sp20 {
		padding-bottom: 20px !important;
	}
	.mt-sp25 {
		margin-top: 25px !important;
	}
	.mb-sp25 {
		margin-bottom: 25px !important;
	}
	.pt-sp25 {
		padding-top: 25px !important;
	}
	.pb-sp25 {
		padding-bottom: 25px !important;
	}
	.mt-sp30 {
		margin-top: 30px !important;
	}
	.mb-sp30 {
		margin-bottom: 30px !important;
	}
	.pt-sp30 {
		padding-top: 30px !important;
	}
	.pb-sp30 {
		padding-bottom: 30px !important;
	}
	.mt-sp35 {
		margin-top: 35px !important;
	}
	.mb-sp35 {
		margin-bottom: 35px !important;
	}
	.pt-sp35 {
		padding-top: 35px !important;
	}
	.pb-sp35 {
		padding-bottom: 35px !important;
	}
	.mt-sp40 {
		margin-top: 40px !important;
	}
	.mb-sp40 {
		margin-bottom: 40px !important;
	}
	.pt-sp40 {
		padding-top: 40px !important;
	}
	.pb-sp40 {
		padding-bottom: 40px !important;
	}
	.mt-sp45 {
		margin-top: 45px !important;
	}
	.mb-sp45 {
		margin-bottom: 45px !important;
	}
	.pt-sp45 {
		padding-top: 45px !important;
	}
	.pb-sp45 {
		padding-bottom: 45px !important;
	}
	.mt-sp50 {
		margin-top: 50px !important;
	}
	.mb-sp50 {
		margin-bottom: 50px !important;
	}
	.pt-sp50 {
		padding-top: 50px !important;
	}
	.pb-sp50 {
		padding-bottom: 50px !important;
	}
	.mt-sp55 {
		margin-top: 55px !important;
	}
	.mb-sp55 {
		margin-bottom: 55px !important;
	}
	.pt-sp55 {
		padding-top: 55px !important;
	}
	.pb-sp55 {
		padding-bottom: 55px !important;
	}
	.mt-sp60 {
		margin-top: 60px !important;
	}
	.mb-sp60 {
		margin-bottom: 60px !important;
	}
	.pt-sp60 {
		padding-top: 60px !important;
	}
	.pb-sp60 {
		padding-bottom: 60px !important;
	}
	.mt-sp65 {
		margin-top: 65px !important;
	}
	.mb-sp65 {
		margin-bottom: 65px !important;
	}
	.pt-sp65 {
		padding-top: 65px !important;
	}
	.pb-sp65 {
		padding-bottom: 65px !important;
	}
	.mt-sp70 {
		margin-top: 70px !important;
	}
	.mb-sp70 {
		margin-bottom: 70px !important;
	}
	.pt-sp70 {
		padding-top: 70px !important;
	}
	.pb-sp70 {
		padding-bottom: 70px !important;
	}
	.mt-sp75 {
		margin-top: 75px !important;
	}
	.mb-sp75 {
		margin-bottom: 75px !important;
	}
	.pt-sp75 {
		padding-top: 75px !important;
	}
	.pb-sp75 {
		padding-bottom: 75px !important;
	}
	.mt-sp80 {
		margin-top: 80px !important;
	}
	.mb-sp80 {
		margin-bottom: 80px !important;
	}
	.pt-sp80 {
		padding-top: 80px !important;
	}
	.pb-sp80 {
		padding-bottom: 80px !important;
	}
	.mt-sp85 {
		margin-top: 85px !important;
	}
	.mb-sp85 {
		margin-bottom: 85px !important;
	}
	.pt-sp85 {
		padding-top: 85px !important;
	}
	.pb-sp85 {
		padding-bottom: 85px !important;
	}
	.mt-sp90 {
		margin-top: 90px !important;
	}
	.mb-sp90 {
		margin-bottom: 90px !important;
	}
	.pt-sp90 {
		padding-top: 90px !important;
	}
	.pb-sp90 {
		padding-bottom: 90px !important;
	}
	.mt-sp95 {
		margin-top: 95px !important;
	}
	.mb-sp95 {
		margin-bottom: 95px !important;
	}
	.pt-sp95 {
		padding-top: 95px !important;
	}
	.pb-sp95 {
		padding-bottom: 95px !important;
	}
	.mt-sp100 {
		margin-top: 100px !important;
	}
	.mb-sp100 {
		margin-bottom: 100px !important;
	}
	.pt-sp100 {
		padding-top: 100px !important;
	}
	.pb-sp100 {
		padding-bottom: 100px !important;
	}
	.mt-sp105 {
		margin-top: 105px !important;
	}
	.mb-sp105 {
		margin-bottom: 105px !important;
	}
	.pt-sp105 {
		padding-top: 105px !important;
	}
	.pb-sp105 {
		padding-bottom: 105px !important;
	}
	.mt-sp110 {
		margin-top: 110px !important;
	}
	.mb-sp110 {
		margin-bottom: 110px !important;
	}
	.pt-sp110 {
		padding-top: 110px !important;
	}
	.pb-sp110 {
		padding-bottom: 110px !important;
	}
	.mt-sp115 {
		margin-top: 115px !important;
	}
	.mb-sp115 {
		margin-bottom: 115px !important;
	}
	.pt-sp115 {
		padding-top: 115px !important;
	}
	.pb-sp115 {
		padding-bottom: 115px !important;
	}
	.mt-sp120 {
		margin-top: 120px !important;
	}
	.mb-sp120 {
		margin-bottom: 120px !important;
	}
	.pt-sp120 {
		padding-top: 120px !important;
	}
	.pb-sp120 {
		padding-bottom: 120px !important;
	}
	.mt-sp125 {
		margin-top: 125px !important;
	}
	.mb-sp125 {
		margin-bottom: 125px !important;
	}
	.pt-sp125 {
		padding-top: 125px !important;
	}
	.pb-sp125 {
		padding-bottom: 125px !important;
	}
	.mt-sp130 {
		margin-top: 130px !important;
	}
	.mb-sp130 {
		margin-bottom: 130px !important;
	}
	.pt-sp130 {
		padding-top: 130px !important;
	}
	.pb-sp130 {
		padding-bottom: 130px !important;
	}
	.mt-sp135 {
		margin-top: 135px !important;
	}
	.mb-sp135 {
		margin-bottom: 135px !important;
	}
	.pt-sp135 {
		padding-top: 135px !important;
	}
	.pb-sp135 {
		padding-bottom: 135px !important;
	}
	.mt-sp140 {
		margin-top: 140px !important;
	}
	.mb-sp140 {
		margin-bottom: 140px !important;
	}
	.pt-sp140 {
		padding-top: 140px !important;
	}
	.pb-sp140 {
		padding-bottom: 140px !important;
	}
	.mt-sp145 {
		margin-top: 145px !important;
	}
	.mb-sp145 {
		margin-bottom: 145px !important;
	}
	.pt-sp145 {
		padding-top: 145px !important;
	}
	.pb-sp145 {
		padding-bottom: 145px !important;
	}
	.mt-sp150 {
		margin-top: 150px !important;
	}
	.mb-sp150 {
		margin-bottom: 150px !important;
	}
	.pt-sp150 {
		padding-top: 150px !important;
	}
	.pb-sp150 {
		padding-bottom: 150px !important;
	}
	.mt-sp155 {
		margin-top: 155px !important;
	}
	.mb-sp155 {
		margin-bottom: 155px !important;
	}
	.pt-sp155 {
		padding-top: 155px !important;
	}
	.pb-sp155 {
		padding-bottom: 155px !important;
	}
	.mt-sp160 {
		margin-top: 160px !important;
	}
	.mb-sp160 {
		margin-bottom: 160px !important;
	}
	.pt-sp160 {
		padding-top: 160px !important;
	}
	.pb-sp160 {
		padding-bottom: 160px !important;
	}
	.mt-sp165 {
		margin-top: 165px !important;
	}
	.mb-sp165 {
		margin-bottom: 165px !important;
	}
	.pt-sp165 {
		padding-top: 165px !important;
	}
	.pb-sp165 {
		padding-bottom: 165px !important;
	}
	.mt-sp170 {
		margin-top: 170px !important;
	}
	.mb-sp170 {
		margin-bottom: 170px !important;
	}
	.pt-sp170 {
		padding-top: 170px !important;
	}
	.pb-sp170 {
		padding-bottom: 170px !important;
	}
	.mt-sp175 {
		margin-top: 175px !important;
	}
	.mb-sp175 {
		margin-bottom: 175px !important;
	}
	.pt-sp175 {
		padding-top: 175px !important;
	}
	.pb-sp175 {
		padding-bottom: 175px !important;
	}
	.mt-sp180 {
		margin-top: 180px !important;
	}
	.mb-sp180 {
		margin-bottom: 180px !important;
	}
	.pt-sp180 {
		padding-top: 180px !important;
	}
	.pb-sp180 {
		padding-bottom: 180px !important;
	}
	.mt-sp185 {
		margin-top: 185px !important;
	}
	.mb-sp185 {
		margin-bottom: 185px !important;
	}
	.pt-sp185 {
		padding-top: 185px !important;
	}
	.pb-sp185 {
		padding-bottom: 185px !important;
	}
	.mt-sp190 {
		margin-top: 190px !important;
	}
	.mb-sp190 {
		margin-bottom: 190px !important;
	}
	.pt-sp190 {
		padding-top: 190px !important;
	}
	.pb-sp190 {
		padding-bottom: 190px !important;
	}
	.mt-sp195 {
		margin-top: 195px !important;
	}
	.mb-sp195 {
		margin-bottom: 195px !important;
	}
	.pt-sp195 {
		padding-top: 195px !important;
	}
	.pb-sp195 {
		padding-bottom: 195px !important;
	}
	.mt-sp200 {
		margin-top: 200px !important;
	}
	.mb-sp200 {
		margin-bottom: 200px !important;
	}
	.pt-sp200 {
		padding-top: 200px !important;
	}
	.pb-sp200 {
		padding-bottom: 200px !important;
	}
}
main {
	padding-bottom: clamp(6rem, 8vw, 10rem);
}
@media screen and (max-width: 640px) {
	main {
		padding-bottom: 30px;
	}
}
.c-inner {
	margin-inline: auto;
	width: min(1000px, 100% - 20px);
}
.c-text-center {
	text-align: center;
}
.c-title,
.c-title--center {
	display: grid;
}
.c-title--center {
	text-align: center;
	max-inline-size: max-content;
	margin-inline: auto;
}
.c-title-wrap {
	display: grid;
}
@media screen and (max-width: 640px) {
	.c-title-wrap {
		margin-bottom: 40px;
	}
}
.c-title-text,
.c-title-text--sp-left {
	text-align: center;
	margin-top: 30px;
}
.c-title-text-em + .c-title-text,
.c-title-text-em--center + .c-title-text,
.c-title-text-em--center-sp-left + .c-title-text,
.c-title-text-em + .c-title-text--sp-left,
.c-title-text-em--center + .c-title-text--sp-left,
.c-title-text-em--center-sp-left + .c-title-text--sp-left {
	margin-top: 30px;
}
@media screen and (max-width: 640px) {
	.c-title-text--sp-left {
		text-align: left;
	}
}
.c-title-text-em,
.c-title-text-em--center,
.c-title-text-em--center-sp-left {
	font-size: clamp(2.3rem, 3.2vw, 2rem);
	margin-top: clamp(6rem, 6vw, 7.2rem);
}
@media screen and (max-width: 640px) {
	.c-title-text-em,
	.c-title-text-em--center,
	.c-title-text-em--center-sp-left {
		margin-top: 30px;
		line-height: 1.6em;
	}
}
.c-title-text-em--center,
.c-title-text-em--center-sp-left {
	text-align: center;
}
@media screen and (max-width: 640px) {
	.c-title-text-em--center-sp-left {
		text-align: left;
	}
}
.c-title-em {
	font-size: clamp(5rem, 5vw, 6rem);
	font-weight: 400;
}
@media screen and (max-width: 640px) {
	.c-title-em {
		font-size: 2.5rem;
	}
}
.c-title-en,
.c-title-en--white {
	position: relative;
	width: 272px;
	z-index: 0;
	margin-inline: auto;
}
.c-title-en span,
.c-title-en--white span {
	color: #8b8b8b;
	background-color: #f7fdf2;
	padding-inline: 10px;
	font-size: clamp(1.8rem, 1.8vw, 2rem);
	font-weight: 400;
}
.c-title-en--white span {
	background-color: #fff;
}
.c-title-en::before,
.c-title-en--white::before {
	content: "";
	position: absolute;
	top: 60%;
	width: 100%;
	height: 2px;
	background-color: #5aaa46;
	translate: 0 -50%;
	left: 0;
	z-index: -1;
}
.c-icon-title,
.c-icon-title--construction,
.c-icon-title--mentenance {
	display: grid;
	color: #fff;
	position: relative;
	padding-left: 5em;
	gap: 4px;
}
@media screen and (max-width: 640px) {
	.c-icon-title,
	.c-icon-title--construction,
	.c-icon-title--mentenance {
		padding-left: 4em;
	}
}
.c-icon-title::before,
.c-icon-title--construction::before,
.c-icon-title--mentenance::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	translate: 0 -50%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
@media screen and (max-width: 640px) {
	.c-icon-title::before,
	.c-icon-title--construction::before,
	.c-icon-title--mentenance::before {
		scale: 0.7;
		transform-origin: left center;
	}
}
.c-icon-title-en {
	font-size: clamp(1.4rem, 1.6vw, 1.6rem);
}
.c-icon-title-em {
	font-size: clamp(2.5rem, 3.6vw, 3.6rem);
}
.c-icon-title--mentenance::before {
	width: 80px;
	height: 76px;
	background-image: url("../images/common/icon_maintenance.svg");
}
.c-icon-title--construction::before {
	width: 86px;
	height: 65px;
	background-image: url("../images/common/icon_architecture.svg");
}
.c-main-color,
.c-main-color--em {
	color: #5aaa46;
}
.c-line-title,
.c-line-title--s {
	font-size: clamp(2rem, 2.2vw, 1.5rem);
	position: relative;
	padding-left: 0.7em;
	font-weight: 700;
	letter-spacing: 0.2em;
}
@media screen and (max-width: 640px) {
	.c-line-title,
	.c-line-title--s {
		margin-bottom: 20px;
		line-height: 1.4em;
	}
}
@media screen and (max-width: 640px) {
	* + .c-line-title,
	* + .c-line-title--s {
		margin-top: 60px;
	}
}
.c-line-title--s {
	font-size: clamp(1.6rem, 1.6vw, 1.6rem);
	padding-left: 1em;
}
.c-line-title--s::before {
	width: 6px;
}
.c-line-title::before,
.c-line-title--s::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 4px;
	height: 80%;
	background-color: #5aaa46;
	top: 50%;
	translate: 0 -50%;
}
@media screen and (max-width: 640px) {
	.c-line-title::before,
	.c-line-title--s::before {
		width: 3px;
		height: 80%;
	}
}
.sdgs-img-list + .c-line-title,
.sdgs-img-list + .c-line-title--s {
	margin-top: 60px;
}
.sdgs-main-head {
	background-color: #f7fdf2;
	width: 100%;
	overflow: hidden;
	z-index: 0;
	position: relative;
}
@media screen and (min-width: 641px) {
	.sdgs-main-head {
		height: 460px;
	}
}
@media screen and (max-width: 640px) {
	.sdgs-main-head {
		padding: 70px 9px 316px;
	}
}
@media screen and (max-width: 640px) {
	.sdgs-main-head::before {
		content: "";
		position: absolute;
		width: 724px;
		height: 280px;
		background: url("../images/common/bg_sdgs.png") no-repeat center;
		background-size: contain;
		z-index: -1;
		left: 0;
		translate: 0 216px;
		top: 0;
	}
}
.sdgs-main-head-inner {
	height: 100%;
	display: grid;
	width: min(1000px, 100%);
	margin-inline: auto;
}
@media screen and (min-width: 641px) {
	.sdgs-main-head-inner {
		grid-template-columns: auto 1fr;
	}
}
.sdgs-main-head-img {
	position: relative;
	z-index: -1;
}
@media screen and (max-width: 640px) {
	.sdgs-main-head-img {
		display: none;
	}
}
.sdgs-main-head-figure {
	position: absolute;
	left: 0;
	top: 0;
	width: 1700px;
	translate: -9% -100px;
	z-index: -1;
}
.sdgs-main-head-title,
.top-sdgs-main-head-title-br,
.sdgs-main-head-title-br {
	font-size: clamp(2.5rem, 4vw, 5rem);
	font-weight: 700;
	line-height: 2em;
}
@media screen and (min-width: 641px) {
	.sdgs-main-head-title,
	.top-sdgs-main-head-title-br,
	.sdgs-main-head-title-br {
		align-self: center;
		margin-inline: auto 0;
	}
}
.sdgs-main-head-title-group {
	display: grid;
	place-content: center;
}
@media screen and (max-width: 640px) {
	.sdgs-main-head-title-group {
		place-content: start;
		grid-template-columns: 1fr;
	}
}
.sdgs-main-head-title-em {
	font-size: clamp(7rem, 7vw, 8rem);
	color: #5aaa46;
	font-weight: 700;
	letter-spacing: -0.05em;
}
@media screen and (max-width: 640px) {
	.sdgs-main-head-title-em {
		font-size: 4.6rem;
	}
}
.sdgs-main-head-title-br {
	display: block;
	font-weight: 700;
}
@media screen and (max-width: 640px) {
	.sdgs-main-head-title-br {
		font-size: 3.5rem;
		text-align: left;
	}
}
.top-sdgs-main-head {
	background-color: #f7fdf2;
	width: 100%;
	overflow: hidden;
	z-index: 0;
	position: relative;
}
@media screen and (min-width: 641px) {
	.top-sdgs-main-head {
		height: 658px;
	}
}
@media screen and (max-width: 640px) {
	.top-sdgs-main-head {
		padding: 70px 9px 50px;
	}
}
@media screen and (max-width: 640px) {
	.top-sdgs-main-head::before {
		content: "";
		position: absolute;
		width: 724px;
		height: 280px;
		background: url("../images/common/bg_sdgs.png") no-repeat center;
		background-size: contain;
		z-index: -1;
		left: 0;
		translate: 0 216px;
		top: 0;
	}
}
.top-sdgs-main-head-inner {
	height: 100%;
	display: grid;
	width: min(1000px, 100% - 20px);
	margin-inline: auto;
}
@media screen and (min-width: 641px) {
	.top-sdgs-main-head-inner {
		grid-template-columns: auto 1fr;
	}
}
.top-sdgs-main-head-img {
	position: relative;
	z-index: -1;
}
@media screen and (max-width: 640px) {
	.top-sdgs-main-head-img {
		display: none;
	}
}
.top-sdgs-main-head-figure {
	position: absolute;
	left: 0;
	top: 0;
	width: 1702px;
	translate: -14.5% 0;
	z-index: -1;
}
.top-sdgs-main-head-title {
	font-size: clamp(2.5rem, 4vw, 5rem);
	line-height: 2em;
	align-self: center;
}
@media screen and (min-width: 641px) {
	.top-sdgs-main-head-title {
		margin-inline: auto 0;
	}
}
.top-sdgs-main-head-title-group {
	display: grid;
	place-content: center;
	padding-bottom: 95px;
}
@media screen and (max-width: 640px) {
	.top-sdgs-main-head-title-group {
		place-content: start;
		grid-template-columns: 1fr;
	}
}
@media screen and (max-width: 640px) {
	.top-sdgs-main-head-title-group > [class*="c-button"] {
		margin-top: 356px;
	}
}
@media screen and (max-width: 640px) {
	.top-sdgs-main-head-title-group > [class*="c-button"] .c-button-item {
		margin-inline: auto;
	}
}
.top-sdgs-main-head-title-em {
	font-size: clamp(7rem, 7vw, 8rem);
	color: #5aaa46;
	letter-spacing: -0.05em;
}
@media screen and (max-width: 640px) {
	.top-sdgs-main-head-title-em {
		font-size: 4.6rem;
	}
}
@media (max-width: 370px) {
	.top-sdgs-main-head-title-em {
		font-size: 3.5rem;
	}
}
.top-sdgs-main-head-title-br {
	display: block;
}
@media screen and (max-width: 640px) {
	.top-sdgs-main-head-title-br {
		font-size: 3.5rem;
		text-align: left;
	}
}
@media (max-width: 370px) {
	.top-sdgs-main-head-title-br {
		font-size: 2.8rem;
	}
}
.sdgs-title {
	margin-inline: auto;
	max-inline-size: max-content;
	color: #5aaa46;
	font-size: clamp(3.5rem, 3.5vw, 2.5rem);
}
@media screen and (max-width: 640px) {
	.sdgs-title {
		line-height: 1.2em;
		font-size: 3rem;
	}
}
.sdgs-title-highlight {
	background: linear-gradient(transparent 73%, #fff500 70%);
	background-position: 0px -9px;
}
.sdgs-text {
	text-align: center;
}
@media screen and (min-width: 641px) {
	.sdgs-text {
		line-height: 2em;
	}
}
@media screen and (max-width: 640px) {
	.sdgs-text {
		text-align: left;
	}
}
.c-company-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(333px, 1fr));
	gap: 80px 0;
}
@media (max-width: 1050px) {
	.c-company-list {
		width: calc(100% + 20px);
		translate: -10px 0;
		gap: 40px 0;
		grid-template-columns: repeat(2, 1fr);
		max-width: 800px;
		margin-inline: auto;
	}
}
.c-company-list-link {
	display: block;
	background-color: #f8f8f8;
	padding-bottom: 15px;
}
@media screen and (max-width: 1000px) {
	.c-company-list-link {
		padding-inline: 10px;
		height: 100%;
	}
}
.c-company-list-link-title-ja {
	color: #fff;
}
.c-company-list-figure {
	display: grid;
	vertical-align: middle;
}
@media screen and (max-width: 1000px) {
	.c-company-list-figure {
		width: calc(100% + 20px);
		translate: -10px 0;
	}
}
.c-company-list-figure img {
	width: calc(100% + 1px);
	max-width: calc(100% + 1px);
	height: 100%;
	aspect-ratio: 333/211;
	object-fit: cover;
}
.c-company-list-text {
	margin-top: 15px;
	text-align: center;
	font-size: clamp(1.2rem, 1.2vw, 1.2rem);
	color: #5aaa46;
}
.c-company-list-title {
	text-align: center;
	font-weight: 600;
	display: grid;
	color: #fff;
	place-content: center;
	height: 100%;
	font-weight: 400;
}
.c-company-list-title-en {
	font-size: clamp(1.4rem, 1.6vw, 1.6rem);
	padding-bottom: 35px;
	position: relative;
}
.c-company-list-title-en::after {
	content: "";
	position: absolute;
	width: 200px;
	height: 15px;
	background: url("../images/common/group.svg") no-repeat center;
	background-size: cover;
	left: 50%;
	translate: -50% 0;
	bottom: 0;
}
.c-company-list-title-ja {
	font-size: clamp(2.2rem, 2.5vw, 2.8rem);
}
.c-company-list-name {
	text-align: center;
	text-decoration: none;
	border-bottom: 0;
	font-size: clamp(1.4rem, 1.6vw, 1.6rem);
	font-weight: 500;
	position: relative;
}
.c-company-list-item--green {
	background-color: #5aaa46;
	grid-row: 1/3;
}
@media (max-width: 1050px) {
	.c-company-list-item--green {
		grid-row: 1/2;
		grid-column: 1/3;
		padding-block: 2em;
	}
}
.sdgs-img-list {
	display: grid;
	justify-content: center;
}
@media screen and (min-width: 641px) {
	.sdgs-img-list {
		gap: 40px;
		margin-top: 84px;
	}
}
@media screen and (max-width: 640px) {
	.sdgs-img-list {
		gap: 10px;
		margin-top: 39px;
	}
}
@media screen and (min-width: 641px) {
	.sdgs-img-list {
		grid-template-columns: repeat(auto-fit, minmax(140px, min(100px, 100%)));
	}
}
@media screen and (max-width: 640px) {
	.sdgs-img-list {
		grid-template-columns: repeat(2, minmax(0, 140px));
	}
}
.sdgs-img-list-figure {
	display: grid;
	vertical-align: middle;
}
@media screen and (min-width: 641px) {
	.sdgs-img-list-figure {
		width: 140px;
		aspect-ratio: 1/1;
		object-fit: cover;
	}
}
.sdgs-img-list-figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.c-img-block--center {
	text-align: center;
}
.section-wrap,
.section-wrap--green,
.section-wrap--green--town,
.section-wrap--green--earth,
.section-wrap--white,
.section-wrap--white-bg-people {
	padding-block: 135px 200px;
}
@media screen and (max-width: 1000px) {
	.section-wrap,
	.section-wrap--green,
	.section-wrap--green--town,
	.section-wrap--green--earth,
	.section-wrap--white,
	.section-wrap--white-bg-people {
		padding-block: 100px 100px;
	}
}
@media screen and (max-width: 640px) {
	.section-wrap,
	.section-wrap--green,
	.section-wrap--green--town,
	.section-wrap--green--earth,
	.section-wrap--white,
	.section-wrap--white-bg-people {
		padding-block: 60px;
	}
}
.section-wrap--white-bg-people {
	position: relative;
	padding-bottom: 272px;
}
@media screen and (max-width: 640px) {
	.section-wrap--white-bg-people {
		padding-bottom: 130px;
	}
}
.section-wrap--white-bg-people::before {
	content: "";
	position: absolute;
	left: 50%;
	translate: -50% 0;
	width: min(1257px, 100%);
	background: url("../images/sdgs/bg_people.png") no-repeat bottom center;
	background-size: cover;
	bottom: 0;
}
@media screen and (min-width: 641px) {
	.section-wrap--white-bg-people::before {
		height: 196px;
	}
}
@media screen and (max-width: 640px) {
	.section-wrap--white-bg-people::before {
		height: 100px;
	}
}
.section-wrap--green,
.section-wrap--green--town,
.section-wrap--green--earth {
	background-color: #f7fdf2;
	position: relative;
}
@media screen and (min-width: 641px) {
	.section-wrap--green,
	.section-wrap--green--town,
	.section-wrap--green--earth {
		padding-block: 115px;
	}
}
.section-wrap--green--earth {
	position: relative;
	padding-bottom: clamp(15rem, 20vw, 176rem);
}
@media screen and (max-width: 640px) {
	.section-wrap--green--earth .c-img-block-figure {
		max-width: 400px;
		margin-inline: auto;
	}
}
.section-wrap--green--earth::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	translate: -50% 0;
	background: url("../images/sdgs/bg_cloud_earth.svg") no-repeat center;
	width: 738px;
	height: 146px;
	background-size: cover;
}
@media screen and (max-width: 1000px) {
	.section-wrap--green--earth::after {
		width: max(70%, 250px);
		background-position: bottom center;
		background-size: contain;
	}
}
.section-wrap--green--earth::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	translate: -50% 0;
	background: url("../images/sdgs/cloud.svg") repeat-x;
	background-position: center bottom;
	width: 100%;
	height: 180px;
	background-size: contain;
}
.section-wrap--green--town {
	padding-bottom: 180px;
}
@media screen and (max-width: 640px) {
	.section-wrap--green--town {
		padding-block: 50px 120px;
	}
}
.section-wrap--green--town::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	background: url("../images/top/bg_town.svg") repeat-x center;
	width: 100%;
	height: 156px;
	background-size: auto;
	translate: -50% 30%;
}
@media screen and (max-width: 640px) {
	.section-wrap--green--town::before {
		width: 100%;
		translate: -50% 0;
		height: 90px;
		background-size: cover;
	}
}
.c-dot-list {
	display: grid;
	row-gap: 8px;
}
.c-dot-list-item {
	position: relative;
	padding-left: 1em;
}
@media screen and (max-width: 640px) {
	.c-dot-list-item {
		padding-left: 0.8em;
	}
}
.c-dot-list-item::before {
	content: "";
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background-color: #000;
	position: absolute;
	left: 0;
	top: 1em;
}
.c-line-title + .c-dot-list,
.c-line-title--s + .c-dot-list {
	margin-top: 8px;
}
.c-increment-list {
	display: grid;
	row-gap: 8px;
}
.c-increment-list-item {
	display: flex;
}
.c-increment-list-item::before {
	content: "";
	margin-right: 2px;
}
.c-increment-list-item:nth-child(1)::before {
	content: "①";
}
.c-increment-list-item:nth-child(2)::before {
	content: "②";
}
.c-increment-list-item:nth-child(3)::before {
	content: "③";
}
.c-increment-list-item:nth-child(4)::before {
	content: "④";
}
.c-increment-list-item:nth-child(5)::before {
	content: "⑤";
}
.c-increment-list-item:nth-child(6)::before {
	content: "⑥";
}
.c-increment-list-item:nth-child(7)::before {
	content: "⑦";
}
.c-increment-list-item:nth-child(8)::before {
	content: "⑧";
}
.c-increment-list-item:nth-child(9)::before {
	content: "⑨";
}
.c-increment-list-item:nth-child(10)::before {
	content: "⑩";
}
.c-line-title + .c-increment-list,
.c-line-title--s + .c-increment-list {
	margin-top: 20px;
}
.c-line-block,
.c-line-block--development,
.c-line-block--evolution,
.c-line-block--protection {
	background-color: #fff;
	position: relative;
	z-index: 0;
}
.c-line-block ~ .c-line-block,
.c-line-block--development ~ .c-line-block,
.c-line-block ~ .c-line-block--development,
.c-line-block--development ~ .c-line-block--development,
.c-line-block--evolution ~ .c-line-block,
.c-line-block--evolution ~ .c-line-block--development,
.c-line-block ~ .c-line-block--evolution,
.c-line-block--development ~ .c-line-block--evolution,
.c-line-block--evolution ~ .c-line-block--evolution,
.c-line-block--protection ~ .c-line-block,
.c-line-block--protection ~ .c-line-block--development,
.c-line-block--protection ~ .c-line-block--evolution,
.c-line-block ~ .c-line-block--protection,
.c-line-block--development ~ .c-line-block--protection,
.c-line-block--evolution ~ .c-line-block--protection,
.c-line-block--protection ~ .c-line-block--protection {
	margin-top: clamp(14rem, 15vw, 17rem);
}
@media screen and (max-width: 640px) {
	.c-line-block ~ .c-line-block,
	.c-line-block--development ~ .c-line-block,
	.c-line-block ~ .c-line-block--development,
	.c-line-block--development ~ .c-line-block--development,
	.c-line-block--evolution ~ .c-line-block,
	.c-line-block--evolution ~ .c-line-block--development,
	.c-line-block ~ .c-line-block--evolution,
	.c-line-block--development ~ .c-line-block--evolution,
	.c-line-block--evolution ~ .c-line-block--evolution,
	.c-line-block--protection ~ .c-line-block,
	.c-line-block--protection ~ .c-line-block--development,
	.c-line-block--protection ~ .c-line-block--evolution,
	.c-line-block ~ .c-line-block--protection,
	.c-line-block--development ~ .c-line-block--protection,
	.c-line-block--evolution ~ .c-line-block--protection,
	.c-line-block--protection ~ .c-line-block--protection {
		margin-top: 100px;
	}
}
.c-line-block::before,
.c-line-block--development::before,
.c-line-block--evolution::before,
.c-line-block--protection::before,
.c-line-block::after,
.c-line-block--development::after,
.c-line-block--evolution::after,
.c-line-block--protection::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: min(1000px, 100%);
	background: url(../images/sdgs/bg_line.svg) repeat left top;
	font-size: clamp(2.5rem, 4vw, 2.5rem);
}
@media screen and (min-width: 641px) {
	.c-line-block::before,
	.c-line-block--development::before,
	.c-line-block--evolution::before,
	.c-line-block--protection::before,
	.c-line-block::after,
	.c-line-block--development::after,
	.c-line-block--evolution::after,
	.c-line-block--protection::after {
		height: 19px;
	}
}
@media screen and (max-width: 640px) {
	.c-line-block::before,
	.c-line-block--development::before,
	.c-line-block--evolution::before,
	.c-line-block--protection::before,
	.c-line-block::after,
	.c-line-block--development::after,
	.c-line-block--evolution::after,
	.c-line-block--protection::after {
		height: 10px;
	}
}
.c-line-block::after,
.c-line-block--development::after,
.c-line-block--evolution::after,
.c-line-block--protection::after {
	top: auto;
	bottom: 0;
}
.c-line-block--protection .c-line-block-group::after {
	width: 217px;
	height: 160px;
	background-image: url("../images/sdgs/bg_protection.svg");
}
.c-line-block--evolution .c-line-block-group::after {
	width: 262px;
	height: 160px;
	background-image: url("../images/sdgs/bg_evolution.svg");
}
.c-line-block--development .c-line-block-group::after {
	width: 190px;
	height: 185px;
	bottom: 0;
	background-image: url("../images/sdgs/bg_development.svg");
}
.c-line-block-title {
	border-radius: 50%;
	aspect-ratio: 1/1;
	position: absolute;
	left: 50%;
	top: 0;
	translate: -50% -35%;
	display: grid;
	background-color: #fff;
	z-index: 1;
	padding-top: 70px;
	text-align: center;
	box-sizing: border-box;
	font-size: clamp(3rem, 3.5vw, 2.5rem);
	width: 291px;
	font-weight: 700;
	letter-spacing: 0.2em;
}
@media screen and (max-width: 1000px) {
	.c-line-block-title {
		width: 200px;
		padding-top: 50px;
	}
}
@media screen and (max-width: 640px) {
	.c-line-block-title {
		padding-top: 30px;
		font-size: 2.5rem;
		width: 150px;
	}
}
@media screen and (min-width: 1001px) {
	.c-line-block-contents {
		padding: 136px 80px 130px;
	}
}
@media screen and (max-width: 1000px) {
	.c-line-block-contents {
		padding: 80px 40px;
	}
}
@media screen and (max-width: 640px) {
	.c-line-block-contents {
		padding: 45px 20px;
	}
}
.c-line-block-group {
	position: relative;
	z-index: 2;
}
@media screen and (max-width: 1000px) {
	.c-line-block-group {
		padding-bottom: 145px;
	}
}
@media screen and (max-width: 640px) {
	.c-line-block-group {
		padding-bottom: 125px;
	}
}
.c-line-block-group::after {
	content: "";
	position: absolute;
	bottom: -31px;
	right: 40px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
@media screen and (max-width: 640px) {
	.c-line-block-group::after {
		scale: 0.7;
		transform-origin: bottom right;
		right: 0;
		bottom: 0;
	}
}
.main-head {
	background-color: #f7fdf2;
	width: 100%;
	overflow: hidden;
}
@media screen and (min-width: 1001px) {
	.main-head {
		height: 300px;
	}
}
.main-head-inner {
	height: 100%;
	display: grid;
	width: min(1000px, 100% - 20px);
	margin-inline: auto;
	z-index: 0;
	position: relative;
}
@media screen and (min-width: 641px) {
	.main-head-inner {
		grid-template-columns: 1fr auto;
	}
}
@media screen and (max-width: 1000px) {
	.main-head-inner {
		grid-template-columns: 1fr 50%;
	}
}
@media screen and (max-width: 640px) {
	.main-head-inner {
		grid-template-columns: 1fr;
		padding-block: 40px 0;
	}
}
.main-head-img {
	position: relative;
	align-self: end;
}
@media screen and (max-width: 640px) {
	.main-head-img {
		margin-top: 20px;
	}
}
.main-head-figure {
	display: grid;
	vertical-align: middle;
}
@media screen and (max-width: 640px) {
	.main-head-figure {
		width: min(400px, 100% - 30px);
		margin-inline: auto;
	}
}
.main-head-title {
	line-height: 1.4em;
	align-self: center;
	letter-spacing: 0.1em;
}
@media screen and (min-width: 1001px) {
	.main-head-title {
		padding-bottom: 20px;
	}
}
@media screen and (max-width: 1000px) {
	.main-head-title {
		display: grid;
		place-content: center;
	}
}
@media screen and (max-width: 640px) {
	.main-head-title {
		justify-content: center;
		text-align: center;
	}
}
.main-head-title-em,
.main-head-title-em--icon-architecture {
	font-size: clamp(2.5rem, 4vw, 2.5rem);
	color: #5aaa46;
	font-weight: 700;
	display: inline-block;
}
@media screen and (max-width: 640px) {
	.main-head-title-em,
	.main-head-title-em--icon-architecture {
		font-size: 2.5rem;
	}
}
@media screen and (min-width: 1001px) {
	.main-head-title-em br,
	.main-head-title-em--icon-architecture br {
		display: none;
	}
}
.main-head-title-em--icon-architecture {
	position: relative;
	padding-right: 1.8em;
	font-weight: 700;
	line-height: 1.1em;
}
@media screen and (max-width: 640px) {
	.main-head-title-em--icon-architecture {
		padding-right: 1.5em;
		margin-top: 4px;
		display: inline-block;
		translate: 0.8em 0;
	}
}
.main-head-title-em--icon-architecture::after {
	content: "";
	position: absolute;
	right: 0;
	top: 55%;
	translate: 0 -50%;
	width: 54px;
	height: 40px;
	background: url("../images/common/icon_architecture_mcolor.svg") no-repeat center;
	background-size: cover;
}
.main-head-title-en {
	display: block;
	color: #8b8b8b;
	margin-top: 6px;
	font-size: clamp(1.8rem, 2vw, 2rem);
}
.c-grid,
.c-grid--img-right {
	display: grid;
	margin-inline: auto;
	align-items: flex-start;
	width: min(1500px, 100% - 20px);
}
@media screen and (min-width: 641px) {
	.c-grid,
	.c-grid--img-right {
		column-gap: 8%;
	}
}
@media screen and (max-width: 1000px) {
	.c-grid,
	.c-grid--img-right {
		column-gap: 5%;
	}
}
.c-grid--img-right {
	position: relative;
}
@media screen and (min-width: 641px) {
	.c-grid--img-right {
		grid-template-columns: 1fr min(550px, 40%);
	}
}
@media screen and (max-width: 640px) {
	.c-grid--img-right {
		padding-inline: 10px;
	}
}
@media (max-width: 768px) {
	.c-grid--img-right {
		grid-template-columns: 1fr;
	}
}
.c-grid--img-right::before {
	z-index: -1;
	content: "Message";
	position: absolute;
	left: 0;
	top: 0;
	font-size: clamp(10rem, 18vw, 12.5rem);
	color: #f7fdf2;
	line-height: 1;
	translate: 0 -78px;
}
@media screen and (max-width: 640px) {
	.c-grid--img-right::before {
		font-size: 6.7rem;
		translate: 0 -32px;
	}
}
.c-grid--img-right .c-grid-item:first-child {
	margin-inline: auto 0;
}
@media screen and (min-width: 1001px) {
	.c-grid--img-right .c-grid-item:first-child {
		width: min(550px, 100%);
	}
}
@media screen and (max-width: 640px) {
	.c-grid--img-right .c-grid-item:first-child {
		margin-inline: auto;
	}
}
@media (max-width: 768px) {
	.c-grid--img-right .c-grid-item:nth-child(2) {
		margin-top: 30px;
	}
	.c-grid--img-right .c-grid-item:nth-child(2) figure {
		width: min(100%, 450px);
		max-height: 450px;
		overflow: hidden;
		margin-inline: auto;
	}
	.c-grid--img-right .c-grid-item:nth-child(2) figure img {
		width: 100%;
	}
}
@media screen and (max-width: 1000px) {
	.c-grid--img-right .c-grid-item:nth-child(2) {
		width: calc(100% + 10px);
	}
}
.c-grid-title {
	display: block;
	line-height: 1.6em;
}
@media screen and (min-width: 1001px) {
	.c-grid-title {
		white-space: nowrap;
	}
}
@media screen and (max-width: 1000px) {
	.c-grid-title {
		margin-bottom: 20px;
	}
}
.c-grid-title-green {
	color: #5aaa46;
}
.c-grid-title-em {
	font-size: clamp(2.3rem, 2.8vw, 3.2rem);
	display: block;
	line-height: 1.6em;
	font-weight: 700;
}
@media screen and (max-width: 640px) {
	.c-grid-title-em {
		line-height: 1.9em;
		margin-bottom: 10px;
	}
}
.c-grid-text,
.c-grid-text-en {
	line-height: 2em;
}
.c-grid-text + .c-grid-text,
.c-grid-text + .c-grid-text-en {
	margin-top: clamp(2rem, 4vw, 2.5rem);
}
.c-grid-title + .c-grid-text,
.c-grid-title + .c-grid-text-en {
	margin-top: clamp(2rem, 4vw, 2.5rem);
}
.recruit-card-wrap,
.recruit-card-wrap--col2 {
	display: grid;
}
.recruit-card-wrap--col2 {
	justify-content: space-between;
	max-width: 1440px;
	margin-inline: auto;
	gap: 22px;
}
@media screen and (min-width: 641px) {
	.recruit-card-wrap--col2 {
		grid-template-columns: repeat(2, 1fr);
		justify-content: center;
	}
}
@media (max-width: 768px) {
	.recruit-card-wrap--col2 {
		max-width: 489px;
		grid-template-columns: 1fr;
	}
}
.recruit-card--maintenance .recruit-card-name::before {
	width: 60px;
	height: 57px;
	background-image: url("../images/common/icon_maintenance.svg");
}
.recruit-card--architecture .recruit-card-name::before {
	width: 65px;
	height: 49px;
	top: 15px;
	background-image: url("../images/common/icon_architecture.svg");
}
.recruit-card-name {
	font-size: clamp(3rem, 3.5vw, 4rem);
	position: relative;
	padding-top: clamp(6rem, 7vw, 8.5rem);
}
@media screen and (max-width: 640px) {
	.recruit-card-name {
		padding-top: 43px;
	}
}
.recruit-card-name::before {
	content: "";
	top: 0;
	left: 50%;
	translate: -50% 0;
	position: absolute;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
@media screen and (max-width: 640px) {
	.recruit-card-name::before {
		scale: 0.7;
		transform-origin: top center;
	}
}
.recruit-card-comment {
	font-weight: 400;
	font-size: clamp(1.4rem, 1.5vw, 1.6rem);
	margin-top: clamp(0.8rem, 1.5vw, 2rem);
}
.recruit-card-group {
	overflow: hidden;
	position: relative;
	height: 100%;
}
.recruit-card-link {
	display: block;
	position: relative;
	z-index: 0;
}
.recruit-card-figure {
	width: 100%;
	border-radius: 20px;
	overflow: hidden;
	position: relative;
	display: grid;
	vertical-align: middle;
}
.recruit-card-figure::before {
	content: "";
	position: absolute;
	inset: 0 0 0 0;
	background-color: rgba(0, 0, 0, 0.4);
	z-index: 1;
}
.recruit-card-figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.recruit-card-text,
.top-card-text--center,
.top-card-text--grow,
.recruit-card-text--grow {
	z-index: 2;
	position: absolute;
	text-align: center;
	display: grid;
	inset: 0 0 0 0;
	place-content: center;
	color: #fff;
}
.recruit-card-text--grow {
	flex: 1;
}
.recruit-card-title {
	font-size: clamp(2rem, 3.2vw, 2rem);
}
@media screen and (min-width: 641px) {
	.recruit-card-title {
		margin-top: 26px;
	}
}
@media screen and (max-width: 640px) {
	.recruit-card-title {
		margin-top: 26px;
	}
}
.recruit-card-group {
	display: flex;
	flex-direction: column;
}
.recruit-card-group.is-flex-end {
	justify-content: flex-end;
}
.recruit-card-point {
	background-color: #e8f9f3;
	padding: 16px 20px;
	border: 1px solid #daefe8;
}
@media screen and (min-width: 641px) {
	.recruit-card-point {
		margin-top: 31px;
	}
}
@media screen and (max-width: 640px) {
	.recruit-card-point {
		margin-top: 13px;
	}
}
.recruit-card-point p:first-child {
	color: #5aaa46;
}
@media screen and (min-width: 641px) {
	.recruit-card-point p:not(:first-child) {
		margin-top: 12px;
	}
}
@media screen and (max-width: 640px) {
	.recruit-card-point p:not(:first-child) {
		margin-top: 13px;
	}
}
.recruit-text,
.recruit-text--center {
	font-size: clamp(2.8rem, 2.8vw, 3.2rem);
}
@media screen and (max-width: 640px) {
	.recruit-text,
	.recruit-text--center {
		font-size: 2.3rem;
	}
}
.recruit-text--center {
	text-align: center;
}
.c-button--center .c-button-item {
	margin-inline: auto;
}
.c-button--main .c-button-item,
.c-button--main--center .c-button-item {
	background-color: #00590e;
	color: #fff;
}
.c-button--main--center .c-button-item {
	margin-inline: auto;
}
.c-button--border .c-button-item,
.c-button--border--center .c-button-item {
	background-color: rgba(0, 0, 0, 0);
	border-color: #5aaa46;
	border-width: 2px;
}
.c-button--border .c-button-item span,
.c-button--border--center .c-button-item span {
	color: #000;
}
.c-button--border--center .c-button-item {
	margin-inline: auto;
}
.c-button-item {
	width: min(300px, 100%);
	border: 1px solid #fff;
	display: grid;
	place-content: center;
	position: relative;
	font-size: clamp(1.4rem, 1.6vw, 1.6rem);
	min-height: clamp(5.5rem, 5.5vw, 6rem);
	transition: all 0.3s;
}
.c-button-item span {
	position: relative;
	color: #fff;
	padding-right: 2.2em;
	transition: all 0.3s;
}
@media screen and (max-width: 640px) {
	.c-button-item span {
		padding-right: 2.3em;
	}
}
.c-button-item span::after {
	content: "";
	right: 0;
	top: 50%;
	translate: 0 -50%;
	position: absolute;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	transition: all 0.3s;
}
.c-button-item span.is-icon-blank::after {
	width: 16px;
	height: 16px;
	background-image: url("../images/common/icon_blank.svg");
}
.c-button-item span.is-right-arrow::after {
	width: 20px;
	height: 20px;
	background-image: url("../images/common/icon_right_arrow.svg");
}
.c-button-item span.is-right-arrow--green::after {
	width: 20px;
	height: 20px;
	background-image: url("../images/common/icon_right_arrow_main.svg");
}
a.c-button-item:hover {
	border-color: #5aaa46;
	background-color: #fff;
	opacity: 1 !important;
}
a.c-button-item:hover span {
	color: #5aaa46;
	opacity: 1;
}
a.c-button-item:hover span::after {
	background-image: url("../images/common/icon_right_arrow_main.svg");
}
.c-block-frame-dl,
.c-block-frame-text {
	margin-top: 20px;
}
.c-block-frame,
.c-block-frame--details,
.c-block-frame--entry {
	padding: 60px 58px;
	border: 60px solid #f7fdf2;
	line-height: 2em;
	position: relative;
}
@media screen and (max-width: 640px) {
	.c-block-frame,
	.c-block-frame--details,
	.c-block-frame--entry {
		border: 15px solid #f7fdf2;
		padding: 30px 20px;
		width: calc(100% + 20px);
		translate: -10px 0;
	}
}
@media screen and (max-width: 640px) {
	.c-block-frame,
	.c-block-frame--details,
	.c-block-frame--entry {
		padding-bottom: 220px;
	}
}
.c-block-frame::after,
.c-block-frame--details::after,
.c-block-frame--entry::after {
	content: "";
	position: absolute;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
@media screen and (min-width: 641px) {
	.c-block-frame::after,
	.c-block-frame--details::after,
	.c-block-frame--entry::after {
		right: 58px;
		bottom: 60px;
	}
}
@media screen and (max-width: 640px) {
	.c-block-frame::after,
	.c-block-frame--details::after,
	.c-block-frame--entry::after {
		right: 10px;
		bottom: 10px;
		scale: 0.7;
		transform-origin: right bottom;
	}
}
@media screen and (max-width: 1000px) {
	.c-block-frame--entry {
		padding-bottom: 370px;
	}
}
@media screen and (max-width: 640px) {
	.c-block-frame--entry {
		padding-bottom: 220px;
	}
}
.c-block-frame--entry::after {
	width: 291px;
	height: 240px;
	background-image: url("../images/recruit/entry/bg_entry.svg");
}
@media screen and (min-width: 641px) {
	.c-block-frame--details {
		padding-bottom: 370px;
	}
}
.c-block-frame--details::after {
	width: 355px;
	height: 276px;
	background-image: url("../images/recruit/entry/bg_details.svg");
}
.c-block-frame-list {
	display: grid;
	gap: 40px;
}
@media screen and (min-width: 641px) {
	.c-block-frame-dl {
		display: grid;
		grid-template-columns: auto 1fr;
	}
}
.c-block-frame-dt {
	grid-column: 1/2;
}
.c-block-frame-dd {
	grid-column: 2/3;
}
.c-link-block--center {
	text-align: center;
}
.c-link-block--right {
	text-align: right;
}
* + .c-link-block--right {
	margin-top: 35px;
}
a.c-link {
	border-bottom: 1px solid #000;
}
.c-link-right-arrow {
	padding-right: 1.8em;
	position: relative;
}
.c-link-right-arrow::before {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	width: 20px;
	height: 20px;
	background: url("../images/common/icon_right_arrow_main.svg") no-repeat center;
	background-size: cover;
	translate: 0 -50%;
}
.top-card--maintenance .top-card-name::before {
	background-image: url("../images/common/icon_maintenance.svg");
}
@media screen and (min-width: 641px) {
	.top-card--maintenance .top-card-name::before {
		width: 80px;
		height: 75px;
	}
}
@media screen and (max-width: 640px) {
	.top-card--maintenance .top-card-name::before {
		width: 60px;
		height: 57px;
	}
}
.top-card--architecture .top-card-name::before {
	background-image: url("../images/common/icon_architecture.svg");
}
@media screen and (min-width: 641px) {
	.top-card--architecture .top-card-name::before {
		width: 86px;
		height: 65px;
	}
}
@media screen and (max-width: 640px) {
	.top-card--architecture .top-card-name::before {
		width: 65px;
		height: 49px;
	}
}
.top-card-wrap,
.top-card-wrap--col2 {
	display: grid;
}
.top-card-wrap--col2 {
	justify-content: space-between;
	max-width: 1440px;
	margin-inline: auto;
}
@media screen and (min-width: 1001px) {
	.top-card-wrap--col2 {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media screen and (max-width: 1000px) {
	.top-card-wrap--col2 {
		max-width: 500px;
		row-gap: 20px;
	}
}
.top-card-name {
	font-size: clamp(3rem, 3.5vw, 4rem);
	position: relative;
	padding-top: clamp(6rem, 10vw, 10rem);
}
@media screen and (max-width: 640px) {
	.top-card-name {
		padding-top: 43px;
	}
}
.top-card-name::before {
	content: "";
	top: 0;
	left: 50%;
	translate: -50% 0;
	position: absolute;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
@media screen and (max-width: 640px) {
	.top-card-name::before {
		scale: 0.7;
		transform-origin: top center;
	}
}
.top-card-comment {
	font-weight: 400;
	font-size: clamp(1.5rem, 1.8vw, 2rem);
	margin-top: 5px;
}
.top-card-group {
	overflow: hidden;
	position: relative;
	height: 100%;
}
.top-card-link {
	display: block;
	position: relative;
	z-index: 0;
	height: 100%;
}
@media screen and (min-width: 641px) {
	.top-card-link {
		min-height: 390px;
	}
}
.top-card-figure {
	width: 100%;
	overflow: hidden;
	position: relative;
	display: grid;
	vertical-align: middle;
	height: 100%;
}
.top-card-figure::before {
	content: "";
	position: absolute;
	inset: 0 0 0 0;
	background-color: rgba(0, 0, 0, 0.4);
	z-index: 1;
}
.top-card-figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.top-card-text {
	z-index: 2;
	position: absolute;
	text-align: center;
	display: grid;
	inset: 0 0 0 0;
	place-content: center;
	color: #fff;
}
.top-card-text--grow {
	flex: 1;
}
@media screen and (max-width: 640px) {
	.top-card-text {
		padding-bottom: 20px;
	}
}
.top-card-title {
	font-size: clamp(2rem, 3.2vw, 2rem);
}
@media screen and (min-width: 641px) {
	.top-card-title {
		margin-top: 26px;
	}
}
@media screen and (max-width: 640px) {
	.top-card-title {
		margin-top: 26px;
	}
}
.top-card-group {
	display: flex;
	flex-direction: column;
}
.top-card-group.is-flex-end {
	justify-content: flex-end;
}
.top-card-point {
	background-color: #e8f9f3;
	padding: 16px 20px;
	border: 1px solid #daefe8;
}
@media screen and (min-width: 641px) {
	.top-card-point {
		margin-top: 31px;
	}
}
@media screen and (max-width: 640px) {
	.top-card-point {
		margin-top: 13px;
	}
}
.top-card-point p:first-child {
	color: #5aaa46;
}
@media screen and (min-width: 641px) {
	.top-card-point p:not(:first-child) {
		margin-top: 12px;
	}
}
@media screen and (max-width: 640px) {
	.top-card-point p:not(:first-child) {
		margin-top: 13px;
	}
}
.top-card-text {
	font-size: clamp(2rem, 3.2vw, 2rem);
}
.top-card-text--center {
	text-align: center;
}
.c-works-grid {
	display: grid;
	margin-inline: auto;
}
@media (min-width: 801px) {
	.c-works-grid {
		max-width: 1440px;
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 800px) {
	.c-works-grid {
		max-width: 500px;
	}
}
.c-works-grid-item,
.c-works-grid-item--green,
.c-works-grid-item--main {
	position: relative;
	overflow: hidden;
}
.c-works-grid-item--main {
	background-color: #5aaa46;
}
.c-works-grid-item--green {
	background-color: #00590e;
}
.c-works-grid-link {
	display: grid;
	place-content: center;
	height: 100%;
}
@media (max-width: 800px) {
	.c-works-grid-link {
		min-height: 250px;
	}
}
.c-works-grid-figure {
	display: grid;
	vertical-align: bottom;
}
.c-works-grid-figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.c-works-grid + .c-works-grid {
	margin-top: 20px;
}
.c-works-grid-bg-en {
	position: absolute;
	color: rgba(255, 255, 255, 0.1);
	font-size: clamp(13rem, 13vw, 15rem);
	line-height: 1;
	bottom: 0;
	left: 0;
	translate: -10px 0;
	pointer-events: none;
}
@media (max-width: 800px) {
	.c-works-grid-bg-en {
		font-size: 5rem;
		bottom: 20px;
	}
}
.c-company-grid {
	display: grid;
	gap: 20px;
}
@media (min-width: 801px) {
	.c-company-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 800px) {
	.c-company-grid {
		max-width: 500px;
		margin-inline: auto;
	}
}
.c-company-grid-item,
.c-company-grid-item--overlay {
	display: grid;
	position: relative;
	overflow: hidden;
	z-index: 0;
}
@media (max-width: 800px) {
	.c-company-grid-item,
	.c-company-grid-item--overlay {
		min-height: 275px;
	}
}
.c-company-grid-item:nth-child(1),
.c-company-grid-item--overlay:nth-child(1) {
	grid-row: 1/3;
	background-color: #5aaa46;
	overflow: hidden;
}
@media (max-width: 800px) {
	.c-company-grid-item:nth-child(1),
	.c-company-grid-item--overlay:nth-child(1) {
		min-height: 360px;
	}
}
.c-company-grid-item:nth-child(1)::before,
.c-company-grid-item--overlay:nth-child(1)::before {
	content: "";
	position: absolute;
	left: 50%;
	top: 9%;
	background: url("../images/top/bg_building.svg") no-repeat center;
	width: 1826px;
	height: 261px;
	background-size: 1826px;
	translate: -50% 0;
}
@media (max-width: 800px) {
	.c-company-grid-item:nth-child(1)::before,
	.c-company-grid-item--overlay:nth-child(1)::before {
		width: 972px;
		height: 139px;
		background-size: cover;
	}
}
.c-company-grid-item:nth-child(1) .c-company-grid-link,
.c-company-grid-item--overlay:nth-child(1) .c-company-grid-link {
	align-content: stretch;
}
@media (min-width: 801px) {
	.c-company-grid-item:nth-child(1) .c-company-grid-link,
	.c-company-grid-item--overlay:nth-child(1) .c-company-grid-link {
		padding-bottom: 58px;
	}
}
@media (max-width: 800px) {
	.c-company-grid-item:nth-child(1) .c-company-grid-link,
	.c-company-grid-item--overlay:nth-child(1) .c-company-grid-link {
		padding-bottom: 40px;
	}
}
.c-company-grid-item--overlay {
	min-height: 275px;
}
@media (max-width: 800px) {
	.c-company-grid-item--overlay {
		min-height: 200px;
	}
}
.c-company-grid-item--overlay .c-company-grid-figure::before {
	content: "";
	position: absolute;
	inset: 0 0 0 0;
	background-color: rgba(0, 0, 0, 0.4);
	z-index: 1;
}
.c-company-grid-group {
	display: grid;
	place-content: flex-end center;
}
@media (max-width: 800px) {
	.c-company-grid-group > [class*="c-button"] {
		width: 300px;
		margin-inline: auto;
	}
}
.c-company-grid-title {
	color: #fff;
	font-weight: 400;
	display: grid;
	text-align: center;
	min-height: 89px;
}
.c-company-grid-title-em {
	font-size: clamp(2.5rem, 4vw, 2.5rem);
	letter-spacing: 0.07em;
}
.c-company-grid-title-en {
	font-size: clamp(1.4rem, 1.6vw, 1.6rem);
	translate: 0 -10px;
}
.c-company-grid-figure {
	position: absolute;
	inset: 0 0 0 0;
	z-index: -1;
}
.c-company-grid-figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.c-company-grid-link {
	display: grid;
	align-content: center;
}
@media (min-width: 801px) {
	.c-company-grid-link > [class*="c-button"] {
		margin-top: 10px;
	}
}
.c-article-list {
	display: grid;
	align-items: center;
}
.c-article-list-date {
	font-size: clamp(1.4rem, 1.4vw, 1.4rem);
}
@media screen and (max-width: 640px) {
	.c-article-list-date {
		margin-right: 15px;
	}
}
.c-article-list-text {
	position: relative;
	z-index: 0;
	flex-grow: 1;
	display: inline-block;
	font-size: clamp(1.4rem, 1.4vw, 1.4rem);
	margin-right: 2em;
}
@media screen and (min-width: 641px) {
	.c-article-list-text {
		overflow: hidden;
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 1;
		word-break: break-all;
	}
}
@media screen and (max-width: 640px) {
	.c-article-list-text {
		overflow: hidden;
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 2;
		word-break: break-all;
	}
}
@media screen and (max-width: 640px) {
	.c-article-list-text {
		grid-column: 1/4;
	}
}
@media screen and (min-width: 641px) {
	.c-article-list-text span::before {
		content: "";
		position: absolute;
		inset: 0 0 0 0;
		transition: transform 0.3s ease-in;
		border-bottom: 1px solid #5aaa46;
		transform: translateX(-100%);
		z-index: -1;
		opacity: 0;
		overflow: hidden;
	}
}
.c-article-list-link {
	display: grid;
	width: 100%;
	align-items: center;
	border-bottom: 1px solid #d9d9d9;
	background-color: #fff;
	grid-template-columns: auto auto 1fr;
}
@media screen and (min-width: 641px) {
	.c-article-list-link {
		gap: 22px;
		padding-block: 20px;
		padding-left: 30px;
	}
}
@media screen and (max-width: 640px) {
	.c-article-list-link {
		gap: 10px 12px;
		padding-block: 15px;
		padding-left: 15px;
	}
}
.c-article-list-tag {
	padding: 5px;
	background-color: #5aaa46;
	display: grid;
	place-content: center;
	color: #fff;
	font-size: clamp(1.2rem, 1.4vw, 1.4rem);
}
@media screen and (min-width: 641px) {
	.c-article-list-tag {
		min-width: 100px;
		min-height: 30px;
	}
}
@media screen and (max-width: 640px) {
	.c-article-list-tag {
		min-width: 75px;
		min-height: 18px;
		grid-column: 2/3;
	}
}
.top-head-inner {
	background-color: rgba(89, 210, 0, 0.05);
}
@media screen and (min-width: 1001px) {
	.top-head-inner {
		padding-bottom: 95px;
	}
}
@media screen and (max-width: 1000px) {
	.top-head-inner {
		padding-bottom: 50px;
	}
}
.top-head-text {
	text-align: center;
	margin-top: 38px;
	font-size: clamp(1.8rem, 2.2vw, 2.4rem);
}
@media screen and (max-width: 1000px) {
	.top-head-text {
		margin-top: 30px;
		padding-inline: 15px;
	}
}
.top-head-img {
	position: relative;
}
@media screen and (min-width: 641px) {
	.top-head-img::after {
		content: "";
		position: absolute;
		height: 4px;
		background-color: #000;
		bottom: 0;
		left: 0;
		width: 100%;
	}
}
.top-head-figure {
	width: min(1440px, 100%);
	position: relative;
	display: grid;
	margin-inline: auto;
	vertical-align: middle;
	position: relative;
}
@media screen and (max-width: 640px) {
	.top-head-figure {
		justify-content: center;
	}
}
.top-head-figure img {
	height: 100%;
}
@media screen and (min-width: 641px) {
	.top-head-figure img {
		width: 100%;
		object-fit: cover;
	}
}
@media screen and (max-width: 640px) {
	.top-head-figure img {
		height: auto;
	}
}
.c-navigation {
	padding-top: 80px;
	padding-top: clamp(2.5rem, 6.5vw, 5rem);
}
.c-navigation .wp-pagenavi {
	display: grid;
	grid-template-columns: repeat(auto-fit, 40px);
	gap: clamp(0.8rem, 0.8vw, 1rem);
	justify-content: center;
}
@media screen and (max-width: 1000px) {
	.c-navigation .wp-pagenavi {
		grid-template-columns: repeat(auto-fit, 30px);
	}
}
.c-navigation .extend,
.c-navigation .pages,
.c-navigation .last {
	display: none;
}
.c-navigation .page,
.c-navigation .current {
	aspect-ratio: 1/1;
	border: 1px solid #5aaa46;
	display: grid;
	place-content: center;
	color: #5aaa46;
	transition: all 0.3s;
	width: clamp(3rem, 3.5vw, 4rem);
}
.c-navigation .page:hover,
.c-navigation .current:hover {
	color: #fff;
	background-color: #5aaa46;
}
.c-navigation .current {
	color: #fff;
	background-color: #5aaa46;
}
.c-navigation .nextpostslink,
.c-navigation .previouspostslink {
	border-radius: 50%;
	border: 1px solid #5aaa46;
	color: rgba(0, 0, 0, 0);
	position: relative;
	aspect-ratio: 1/1;
	transition: background-color 0.3s;
	width: clamp(3rem, 3.5vw, 4rem);
}
.c-navigation .nextpostslink::before,
.c-navigation .previouspostslink::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 40%;
	border-top: 1px solid #5aaa46;
	border-right: 1px solid #5aaa46;
	rotate: 45deg;
	translate: -50% -50%;
	transition: border-color 0.3s;
}
@media screen and (min-width: 1001px) {
	.c-navigation .nextpostslink::before,
	.c-navigation .previouspostslink::before {
		width: 10px;
		height: 10px;
	}
}
@media screen and (max-width: 1000px) {
	.c-navigation .nextpostslink::before,
	.c-navigation .previouspostslink::before {
		width: 8px;
		height: 8px;
	}
}
.c-navigation .nextpostslink:hover,
.c-navigation .previouspostslink:hover {
	background-color: #5aaa46;
}
.c-navigation .nextpostslink:hover::before,
.c-navigation .previouspostslink:hover::before {
	border-color: #fff;
}
@media screen and (min-width: 1001px) {
	.c-navigation .nextpostslink {
		translate: 20px 0;
	}
}
@media screen and (min-width: 1001px) {
	.c-navigation .previouspostslink {
		translate: -20px 0;
	}
}
.c-navigation .previouspostslink::before {
	scale: -1 -1;
	left: 55%;
}
.c-arcicle-head-group {
	margin-top: 20px;
	display: grid;
	grid-template-columns: 100px auto;
	align-items: center;
	justify-content: flex-start;
	column-gap: 30px;
}
@media screen and (max-width: 640px) {
	.c-arcicle-head-group {
		column-gap: 0px;
	}
}
.c-arcicle-head-group .c-article-list-tag {
	grid-column: 1/2;
	max-width: 75px;
}
.c-arcicle-head-date {
	display: inline-block;
}
@media screen and (min-width: 1001px) {
	.c-arcicle-inner {
		min-height: 200px;
	}
}
@media screen and (max-width: 640px) {
	.c-arcicle-inner {
		padding-top: 30px;
	}
}
.c-arcicle p {
	line-height: 2em;
}
.c-arcicle a {
	text-decoration: underline;
}
.building {
	list-style-type: none;
	margin-bottom: 28px;
	margin-left: 0;
	margin-right: 0;
	width: 100%;
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	max-width: 1440px;
	margin-inline: auto;
}
@media screen and (min-width: 641px) {
	.building {
		padding-top: 80px;
	}
}
@media screen and (max-width: 1000px) {
	.building {
		grid-template-columns: repeat(auto-fit, minmax(187px, 1fr));
	}
}
.building:after {
	clear: both;
	content: ".";
	display: block;
	height: 0;
	line-height: 0;
	font-size: 0;
	visibility: hidden;
}
.building > li {
	box-sizing: border-box;
	padding: 1px;
	position: relative;
}
.building > li > h5 {
	background: rgba(0, 0, 0, 0.5);
	bottom: 0;
	box-sizing: border-box;
	color: #fff;
	font-size: 80%;
	font-weight: normal;
	padding: 10px;
	position: absolute;
	text-align: center;
	width: 100%;
	left: 0;
}
.building > li > img {
	display: block;
	height: auto;
	width: 100%;
}
.sdgs-main-head {
	margin-top: 0 !important;
}
.top_banner {
	padding-block: 30px 25px;
	border-top: 1px solid #ededed;
	position: relative;
}
@media screen and (max-width: 640px) {
	.top_banner {
		padding-block: 15px 10px;
	}
}
.top_banner::before {
	content: "";
	position: absolute;
	bottom: -2px;
	width: 100%;
	height: 1px;
	background-color: #ededed;
}
.paragraph .is-sp-img-width img {
	max-width: 100%;
} /*# sourceMappingURL=style.min.css.map */
