@charset "utf-8";
/*
Theme Name:syokaku
Theme URI:
Author:
*/

@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap";

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

body {
	line-height: 1;
	width: 100%;
	position: relative;
	overflow-x: hidden;
	-webkit-text-size-adjust: 100%;
	margin: 0;
	max-width: 100vw;
	height: auto;
}

main {
	max-width: 100vw;
}

ol,
ul {
	list-style: none;
}

li {
	list-style-type: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

img {
	vertical-align: bottom;
}

textarea,
select,
option {
	font: inherit;
}

.alignright {
	display: block;
	margin: 0 0 10px auto;
}

.alignleft {
	display: block;
	margin: 0 auto 10px 0;
}

.aligncenter {
	display: block;
	margin: 0 auto 10px;
}

a {
	transition: all 0.3s ease-in-out;
}

a:link {
	text-decoration: none;
}

a:hover {
	text-decoration: none;
	opacity: 0.7;
}

a:active {
	text-decoration: none;
}

.cf:before,
.cf:after {
	content: " ";
	display: table;
}

.cf:after {
	clear: both;
}

.cf {
	*zoom: 1;
}

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

html {
	font-size: 62.5%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	scroll-behavior: smooth;
}

body {
	background: #fff;
	color: #595757;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
	font-family: "Noto Sans JP";
}

* {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

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

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

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

@media screen and (max-width: 374px) {
	html {
		font-size: 2.667vw;
	}
}

.footer {
	padding-top: clamp(40px, 6.25vw, 90px);
	padding-bottom: clamp(24px, 3.6805555556vw, 53px);
	background: #595757;
	width: 100%;
	position: relative;
	z-index: 3;
}

.footerInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (10vw), 144px);
	padding-right: clamp(19px, (10vw), 144px);
}

@media (max-width: 767px) {
	.footerInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.footerRow {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

@media (max-width: 1023px) {
	.footerRow {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.footerLogo {
	width: clamp(120px, 10.5555555556vw, 152px);
	min-width: clamp(120px, 10.5555555556vw, 152px);
}

.footerLogoImg {
	width: 100%;
	-o-object-fit: contain;
	object-fit: contain;
}

.footerLinks {
	width: calc(100% - clamp(120px, 10.5555555556vw, 152px));
	padding-left: clamp(0px, 7.4305555556vw, 107px);
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-column-gap: clamp(35px, 3.0555555556vw, 44px);
	-moz-column-gap: clamp(35px, 3.0555555556vw, 44px);
	column-gap: clamp(35px, 3.0555555556vw, 44px);
}

@media (max-width: 1023px) {
	.footerLinks {
		width: 100%;
		padding-left: 0;
		margin-top: 30px;
	}
}

@media (max-width: 767px) {
	.footerLinks {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
		row-gap: 25px;
	}
}

.footerContainer {
	width: 50%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media (max-width: 767px) {
	.footerContainer {
		display: contents;
	}
}

.footerWrap {
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-column-gap: clamp(35px, 3.0555555556vw, 44px);
	-moz-column-gap: clamp(35px, 3.0555555556vw, 44px);
	column-gap: clamp(35px, 3.0555555556vw, 44px);
}

.footerWrap.-space {
	margin-top: clamp(0px, 2.3611111111vw, 34px);
}

@media (max-width: 767px) {
	.footerWrap.-space {
		margin-top: 0;
	}
}

@media (max-width: 767px) {
	.footerWrap.-first {
		-webkit-box-ordinal-group: 2;
		-webkit-order: 1;
		-ms-flex-order: 1;
		order: 1;
	}

	.footerWrap.-second {
		-webkit-box-ordinal-group: 4;
		-webkit-order: 3;
		-ms-flex-order: 3;
		order: 3;
	}

	.footerWrap.-third {
		-webkit-box-ordinal-group: 3;
		-webkit-order: 2;
		-ms-flex-order: 2;
		order: 2;
	}

	.footerWrap.-fourth {
		-webkit-box-ordinal-group: 5;
		-webkit-order: 4;
		-ms-flex-order: 4;
		order: 4;
	}
}

.footerBlock {
	width: 50%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

.footerLink {
	width: 100%;
	cursor: pointer;
	font-size: clamp(1.3rem, (1.1111111111vw), 1.6rem);
	font-weight: 500;
	line-height: 1.6875;
	color: #fff;
	padding-bottom: 4.5px;
	border-bottom: 0.5px solid #fff;
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.footerLink::after {
	content: "";
	display: block;
	width: clamp(5px, 0.4166666667vw, 6px);
	height: clamp(8px, 0.7638888889vw, 11px);
	background-image: url(./img/common/icon_arrow.svg);
	background-repeat: no-repeat;
	background-size: contain;
}

.footerLinkSub {
	margin-top: clamp(6px, 0.5138888889vw, 7.4px);
	font-size: clamp(1.25rem, (0.9722222222vw), 1.4rem);
	line-height: 1.5;
	color: #fff;
	cursor: pointer;
}

.footerLink + .footerLinkSub {
	margin-top: clamp(10px, 0.8333333333vw, 12px);
}

.footerBanner {
	-o-object-fit: cover;
	object-fit: cover;
	margin-top: clamp(9px, 5.2083333333vw, 75px);
	width: 100%;
	aspect-ratio: 423/85;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

@media (max-width: 767px) {
	.footerBanner {
		margin-top: 9px;
	}
}

.footerBannerImg {
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
}

.footerBannerWrap {
	width: 50%;
	background-color: #009b73;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	color: #fff;
}

.footerBannerTtl {
	font-size: clamp(1.6rem, (1.4583333333vw), 2.1rem);
	font-weight: 600;
	line-height: 1;
}

.footerBannerTxt {
	margin-top: clamp(7px, 0.625vw, 9px);
	font-size: 1rem;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	padding-left: 0.5em;
	padding-right: 0.5em;
}

.footerBannerTxt::after {
	content: "";
	display: block;
	width: clamp(8px, 0.6944444444vw, 10px);
	height: clamp(8px, 0.6944444444vw, 10px);
	background-image: url(./img/common/icon_blank.svg);
	background-repeat: no-repeat;
	background-size: contain;
	margin-left: 3px;
}

.footerBannerTxt span {
	display: inline-block;
}

.footerBottom {
	width: 100%;
	margin-top: 1em;
	display: flex;
	justify-content: space-between;
}

@media (max-width: 980px) {
	.footerBottom {
		align-items: flex-end;
	}
}

.footerInsta {
	width: 40px;
	height: 40px;
	display: block;
}

.footerInsta img {
	width: 100%;
}

.footerPolicy {
	margin-top: clamp(26px, 2.7777777778vw, 40px);
	color: #fff;
	font-size: clamp(1.1rem, (0.9722222222vw), 1.4rem);
	font-weight: 500;
	line-height: 1.75;
}

.footerCopyrights {
	width: 100%;
	color: #fff;
	margin-top: 10px;
	font-size: clamp(1rem, (0.8333333333vw), 1.2rem);
	font-weight: 500;
	line-height: 1;
}

.Img {
	aspect-ratio: 1/1;
}

.anchor {
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: -150px;
	left: 0;
	width: 1px;
	height: 1px;
	display: block;
}

.burger {
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 20;
	aspect-ratio: 1/1;
	height: 70px;
	background: #fff;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
	display: none;
}

@media (max-width: 980px) {
	.burger {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
	}
}

.burger.-active {
	background-color: #000;
}

.burgerWrap {
	width: 100%;
	height: 100%;
	position: relative;
}

.burgerBar {
	height: 1.6px;
	width: 33px;
	background-color: #000;
	position: absolute;
	left: 50%;
	-webkit-transition: all 0.2s cubic-bezier(0.24, 0.63, 0.57, 1.5);
	transition: all 0.2s cubic-bezier(0.24, 0.63, 0.57, 1.5);
}

.burgerBar:nth-of-type(1) {
	top: 25px;
	-webkit-transform: translate(-50%, 0%) rotate(0deg);
	transform: translate(-50%, 0%) rotate(0deg);
}

.burgerBar:nth-of-type(1).-active {
	top: 50%;
	-webkit-transform: translate(-50%, -50%) rotate(45deg);
	transform: translate(-50%, -50%) rotate(45deg);
	background-color: #fff;
}

.burgerBar:nth-of-type(2) {
	top: 50%;
	-webkit-transform: translate(-50%, -50%) rotate(0deg);
	transform: translate(-50%, -50%) rotate(0deg);
}

.burgerBar:nth-of-type(2).-active {
	opacity: 1;
	top: 50%;
	-webkit-transform: translate(-50%, -50%) rotate(-45deg);
	transform: translate(-50%, -50%) rotate(-45deg);
	background-color: #fff;
}

.burgerBar:nth-of-type(3) {
	bottom: 25px;
	-webkit-transform: translate(-50%, 0%) rotate(0deg);
	transform: translate(-50%, 0%) rotate(0deg);
}

.burgerBar:nth-of-type(3).-active {
	bottom: 50%;
	-webkit-transform: translate(-50%, -50%) rotate(-45deg);
	transform: translate(-50%, -50%) rotate(-45deg);
	background-color: #fff;
	opacity: 0;
}

.headerBg {
	background-color: #fff;
	height: 70px;
	width: 100vw;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 4;
	display: none;
}

@media (max-width: 980px) {
	.headerBg {
		display: block;
	}
}

.headerInner {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 4;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-webkit-justify-content: flex-end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-column-gap: clamp(23px, 2.5694444444vw, 37px);
	-moz-column-gap: clamp(23px, 2.5694444444vw, 37px);
	column-gap: clamp(23px, 2.5694444444vw, 37px);
	opacity: 0;
	pointer-events: none;
	background-color: #efefef;
}

.headerInner.-show {
	pointer-events: auto;
	opacity: 1;
}

@media (max-width: 980px) {
	.headerInner {
		max-height: 100lvh;
		-webkit-transform: translateX(100%);
		transform: translateX(100%);
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.headerInner.-active {
	-webkit-transform: translateY(0px);
	transform: translateY(0px);
	opacity: 1;
	pointer-events: all;
}

@media (max-width: 980px) {
	.headerInner.-active {
		-webkit-transform: translateX(0);
		transform: translateX(0);
	}
}

.headerInner::after {
	content: "";
	display: block;
	width: 100vw;
	height: 100%;
	position: absolute;
	right: 0;
	top: 0;
	background-color: #fff;
	z-index: -1;
}

@media (max-width: 980px) {
	.headerInner::after {
		display: none;
	}
}

.headerLogo {
	position: fixed;
	left: clamp(20px, 2.3263888889vw, 33.5px);
	top: 20px;
	z-index: 20;
	width: clamp(180px, 22vw, 260px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
	-webkit-transform: translateY(-50px);
	transform: translateY(-50px);
	opacity: 0;
}

.headerLogo.-show {
	opacity: 1;
	-webkit-transform: translateY(0px);
	transform: translateY(0px);
}

@media (max-width: 980px) {
	.headerLogo {
		opacity: 1;
		-webkit-transform: translateY(0px);
		transform: translateY(0px);
		top: 25px;
	}
}

.headerLogoLink {
	width: 100%;
	display: inline-block;
}

.headerLogoImg {
	width: 100%;
	-o-object-fit: contain;
	object-fit: contain;
}

.headerSocialIcon {
	width: 35px;
	position: fixed;
	left: clamp(16px, 3.4722222222vw, 50px);
	bottom: 30px;
	z-index: 20;
	overflow: visible;
	background-color: #fff;
	border-radius: 20px;
}

.headerSocialIcon img {
	width: 100%;
	aspect-ratio: 1/1;
}

.headerNav {
	max-height: 100%;
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media (max-width: 980px) {
	.headerNav {
		overflow-y: scroll;
		padding-top: 120px;
		padding-bottom: 40px;
	}
}

.headerList {
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-column-gap: clamp(23px, 2.5694444444vw, 37px);
	-moz-column-gap: clamp(23px, 2.5694444444vw, 37px);
	column-gap: clamp(23px, 2.5694444444vw, 37px);
}

@media (max-width: 980px) {
	.headerList {
		row-gap: 34px;
		display: -webkit-inline-box;
		display: -webkit-inline-flex;
		display: -ms-inline-flexbox;
		display: inline-flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.headerItem {
	position: relative;
	display: inline-block;
	overflow: visible;
}

@media (max-width: 980px) {
	.headerItem {
		padding-right: 125px;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-webkit-flex-direction: row;
		-ms-flex-direction: row;
		flex-direction: row;
	}

	.headerItem::before {
		content: "";
		display: block;
		width: 21px;
		min-width: 21px;
		height: 1px;
		margin-right: 9px;
		background-color: #595757;
	}
}

@media (max-width: 980px) {
	.headerItem:last-of-type {
		/*		display: none;*/
	}
}

.headerLink {
	letter-spacing: 0.0714285714em;
	white-space: nowrap;
	font-size: clamp(1.35rem, (0.9375vw), 1.35rem);
	font-weight: bold;
	line-height: 1.7481481481;
	color: #595757;
	display: inline-block;
	overflow: visible;
}

@media (max-width: 980px) {
	.headerLink {
		max-width: 100vw;
		font-size: 1.6rem;
		white-space: wrap;
		font-weight: 500;
	}
}

.headerLink span {
	display: inline-block;
}

.headerSocial {
	-o-object-fit: contain;
	object-fit: contain;
	width: 38px;
	aspect-ratio: 1/1;
	overflow: visible;
}

.headerCloseTrigger {
	width: 100vw;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
	display: none;
	z-index: 2;
}

.headerCloseTrigger.-active {
	display: block;
}

.headerAttention {
	position: fixed;
	right: clamp(16px, 9.7222222222vw, 140px);
	top: 35px;
	row-gap: 10px;
	z-index: 5;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: end;
	-webkit-align-items: flex-end;
	-ms-flex-align: end;
	align-items: flex-end;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media (max-width: 980px) {
	.headerAttention {
		left: clamp(16px, 3.4722222222vw, 50px);
		top: 70px;
		right: auto;
	}
}

.headerAttentionLink {
	font-size: clamp(1.12rem, (1.1111111111vw), 1.6rem);
	font-weight: 500;
	line-height: 1;
	white-space: nowrap;
	text-decoration: underline;
}

.headerRecruit {
	font-size: 1.5rem;
	font-weight: 600;
	background-color: #009c74;
	padding: 10px 40px;
	border-radius: 0 0 0 20px;
	position: relative;
}

.headerRecruit:before {
	content: "";
	display: inline-block;
	background: url(./img/common/ornament_rec.svg) no-repeat;
	background-size: contain;
	width: 20px;
	height: 20px;
	position: absolute;
	top: 0;
	left: -20px;
}

.headerRecruit:after {
	content: "";
	display: inline-block;
	background: url(./img/common/ornament_rec.svg) no-repeat;
	background-size: contain;
	width: 20px;
	height: 20px;
	position: absolute;
	bottom: -20px;
	right: 0;
}

.headerRecruit img {
	height: 6.2vh;
}

@media (max-width: 980px) {
	.headerRecruit {
		display: none;
	}
}

.breadcrumb {
	margin-top: clamp(60px, 10.2083333333vw, 147px);
	z-index: 2;
	position: relative;
}

.breadcrumbInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
}

@media (max-width: 767px) {
	.breadcrumbInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.breadcrumbList {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	row-gap: 5px;
	width: 100%;
}

.breadcrumbItem {
	color: #595757;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	font-size: clamp(1.2rem, (0.9027777778vw), 1.3rem);
	font-weight: 300;
	line-height: 1;
}

.breadcrumbItem:not(:last-of-type)::after {
	color: #595757;
	content: "＞";
	display: inline-block;
	padding-left: 0.9em;
	padding-right: 0.9em;
}

.breadcrumbTtl {
	color: #595757;
}

.breadcrumbTtl.-current {
	pointer-events: none;
	max-width: 30vw;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
}

.pagination {
	margin-top: clamp(45px, 5.5555555556vw, 80px);
	margin-left: auto;
	margin-right: auto;
}

.paginationList {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.paginationItem {
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.paginationItem:not(.-prev):not(.-next) {
	margin-left: clamp(5px, 0.4166666667vw, 6px);
	margin-right: clamp(5px, 0.4166666667vw, 6px);
}

.paginationItem.-prev {
	margin-right: clamp(27px, 2.0833333333vw, 30px);
}

.paginationItem.-next {
	margin-left: clamp(27px, 2.0833333333vw, 30px);
}

.paginationLink {
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.paginationLink.-prev {
	rotate: 180deg;
	-webkit-transform-origin: center;
	transform-origin: center;
}

.paginationLink:not(.-prev):not(.-next) {
	font-size: clamp(1.5rem, (1.1111111111vw), 1.6rem);
	line-height: 1;
	letter-spacing: 0.05em;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: clamp(35px, 2.6388888889vw, 38px);
	min-width: clamp(35px, 2.6388888889vw, 38px);
	height: clamp(35px, 2.6388888889vw, 38px);
	border: 1px solid #b4b4b4;
	color: #b4b4b4;
}

.paginationLink:not(.-prev):not(.-next).-current {
	border: 1px solid #009c74;
	background-color: #009c74;
	color: #fff;
	pointer-events: none;
}

.paginationLink:hover {
	opacity: 0.7;
}

.paginationLink img {
	width: clamp(14px, 1.0416666667vw, 15px);
	height: clamp(21px, 1.5625vw, 22.5px);
	-o-object-fit: contain;
	object-fit: contain;
}

/* Page Navigation */
/* -------------------------------------------------- */
#pageNavWrap {
	margin-top: clamp(45px, 5.5555555556vw, 80px);
	text-align: center;
	width: 100%;
}

#pager {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

#pageNavWrap a,
#pageNavWrap span {
	width: 40px;
	height: 40px;
	line-height: 40px;
	display: inline-block;
	color: #fff;
	margin: 0 2px;
	white-space: nowrap;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
}

#pageNavWrap a {
	color: #b4b4b4;
	border: 1px solid #b4b4b4;
}

#pageNavWrap a.prev,
#pageNavWrap a.next {
	width: 60px;
	font-size: 0;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
}

#pageNavWrap span.current,
#pageNavWrap a:hover {
	color: #fff;
	background-color: #009c74;
	transition: all 0.3s ease-in-out 0s;
	opacity: 1;
}

#pageNavWrap a.current{
	color: #fff;
	background-color: #009c74;
	transition: all 0.3s ease-in-out 0s;
	opacity: 1;
	pointer-events: none;
}

#pageNavWrap span.dots {
	width: 1em;
	background-color: #fff;
	color: #000;
}

a.prev::after {
	content: "";
	background: url(img/common/icon_pagination_arrow-prev.svg) no-repeat;
	background-size: contain;
	width: 20px;
	height: 24px;
	display: flex;
}

a.next::after {
	content: "";
	background: url(img/common/icon_pagination_arrow.svg) no-repeat;
	background-size: contain;
	width: 20px;
	height: 24px;
	display: flex;
}

a.prev:hover,
a.next:hover {
	background-color: transparent !important;
}





.head {
	padding-top: clamp(125px, 17.2222222222vw, 248px);
	z-index: 2;
	position: relative;
}

.headInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
}

@media (max-width: 767px) {
	.headInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.headWrap {
	width: 100%;
	position: relative;
}

.headSub {
	font-size: clamp(2.7rem, (3.6805555556vw), 5.3rem);
	font-weight: bold;
	line-height: 1;
	color: #009b73;
}

.headSub.-space {
	padding-bottom: clamp(18px, 2.8472222222vw, 41px);
}

.headTtl {
	margin-top: clamp(7px, 0.9375vw, 13.5px);
	font-size: clamp(1.2rem, (1.3888888889vw), 2rem);
	line-height: 1.75;
	color: #595757;
}

.headImg {
	pointer-events: none;
	aspect-ratio: 572/412;
	width: clamp(240px, 39.7222222222vw, 572px);
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transform: translate(-65%, -31%);
	transform: translate(-65%, -31%);
}

@media (max-width: 767px) {
	.headImg {
		-webkit-transform: translate(-46%, -25%);
		transform: translate(-46%, -25%);
	}
}

.headBg {
	position: relative;
	width: 62.5%;
	height: clamp(140px, 19.3055555556vw, 278px);
	border-bottom-left-radius: clamp(18px, 2.5vw, 36px);
	position: absolute;
	top: clamp(70px, 10.8333333333vw, 156px);
	right: 0;
	overflow: hidden;
}
.headBg img {
    width: auto;
    height: 100%;
    position: absolute;
    top: 0%;
    right: 0%;
    /* transform: translateY(0%) translateX(-50%); */
}
@media (max-width: 1490px) {
	.headBg img {
	    width: auto;
	    height: 100%;
	    position: absolute;
	    top: 0%;
	    right: 50%;
	    transform: translateY(0%) translateX(50%);
	    -webkit- transform: translateY(0%) translateX(50%);
	}
}


#company .headBg {
	object-position: 0% 2%;
}

#works .headBg {
	object-position: 0% 30%;
}

#sustainability .headBg {
	object-position: 0% 70%;
}

@media (max-width: 767px) {
	.headBg {
		width: 40%;
		-o-object-position: 30% 0%;
		object-position: 30% 0%;
	}
}

.notFound {
	padding-top: clamp(143px, 15.4861111111vw, 223px);
	padding-left: clamp(11px, 15.2777777778vw, 220px);
	padding-right: clamp(11px, 15.2777777778vw, 220px);
	padding-bottom: 100px;
	margin: auto;
	width: 100%;
}

@media (max-width: 767px) {
	.notFound {
		padding-left: 11px;
		padding-right: 11px;
	}
}

.notFoundInner {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

.notFoundWrap {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	position: relative;
}

.notFoundImg {
	width: clamp(161px, 32.1527777778vw, 463px);
	position: relative;
	overflow: hidden;
}

.notFoundImg::after {
	display: block;
	padding-top: 171.7062634989%;
	content: "";
}

@media (max-width: 767px) {
	.notFoundImg {
		position: relative;
		overflow: hidden;
	}

	.notFoundImg::after {
		display: block;
		padding-top: 172.6708074534%;
		content: "";
	}
}

@media (max-width: 767px) {
	.notFoundHeading {
		line-height: 1.3153846154;
	}
}

.notFoundHeading span {
	margin-left: 0.3em;
	margin-right: 0.26em;
}

.notFoundDesc {
	position: absolute;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	bottom: clamp(8px, 1.9444444444vw, 28px);
	letter-spacing: 0.03em;
	white-space: nowrap;
}

@media (max-width: 767px) {
	.notFoundDesc {
		line-height: 1.2142857143;
	}
}

.notFoundLink {
	margin-top: 56px;
	border: 1px solid #757575;
	color: #757575;
	height: clamp(45px, 3.3333333333vw, 48px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: clamp(343px, 32.1527777778vw, 463px);
	max-width: 100%;
}

@media (max-width: 767px) {
	.notFoundLink {
		line-height: 1.5;
	}
}

.homeMv {
	width: 100%;
}

.homeMvInner {
	width: 100%;
	display: flex;
	flex-direction: row;
	align-items: stretch;
	position: relative;
}

.homeMvPc {
	width: clamp(210px, 20.1388888889vw, 290px);
	min-height: 600px;
	max-height: 98vh;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

@media (max-width: 980px) {
	.homeMvPc {
		display: none;
	}
}

.homeMvList {
	row-gap: 2vw;
	/*	padding-top: 10vh;*/
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	/*	margin-left: clamp(0px, 6.0vw, 89px);*/
	margin: 0 auto;
}

#bannerList {
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 1vh;
}

.homeMvLinkImg {
	width: 38px;
	aspect-ratio: 1/1;
	-o-object-fit: contain;
	object-fit: contain;
}

.homeMvLink {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	font-size: 1.45rem;
	line-height: 1.7509677419;
	font-weight: 600;
	-webkit-column-gap: 7.2px;
	-moz-column-gap: 7.2px;
	column-gap: 7.2px;
	color: #595757;
}

.homeMvLink::before {
	content: "";
	display: block;
	width: 17px;
	height: 1px;
	background-color: #595757;
}

.homeMvTtl {
	height: 20vh;
/* 	height: 24vh; */
	min-height: 140px;
	margin: 0 auto 40px;
	padding-top: 6vh;
}

.homeMvTtlImg {
	width: auto;
	height: 100%;
	min-height: 130px;
	-o-object-fit: contain;
	object-fit: contain;
}

.homeMvContainer {
	width: calc(100% - clamp(210px, 20.1388888889vw, 290px));
	position: relative;
}

@media (max-width: 980px) {
	.homeMvContainer {
		width: 100%;
		padding-top: 70px;
	}
}

.homeMvSlider {
	/*	min-height: 810px;*/
	width: 100%;
	max-height: 98vh;
	overflow: hidden;
	border-bottom-left-radius: 48px;
}

.homeMvSlider .splide__pagination__page {
	opacity: 1;
	background-color: #fff;
	width: 9.16px;
	height: 9.16px;
	margin: 4px;
}

.homeMvSlider .splide__pagination__page.is-active {
	background-color: #707070;
	-webkit-transform: scale(1);
	transform: scale(1);
}

.homeMvSliderInner {
	height: 100%;
}

.homeMvSliderList {
	height: 100%;
}

.homeMvSliderItem {
	width: 100%;
	height: 100%;
}

.homeMvSliderImg {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.homeMvRecruit {
	width: clamp(130px, 13.3333333333vw, 192px);
	height: clamp(130px, 13.3333333333vw, 192px);
	position: absolute;
	bottom: 0;
	right: clamp(31px, 3.6111111111vw, 52px);
	-webkit-transform: translateY(50%);
	transform: translateY(50%);
	z-index: 2;
	display: block;
}

.homeMvRecruit:hover {
	opacity: 0.9;
}

@media (max-width: 767px) {
	.homeMvRecruit {
		-webkit-transform: translateY(0%);
		transform: translateY(0%);
		bottom: 7%;
	}
}

.homeMvRecruitImg {
	-o-object-fit: contain;
	object-fit: contain;
	width: 100%;
	height: 100%;
}

.homeMvFollow {
	margin-left: clamp(0px, 6.1805555556vw, 89px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	margin-top: 48px;
	background-color: #ededed;
	border-radius: 10px;
	padding-top: 11px;
	padding-right: 14px;
	padding-bottom: 11px;
	padding-left: 14px;
}

.homeMvFollowWrap {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.homeMvFollowTxt {
	font-size: clamp(1.2rem, (0.8333333333vw), 1.2rem);
	font-weight: 500;
	line-height: 1.0833333333;
	color: #009b73;
	white-space: nowrap;
}

.homeMvFollowImg {
	aspect-ratio: 1/1;
	width: clamp(36px, 2.5vw, 36px);
}

.homeMvFollowName {
	margin-top: 9px;
	display: block;
	width: 100%;
	min-width: 100%;
	font-size: clamp(1.15rem, (0.7986111111vw), 1.15rem);
	font-weight: 500;
	line-height: 1.1565217391;
	color: #595757;
}

.homeTopics {
	margin-top: clamp(53px, 6.25vw, 90px);
	width: 100%;
}

.homeTopicsInner {
	width: 100%;
	max-width: 1300px;
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (5vw), 72px);
	padding-right: clamp(19px, (5vw), 72px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media (max-width: 767px) {
	.homeTopicsInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.homeTopicsTtl {
	display: inline-block;
	font-size: clamp(2.5rem, (3.4722222222vw), 5rem);
	font-weight: bold;
	line-height: 1;
}

.homeTopicsList {
	width: 100%;
}

.homeTopicsList.-top {
	margin-top: clamp(29px, 2.7777777778vw, 40px);
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 100%;
	row-gap: 0px;
	-webkit-column-gap: clamp(15px, 2.0833333333vw, 30px);
	-moz-column-gap: clamp(15px, 2.0833333333vw, 30px);
	column-gap: clamp(15px, 2.0833333333vw, 30px);
}

@media (max-width: 767px) {
	.homeTopicsList.-top {
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-webkit-flex-direction: row;
		-ms-flex-direction: row;
		flex-direction: row;
		width: 100%;
		row-gap: 0px;
		-webkit-column-gap: 0px;
		-moz-column-gap: 0px;
		column-gap: 0px;
	}
}

.homeTopicsList.-btm {
	border-bottom: 0.5px solid #b7b8b8;
	margin-top: clamp(7px, 1.0416666667vw, 15px);
}

.homeTopicsItem.-top {
	width: calc((100% - clamp(15px, 2.0833333333vw, 30px) * 3) / 4);
}

@media (min-width: 768px) {
	.homeTopicsItem.-top:nth-child(-n+4) {
	    margin-bottom: 40px;
	}
}

@media (max-width: 767px) {
	.homeTopicsItem.-top {
		width: calc((100% - 0px) / 1);
	}

	.homeTopicsItem.-top:not(:first-of-type) {
		margin-top: 16px;
		padding-top: 16px;
		border-top: 0.5px solid #b7b8b8;
	}
}

.homeTopicsItem.-btm {
	width: 100%;
	border-top: 0.5px solid #b7b8b8;
}

.homeTopicsItem.-btm:first-of-type .homeTopicsTtlFourth::after {
	margin-left: 0.4em;
	content: "New!";
	font-size: clamp(1.8rem, (1.5277777778vw), 2.2rem);
	line-height: 1;
	color: red;
}

.homeTopicsLink {
	position: relative;
	display: block;
	width: 100%;
}
.homeTopicsLink img {
	aspect-ratio: 4 / 3;
	object-fit: cover;
	width: 100%;
	height: 100%;
}

@media (max-width: 767px) {
	.homeTopicsLink.-top {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-webkit-justify-content: space-between;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-webkit-flex-direction: row;
		-ms-flex-direction: row;
		flex-direction: row;
	}
}

.homeTopicsLink.-btm {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	padding-top: 21px;
	padding-bottom: 21px;
}

@media (max-width: 767px) {
	.homeTopicsLink.-btm {
		padding-top: 23px;
		padding-bottom: 19px;
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		row-gap: 8px;
	}
}

.homeTopicsLink.-btm::after {
	position: absolute;
	top: 50%;
	right: 0;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	content: "";
	display: block;
	width: 8.5px;
	height: 15px;
	background-image: url(./img/home/icon_arrow.svg);
	background-repeat: no-repeat;
	background-size: contain;
	z-index: 1;
}

.homeTopicsTtlThird {
	margin-top: clamp(45px, 3.8888888889vw, 56px);
	font-weight: bold;
}
.homeTopicsTtlThird span.topicsTtl01 {
	font-size: clamp(3.5rem, (1.7361111111vw), 3rem);
	vertical-align: middle;
}
.homeTopicsTtlThird span.topicsTtl02 {
	font-size: clamp(4rem, (1.7361111111vw), 3.5rem);
	vertical-align: middle;
}

.homeTopicsWrap {
	width: 100%;
	margin-top: 14.2px;
	display: block;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	row-gap: clamp(8px, 0.7638888889vw, 11px);
}

@media (max-width: 767px) {
	.homeTopicsWrap {
		margin-top: 0;
		padding-left: 15px;
	}
}

.homeTopicsThumbnail {
	width: 100%;
	aspect-ratio: 265.5/200;
	-o-object-fit: cover;
	object-fit: cover;
}

@media (max-width: 767px) {
	.homeTopicsLink.-top img {
		aspect-ratio: 337/234;
		width: 50%;
		min-width: 50%;
	}
}

.homeTopicsTag {
	background-color: #595757;
	color: #fff;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.homeTopicsTag.-top {
	min-width: clamp(85px, 8.3333333333vw, 120px);
	height: clamp(15px, 1.7361111111vw, 25px);
	border-radius: clamp(7px, 0.8680555556vw, 12.5px);
	font-size: clamp(1rem, (0.8333333333vw), 1.2rem);
	line-height: 1;
}

.homeTopicsTag.-btm {
	min-width: clamp(95px, 8.3333333333vw, 120px);
	height: clamp(18px, 1.7361111111vw, 25px);
	border-radius: clamp(9px, 0.8680555556vw, 12.5px);
	font-size: clamp(1rem, (0.8333333333vw), 1.2rem);
	line-height: 1;
	margin-left: clamp(7px, 1.3888888889vw, 20px);
}

.homeTopicsTag span {
	white-space: nowrap;
}

.homeTopicsTime {
	white-space: nowrap;
	color: #595757;
}

.homeTopicsTime.-top {
	margin-left: clamp(9px, 0.6944444444vw, 10px);
	font-size: clamp(1rem, (1.0416666667vw), 1.5rem);
	line-height: 1.7333333333;
}

.homeTopicsTime.-btm {
	font-size: clamp(1.1rem, (1.0416666667vw), 1.5rem);
	line-height: 1.7333333333;
}

.homeTopicsTtlSecond {
	width: 100%;
	min-width: 100%;
	font-size: clamp(1.3rem, (1.3888888889vw), 2rem);
	font-weight: 500;
	line-height: 1.45;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #595757;
}

.homeTopicsTtlFourth {
	margin-left: 16px;
	padding-right: 1em;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	color: #595757;
}

@media (max-width: 767px) {
	.homeTopicsTtlFourth {
		margin-left: 0;
		width: 100%;
		min-width: 100%;
	}
}

.homeTopicsTtlFourth span {
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	font-size: 1.7rem;
	line-height: 1.9588235294;
	letter-spacing: 0.05em;
}

.homeTopicsAll {
	margin-top: clamp(11px, 0.9722222222vw, 14px);
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-webkit-justify-content: flex-end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.homeTopicsAllLink {
	font-size: 2rem;
	font-weight: 500;
	color: #009b73;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.homeTopicsAllLink::before {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	background-image: url(./img/home/icon_dots.svg);
	background-repeat: no-repeat;
	background-size: contain;
	margin-right: 10px;
}

.homeCompany {
	margin-top: clamp(115px, 8.3333333333vw, 120px);
}

.homeRecruit {
	margin-bottom: 160px;
}

.homeCompanyInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (5vw), 72px);
	padding-right: clamp(19px, (5vw), 72px);
}

@media (max-width: 767px) {
	.homeCompanyInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

@media (max-width: 767px) {
	.homeCompanyInner {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-webkit-justify-content: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.homeCompanySubTtl {
	font-size: clamp(4rem, (5.5555555556vw), 8rem);
	font-weight: bold;
	line-height: 1;
	text-align: center;
}

.homeCompanyTtl {
	margin-top: clamp(5px, 1.0vw, 10px);
	font-size: clamp(1rem, (1.3888888889vw), 2rem);
	font-weight: 400;
	line-height: 1.75;
	text-align: center;
}

.homeCompanyImg {
	margin-top: clamp(20px, 2.2222222222vw, 32px);
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: center 5%;
	object-position: center 5%;
}

.homeCompanyTtlSecond {
	font-size: clamp(2rem, (2.2222222222vw), 3.2rem);
	font-weight: bold;
	line-height: 1.5;
	letter-spacing: 0.05em;
	white-space: nowrap;
	margin: 0 auto 20px;
}

@media (max-width: 767px) {
	.homeCompanyTtlSecond {
		width: 100%;
	}
}

.homeCompanyTtlSecond span {
	display: inline-block;
}

@media (max-width: 767px) {
	.homeCompanyTtlSecond br {
		display: none;
	}
}

.homeCompanyTxt {
	font-size: clamp(1.6rem,1.7vw,1.7rem);
	line-height: 1.8235294118;
	font-weight: 500;
	letter-spacing: 0.025em;
	padding-left: clamp(0px, 3.8888888889vw, 56px);
	padding-right: clamp(0px, 3.6805555556vw, 53px);
	margin: 0 auto 40px;
}

.homeCompanyTxt br.-sp {
	display: none;
}
@media (max-width: 767px) {
}
@media (max-width: 767px) {
	.homeCompanyTxt br.-sp {
		display: inline;
	}
	.homeCompanyTxt {
		margin-top: 10px;
		padding-left: 0;
		padding-right: 0;
		line-height: 1.5588235294;
	}
}

.homeCompanyLink, .homeRecruitLink {
	margin-top: 14px;
	white-space: nowrap;
	color: #fff;
	background-color: #009b73;
	border-radius: 35px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: clamp(250px, 18.75vw, 270px);
	min-width: clamp(250px, 18.75vw, 270px);
	height: clamp(65px, 4.8611111111vw, 70px);
	position: relative;
	font-size: clamp(2rem, (1.4583333333vw), 2.1rem);
	font-weight: 500;
	line-height: 1;
	margin: 0 auto;
}

@media (max-width: 767px) {
	.homeCompanyLink, .homeRecruitLink {
		margin-top: 17px;
	}
}

.homeCompanyLink::after {
	content: "";
	display: block;
	width: 8px;
	height: 15px;
	background-image: url(./img/home/icon_arrow2.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.homeRecruitLink::after {
	content: "";
	display: block;
	width: 15px;
    height: 16px;
	background-image: url(./img/home/icon_arrow3.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.homeCompanyRow {
	margin-top: clamp(32px, 2.3611111111vw, 34px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	text-align: center;
}

@media (max-width: 1023px) {
	.homeCompanyRow {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-webkit-justify-content: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.homeWorks {
	margin-top: clamp(162px, 11.6666666667vw, 168px);
	padding-bottom: clamp(145px, 11.6666666667vw, 168px);
}

.homeWorksInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (10vw), 144px);
	padding-right: clamp(19px, (10vw), 144px);
}

@media (max-width: 767px) {
	.homeWorksInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

@media (max-width: 767px) {
	.homeWorksInner {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-webkit-justify-content: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.homeWorksSubTtl {
	font-size: clamp(4rem, (5.5555555556vw), 8rem);
	font-weight: bold;
	line-height: 1;
	text-align: center;
}

.homeWorksTtl {
	margin-top: clamp(3px, 0.4166666667vw, 6px);
	font-size: clamp(1rem, (1.3888888889vw), 2rem);
	font-weight: 400;
	line-height: 1.75;
	text-align: center;
}

.homeWorksList {
	margin-top: clamp(25px, 2.9166666667vw, 42px);
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	gap: 0 4%;

}

@media (max-width: 767px) {
	.homeWorksList {
		width: 100vw;
		flex-direction: column;
		row-gap: 70px;
	}
}

.homeWorksItem {
	width: 100%;
	display: flex;
	flex-direction: column-reverse;

}

@media (max-width: 767px) {
	.homeWorksItem {
		width: 100%;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: reverse;
		-webkit-flex-direction: column-reverse;
		-ms-flex-direction: column-reverse;
		flex-direction: column-reverse;
	}
}

.homeWorksWrap {
	padding: 30px 40px 60px;
	background: #e9eaea;
	position: relative;
}

.homeWorksWrapInner {
	display: flex;
	align-items: center;
	justify-content: space-between;
}


@media (max-width: 767px) {
	.homeWorksWrap {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-webkit-justify-content: space-between;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-webkit-flex-direction: row;
		-ms-flex-direction: row;
		flex-direction: row;
		position: relative;
		padding-bottom: 53px;
		width: 100%;
	}
}

.homeWorksTtlSecond {
	font-size: clamp(3rem, (2.8472222222vw), 4.1rem);
	font-weight: bold;
	line-height: 1;
	padding-right: 0.5em;
	border-right: 2px dotted #b7b8b8;
}

@media (max-width: 767px) {
	.homeWorksTtlSecond {
		white-space: nowrap;
		margin-right: 29px;
	}
}

.homeWorksTxt {
	font-size: 1.5rem;
	line-height: 1.6;
	letter-spacing: 0.025em;
	width: 72%;
}

@media (max-width: 767px) {
	.homeWorksTxt {
		margin-top: 0;
		width: auto;
		min-width: auto;
	}
}

.homeWorksImage {
	position: relative;
	overflow: hidden;
	width: 100%;
}

.homeWorksImg {
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: center;
	object-position: center;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	z-index: 0;
	width: 100%;
	height: 100%;
}

@media (max-width: 767px) {
	.homeWorksImg {
		aspect-ratio: 750/470;
		position: static;
		top: auto;
		left: auto;
		-webkit-transform: translate(0);
		transform: translate(0);
	}
}

@media (max-width: 767px) {
	.homeWorksBtn {
		position: absolute;
		bottom: 0;
		left: 50%;
		-webkit-transform: translate(-50%, 50%);
		transform: translate(-50%, 50%);
	}
}

.homeWorksLink {
	white-space: nowrap;
	color: #fff;
	background-color: #009b73;
	border-radius: 35px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 200px;
	min-width: 200px;
	height: clamp(65px, 4.8611111111vw, 70px);
	font-size: clamp(2rem, (1.4583333333vw), 2.1rem);
	font-weight: 500;
	line-height: 1;
	cursor: pointer;
	position: absolute;
	bottom: -35px;
	left: 50%;
	transform: translateX(-50%);
}

@media (max-width: 767px) {
	.homeWorksLink {
		margin-top: 0px;
		width: clamp(250px, 18.75vw, 270px);
		min-width: clamp(250px, 18.75vw, 270px);
	}
}

.homeWorksLink::after {
	content: "";
	display: block;
	width: 8px;
	height: 15px;
	background-image: url(./img/home/icon_arrow2.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.policyDetails {
	padding-bottom: clamp(50px, 6.6666666667vw, 96px);
	margin-top: clamp(32px, 4.1666666667vw, 60px);
	width: 100%;
}

.policyDetailsInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
}

@media (max-width: 767px) {
	.policyDetailsInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.policyDetailsTtl {
	font-size: clamp(2rem, (2.2222222222vw), 3.2rem);
	line-height: 1.21875;
	color: #000;
}

.policyDetailsTtl span {
	display: inline-block;
}

.policyDetailsTxt {
	margin-top: clamp(10px, 1.5277777778vw, 22px);
	font-size: clamp(1.5rem, (1.4583333333vw), 2.1rem);
	line-height: 1.9523809524;
}

@media (max-width: 767px) {
	.policyDetailsTxt {
		line-height: 1.8;
	}
}

.policyDetailsTtlSecond {
	margin-top: clamp(55px, 5.5555555556vw, 80px);
	font-size: clamp(1.7rem, (1.7361111111vw), 2.5rem);
	font-weight: 500;
	line-height: 1.6;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

@media (max-width: 767px) {
	.policyDetailsTtlSecond {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.policyDetailsTtlSecond span {
	padding-left: clamp(12px, 1.1111111111vw, 16px);
	padding-right: clamp(12px, 1.1111111111vw, 16px);
	padding-top: clamp(5px, 0.4166666667vw, 6px);
	padding-bottom: clamp(5px, 0.4166666667vw, 6px);
}

.policyDetailsTtlSecond span.-order {
	color: #fff;
	background-color: #898989;
	white-space: nowrap;
}

.policyDetailsTtlSecond span.-ttl {
	color: #000;
	background-color: #efefef;
	width: 100%;
}

.policyDetailsTtl + .policyDetailsTxt {
	margin-top: clamp(12px, 2.2222222222vw, 32px);
}

.customersDownload {
	margin-top: clamp(34px, 2.6388888889vw, 38px);
	padding-bottom: clamp(20px, 4vw, 60px);
}

.customersDownloadInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
}

@media (max-width: 767px) {
	.customersDownloadInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.customersDownloadTxt {
	font-size: clamp(1.5rem, (1.25vw), 1.8rem);
	line-height: 1.7777777778;
	letter-spacing: 0.05em;
	margin-bottom: clamp(30px, 4.0277777778vw, 58px);
}

.customersContactTxt {
	margin-bottom: clamp(20px, 2.5vw, 40px);
}
.customersContactTxt b {
	font-weight: bold;
}

.customersDownloadFile {
	background-color: #595757;
	padding-left: clamp(25px, 1.875vw, 27px);
	padding-top: clamp(11px, 0.8333333333vw, 12px);
	padding-bottom: clamp(15px, 1.0833333333vw, 15.6px);
	padding-right: clamp(16px, 1.25vw, 18px);
	color: #fff;
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	letter-spacing: 0.05em;
	font-size: clamp(1.7rem, (1.25vw), 1.8rem);
	line-height: 1;
}

@media (max-width: 767px) {
	.customersDownloadFile {
		letter-spacing: 0;
	}
}

.customersDownloadFile::before {
	content: "";
	display: block;
	width: clamp(29px, 2.1527777778vw, 31px);
	height: clamp(26px, 1.875vw, 27px);
	background-image: url(./img/customers/icon_file.svg);
	background-repeat: no-repeat;
	background-size: contain;
	margin-right: clamp(8px, 1.0416666667vw, 15px);
}

.customersDownloadFile:hover {
	opacity: 0.7;
}

.customerDownloadVersion {
	margin-top: 9px;
	font-size: 1.7rem;
	line-height: 1.4705882353;
	letter-spacing: 0.05em;
}

@media (max-width: 767px) {
	.customerDownloadVersion {
		letter-spacing: 0;
	}
}

.customerDownloadLink {
	margin-top: clamp(32px, 4.5138888889vw, 65px);
	white-space: nowrap;
	color: #fff;
	background-color: #009b73;
	border-radius: 35px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: clamp(162px, 18.75vw, 270px);
	min-width: clamp(162px, 18.75vw, 270px);
	height: clamp(50px, 4.8611111111vw, 70px);
	position: relative;
	font-size: clamp(1.3rem, (1.4583333333vw), 2.1rem);
	font-weight: 500;
	line-height: 1;
}

@media (max-width: 767px) {
	.customerDownloadLink {
		margin-top: 32px;
	}
}

.customerDownloadLink::after {
	content: "";
	display: block;
	width: clamp(5px, 0.5555555556vw, 8px);
	height: clamp(9px, 1.0416666667vw, 15px);
	background-image: url(./img/home/icon_arrow2.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.messageDetails {
	margin-top: clamp(50px, 5.1388888889vw, 74px);
	z-index: 2;
	position: relative;
}

@media (max-width: 767px) {
	.messageDetails {
		padding-bottom: 310px;
	}
}

.messageDetailsInner {
	padding-top: clamp(12px, 1.9444444444vw, 28px);
	padding-bottom: clamp(12px, 1.9444444444vw, 28px);
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (44.0277777778vw), 634px);
	max-width: 1600px;
	margin-left: unset;
}

@media (max-width: 767px) {
	.messageDetailsInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.messageDetailsTtl {
	margin-top: clamp(44px, 3.4722222222vw, 50px);
	font-size: clamp(2.7rem, (3.6111111111vw), 5.2rem);
	font-weight: 600;
	line-height: 1;
	color: #009b73;
}

.messageDetailsTtl2 {
	margin-top: clamp(33px, 5.2083333333vw, 75px);
	font-size: clamp(1.85rem, (2.5vw), 3.6rem);
	font-weight: 500;
	line-height: 1.3333333333;
	letter-spacing: 0.05em;
}

.messageDetailsTtl2 span {
	display: inline-block;
}

.messageDetailsTxt {
	margin-top: 35px;
	font-size: clamp(1.36rem, (1.1111111111vw), 1.6rem);
	line-height: 1.875;
}

@media (max-width: 767px) {
	.messageDetailsTxt {
		line-height: 1.6911764706;
	}
}

.messageDetailsRepresentative {
	margin-top: clamp(30px, 3.4722222222vw, 50px);
	font-size: clamp(1rem, (1.1805555556vw), 1.7rem);
	padding-bottom: clamp(30px, 3.4722222222vw, 60px);
	line-height: 1.7647058824;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.messageDetailsName {
	width: clamp(130px, 17.8472222222vw, 257px);
	height: auto;
	-o-object-fit: contain;
	object-fit: contain;
	margin-left: clamp(11px, 1.5277777778vw, 22px);
}

.message {
	position: relative;
	background-color: #F7F8F8;
}

.messageBg {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}

@media (min-width: 2000px) {
	.messageBg {
		top: 0%;
	}
}

@media (max-width: 767px) {
	.messageBg {
		height: 590px;
		top: unset;
		bottom: 0;
	}
}

.messageBgWrap {
	width: 100%;
	height: 100%;
	position: relative;
}

.messageBgWrap::before {
	position: absolute;
	top: -5%;
	left: 0;
	content: "";
	display: block;
	width: 100%;
	height: 25%;
	/*background: #f6f5f5;
	background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(rgb(246, 245, 245)),
    color-stop(64%, rgb(239, 239, 239)),
    to(rgba(239, 239, 239, 0))
  );
  background: linear-gradient(180deg, rgb(246, 245, 245) 0%, rgb(239, 239, 239) 64%, rgba(239, 239, 239, 0) 100%);*/
	z-index: 1;
}

@media (min-width: 2000px) {
	.messageBgWrap::before {
		display: none;
	}
}

@media (max-width: 767px) {
	.messageBgWrap::before {
		display: none;
	}
}

.messageBgImg {
	width: 100%;
	height: 100%;
	-o-object-fit: none;
	object-fit: none;
	-o-object-position: 60% 50%;
	object-position: 60% 50%;
	position: relative;
	z-index: 0;
}

@media (max-width: 767px) {
	.messageBgImg {
		position: absolute;
		bottom: 0;
/*		right: -9%;*/
/*		width: 650px;*/
		-o-object-position: 76% 50%;
		object-position: 76% 50%;
	}
}

@media (max-width: 374px) {
	.messageBgImg {
		width: 100%;
/*		right: -28%;*/
	}
}

.newsArchives {
	margin-top: clamp(37px, 2.8472222222vw, 41px);
	padding-bottom: clamp(75px, 9.3055555556vw, 134px);
}

.newsArchivesInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

@media (max-width: 767px) {
	.newsArchivesInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

@media (max-width: 767px) {
	.newsArchivesInner {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.newsArchivesHead {
	width: 158px;
	/* width: clamp(157px, 20.4861111111vw, 295px);
	min-width: clamp(157px, 20.4861111111vw, 295px); */
}

@media (max-width: 767px) {
	.newsArchivesHead {
		width: 100%;
		min-width: 100%;
	}
}

.newsArchivesContainer {
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media (max-width: 767px) {
	.newsArchivesContainer {
		width: 100%;
	}
}

.newsArchivesList {
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	row-gap: clamp(9px, 1.9444444444vw, 28px);
}

.newsArchivesList + .newsArchivesList {
	margin-top: clamp(9px, 1.9444444444vw, 28px);
}

@media (max-width: 767px) {
	.newsArchivesList {
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-webkit-flex-direction: row;
		-ms-flex-direction: row;
		flex-direction: row;
		width: 100%;
		row-gap: 9px;
		-webkit-column-gap: 8px;
		-moz-column-gap: 8px;
		column-gap: 8px;
	}
}

@media (max-width: 767px) {
	.newsArchivesItem {
		width: calc((100% - 16px) / 3);
	}
}

.newsArchivesLink {
	width: 100%;
	white-space: nowrap;
	border-radius: clamp(16px, 1.6666666667vw, 24px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	height: clamp(32px, 3.2638888889vw, 47px);
	position: relative;
	font-size: clamp(1rem, (1.1805555556vw), 1.7rem);
	font-weight: 500;
	line-height: 1;
	padding-left: 11px;
	padding-right: 11px;
	color: #595757;
	background-color: #dcdddd;
}

.newsArchivesLink.is-active {
	color: #fff;
	background-color: #009b73;
}

.newsArchivesLink:hover {
	color: #fff;
	background-color: #009b73;
	opacity: 1.0;
}

.newsArchivesMain {
	width: calc(100% - clamp(157px, 20.4861111111vw, 295px));
	min-width: calc(100% - clamp(157px, 20.4861111111vw, 295px));
}

@media (max-width: 767px) {
	.newsArchivesMain {
		width: 100%;
		min-width: 100%;
		margin-top: 40px;
	}
}

.newsArchivesMainList {
	display: flex;
	flex-wrap: wrap;
	gap: 50px calc(7% / 3);
}

.newsArchivesMainItem {
	width: calc((93% / 3));
}

.newsArchivesMainItem img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    width: 100%;
    height: 100%;
    margin-bottom: 15px;
}
.newsArchivesMainLink {
	color: #595757;
	display: block;
}

/* .newsArchivesMainLink::after {
	position: absolute;
	top: 50%;
	right: 0;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	content: "";
	display: block;
	width: 8.5px;
	height: 15px;
	background-image: url(./img/home/icon_arrow.svg);
	background-repeat: no-repeat;
	background-size: contain;
	z-index: 1;
} */

.newsArchivesMainLink:hover {
	opacity: 0.7;
}

.newsArchivesMainHead {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.newsArchivesTime {
	white-space: nowrap;
	color: #595757;
	font-size: clamp(1.1rem, (1.0416666667vw), 1.5rem);
	line-height: 1.7333333333;
}

.newsArchivesTag {
	border-radius: clamp(9px, 1.3888888889vw, 20px);
	margin-right: clamp(7px, 1.3888888889vw, 20px);
	background-color: #595757;
	color: #fff;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	min-width: clamp(95px, 8.3333333333vw, 120px);
	height: clamp(15px, 1.7361111111vw, 25px);
}

.newsArchivesTag span {
	white-space: nowrap;
	font-size: clamp(1rem, (0.8333333333vw), 1.2rem);
	line-height: 1;
}

.newsArchivesTtl {
	margin-top: clamp(8px, 1.1111111111vw, 16px);
	font-size: 1.7rem;
	line-height: 1.7647058824;
	letter-spacing: 0.05em;
	color: #595757;
	/* overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2; */
}

@media (max-width: 767px) {
	.newsArchivesMainItem {
		width: calc((93% / 2));
	}
	.newsArchivesTtl {
		/* overflow: hidden;
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 1; */
	}
}

.newsSingle {
	margin-top: clamp(37px, 2.8472222222vw, 41px);
	padding-bottom: clamp(75px, 9.3055555556vw, 134px);
}

.newsSingleInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

@media (max-width: 767px) {
	.newsSingleInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

@media (max-width: 767px) {
	.newsSingleInner {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.newsSingleMain {
	width: calc(100% - clamp(157px, 20.4861111111vw, 295px));
	min-width: calc(100% - clamp(157px, 20.4861111111vw, 295px));
}

@media (max-width: 767px) {
	.newsSingleMain {
		width: 100%;
		min-width: 100%;
		margin-top: 40px;
	}
}

.newsSingleTime {
	white-space: nowrap;
	color: #595757;
	font-size: clamp(1.1rem, (1.0416666667vw), 1.5rem);
	line-height: 1.7333333333;
}

.newsSingleTag {
	border-radius: clamp(9px, 1.3888888889vw, 20px);
	margin-left: clamp(7px, 1.3888888889vw, 20px);
	background-color: #595757;
	color: #fff;
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	min-width: clamp(95px, 8.3333333333vw, 120px);
	height: clamp(15px, 1.7361111111vw, 25px);
	padding-left: 0.5em;
	padding-right: 0.5em;
}

.newsSingleTag span {
	white-space: nowrap;
	font-size: clamp(1rem, (0.8333333333vw), 1.2rem);
	line-height: 1;
}

.newsSingleTtl {
	margin-top: clamp(18px, 2.0833333333vw, 30px);
	font-size: clamp(2rem, (1.8055555556vw), 2.6rem);
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

@media (max-width: 767px) {
	.newsSingleTtl {
		letter-spacing: 0;
	}
}

.newsSingleTxt {
	margin-top: clamp(24px, 3.1944444444vw, 46px);
	padding-top: clamp(24px, 4.1666666667vw, 60px);
	font-size: clamp(1.5rem, (1.25vw), 1.8rem);
	border-top: 1px solid #b5b5b6;
}

@media (max-width: 767px) {
	.newsSingleTxt {
		padding: 0;
		border: none;
	}
}

.newsSingleTxt p {
	margin-bottom: 1em;
}

.newsSingleTxt a {
	text-decoration: underline;
	cursor: pointer;
	color: #009b73;
}

.newsSingleTxt img {
	width: auto;
	height: auto;
}

.newsSingleAll {
	margin-top: clamp(41px, 4.6527777778vw, 67px);
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-webkit-justify-content: flex-end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.newsSingleAllLink {
	font-size: 2rem;
	font-weight: 500;
	color: #009b73;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.newsSingleAllLink::before {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	background-image: url(./img/home/icon_dots.svg);
	background-repeat: no-repeat;
	background-size: contain;
	margin-right: 10px;
}

.worksArchive {
	margin-top: clamp(45px, 7.1527777778vw, 103px);
	padding-bottom: clamp(75px, 9.375vw, 135px);
}

.worksArchiveInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
}

@media (max-width: 767px) {
	.worksArchiveInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}



.worksArchiveTabs {
	display: flex;
	flex-wrap: wrap;
}

.worksArchiveTabs {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.worksArchiveTab {
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: calc(100% / 3);
	height: clamp(50px, 3.9583333333vw, 57px);
	border: 1px solid rgba(0, 0, 0, 0);
	font-size: clamp(1.3rem, (1.3888888889vw), 2rem);
	font-weight: 500;
	line-height: 1.325;
	background-color: #595757;
	color: #fff;
	pointer-events: none;
}

.worksArchiveTab.-left.-unselected {
	color: #595757;
	border-bottom: 1px solid #595757;
	background-color: #fff;
	pointer-events: auto;
	position: relative;
}

.worksArchiveTab.-left.-unselected::before {
	content: "";
	display: block;
	width: 1px;
	height: calc(100% - clamp(7px, 0.9722222222vw, 14px));
	background-color: #595757;
	position: absolute;
	top: 0;
	left: 0;
}

.worksArchiveTab.-left.-unselected::after {
	content: "";
	display: block;
	width: calc(100% - clamp(10px, 1.3888888889vw, 20px));
	height: 1px;
	background-color: #595757;
	position: absolute;
	top: 0;
	left: 0;
}

.worksArchiveTab.-right.-unselected {
	color: #595757;
	border-bottom: 1px solid #595757;
	background-color: #fff;
	pointer-events: auto;
	position: relative;
}

.worksArchiveTab.-right.-unselected::before {
	content: "";
	display: block;
	width: 1px;
	height: calc(100% - clamp(7px, 0.9722222222vw, 14px));
	background-color: #595757;
	position: absolute;
	top: 0;
	right: 0;
}

.worksArchiveTab.-right.-unselected::after {
	content: "";
	display: block;
	width: calc(100% - clamp(10px, 1.3888888889vw, 20px));
	height: 1px;
	background-color: #595757;
	position: absolute;
	top: 0;
	right: 0;
}

.worksArchiveTags {
	margin-top: clamp(20px, 3.3333333333vw, 48px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-column-gap: clamp(7px, 1.0416666667vw, 15px);
	-moz-column-gap: clamp(7px, 1.0416666667vw, 15px);
	column-gap: clamp(7px, 1.0416666667vw, 15px);
	flex-wrap: wrap;
	row-gap:clamp(7px, 1.0416666667vw, 15px);
	overflow: hidden;
  transition: all .2s ease;
}
.worksArchiveTags.-hide {
	height: 0 !important;
}

@media (max-width: 767px) {
	.worksArchiveTags {
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-webkit-flex-direction: row;
		-ms-flex-direction: row;
		flex-direction: row;
		width: 100%;
		row-gap: clamp(9px, 0.9722222222vw, 14px);
		-webkit-column-gap: clamp(7px, 1.0416666667vw, 15px);
		-moz-column-gap: clamp(7px, 1.0416666667vw, 15px);
		column-gap: clamp(7px, 1.0416666667vw, 15px);
	}
}

.worksArchiveTagsWrap {
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 100%;
	row-gap: clamp(9px, 0.9722222222vw, 14px);
	-webkit-column-gap: clamp(7px, 1.0416666667vw, 15px);
	-moz-column-gap: clamp(7px, 1.0416666667vw, 15px);
	column-gap: clamp(7px, 1.0416666667vw, 15px);
}

.worksArchiveTagsWrap.-single {
	width: calc(20% - clamp(7px, 1.0416666667vw, 15px));
}

.worksArchiveTagsWrap.-multiple {
	width: 80%;
}

@media (max-width: 767px) {
	.worksArchiveTagsWrap {
		display: contents;
	}
}

.worksArchiveTag {
	width: calc((100% - clamp(7px, 1.0416666667vw, 15px) * 3) / 4);
	font-size: clamp(1rem, (1.1805555556vw), 1.7rem);
	font-weight: 500;
	line-height: 1;
	text-align: center;
	background-color: #efefef;
	color: #595757;
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	height: clamp(32px, 3.2638888889vw, 47px);
	border-radius: clamp(16px, 1.6666666667vw, 24px);
	padding-left: 0.5em;
	padding-right: 0.5em;
	position: relative;
	cursor: pointer;
	transition: all .2s ease;
}
.worksArchiveTag:hover {
	opacity: 0.7;
}
.worksArchiveTag.-trigger::after {
    position: absolute;
    right: 15px;
    width: 10px;
    height: 7px;
    background-color: #595757;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
    pointer-events: none;
}
.worksArchiveTag.-trigger.-current::after {
    background-color: white;
}
.worksArchiveTag.-trigger.-opened::after {
	rotate: 180deg;
}

.selectbox-3 {
    display: inline-flex;
    align-items: center;
    position: relative;
    width: 100%;
}
@media (max-width: 767px) {
	.selectbox-3  {
		width: calc((100% - clamp(7px, 1.0416666667vw, 15px) * 2) / 3);
	}
}

.selectbox-3::after {
    position: absolute;
    right: 15px;
    width: 10px;
    height: 7px;
    background-color: #595757;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
    pointer-events: none;
}

.selectbox-3.-current::after {
    background-color: #fff;
}


.selectbox-3 select {
    appearance: none;
    width: 100%;
    height: clamp(32px, 3.2638888889vw, 47px);
    padding-left: 0.5em;
    padding-right: 0.5em;
    border: none;
    border-radius: 25px;
    background-color: #efefef;
    color: #595757;
    font-size: clamp(1rem, (1.1805555556vw), 1.7rem);
    cursor: pointer;
    text-align: center;
}
.selectbox-3 select.-current {
  color: #fff;
  background-color: #8c8582;
}

.worksArchiveTag.-single {
	width: 100%;
}

@media (max-width: 767px) {
	.worksArchiveTag.-single {
		width: calc((100% - clamp(7px, 1.0416666667vw, 15px) * 2) / 3);
	}
}

.worksArchiveTag.-current {
	color: #fff;
	background-color: #8c8582;
}

.worksArchiveTag span {
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
}

.worksArchiveList {
	margin-top: clamp(27px, 4.1666666667vw, 60px);
	border-top: 1px solid #b5b5b6;
	padding-top: clamp(35px, 4.1666666667vw, 60px);
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 100%;
	row-gap: clamp(27px, 3.5416666667vw, 51px);
	-webkit-column-gap: clamp(18px, 2.0vw, 30px);
	-moz-column-gap: clamp(18px, 2.0vw, 30px);
	column-gap: clamp(18px, 2.0vw, 30px);
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}

.worksArchiveItem {
	width: calc((100% - clamp(18px, 2vw, 30px) * 3) / 4);
	position: relative;
}

@media (max-width: 767px) {
	.worksArchiveItem {
		width: calc((100% - clamp(18px, 2vw, 30px) * 1) / 2);
	}
}

.worksArchiveLink {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	height: 100%;
}

.worksArchiveWrap {
	width: 100%;
}

.worksArchiveCategory {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	font-size: clamp(1.2rem, (1.0416666667vw), 1.5rem);
	font-weight: 400;
	line-height: 1;
	background-color: #009b73;
	color: #fff;
	padding-left: clamp(10px, 1.1805555556vw, 17px);
	padding-right: clamp(10px, 1.1805555556vw, 17px);
	padding-top: clamp(3px, 0.3472222222vw, 5px);
	padding-bottom: clamp(3px, 0.3472222222vw, 5px);
}

.worksArchiveCategory span:not(:last-of-type)::after {
	content: ' ／ ';
}

.worksArchiveThumbnail {
	aspect-ratio: 265/200;
}

.worksArchiveThumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.worksArchiveTtl {
	margin-top: clamp(6px, 0.7638888889vw, 11px);
	font-size: clamp(1.2rem, (1.3194444444vw), 1.9rem);
	font-weight: 500;
	line-height: 1.4736842105;
	color: #595757;
}

.worksArchiveYear {
	margin-top: clamp(3px, 0.4166666667vw, 6px);
	font-size: clamp(1rem, (1.0416666667vw), 1.5rem);
	line-height: 2;
	color: #595757;
}

.worksSingle {
	margin-top: clamp(50px, 5vw, 72px);
	padding-bottom: clamp(50px, 15.6944444444vw, 226px);
}

.worksSingleInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, 9.7222222222vw, 140px);
	padding-right: 0;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

@media (max-width: 767px) {
	.worksSingleInner {
		padding-left: 19px;
		padding-right: 19px;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.worksSingleContainer {
	width: 30.9230769231%;
	padding-right: clamp(0px, 5.4861111111vw, 79px);
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: stretch;
	-webkit-align-items: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media (max-width: 767px) {
	.worksSingleContainer {
		display: contents;
	}
}

.worksSingleTtl {
	font-size: clamp(2rem, (2.0138888889vw), 2.9rem);
	font-weight: 500;
	line-height: 1.4137931034;
	letter-spacing: 0.05em;
}

@media (max-width: 767px) {
	.worksSingleTtl {
		-webkit-box-ordinal-group: 2;
		-webkit-order: 1;
		-ms-flex-order: 1;
		order: 1;
	}
}

@media (max-width: 767px) {
	.worksSingleWrap {
		width: 100%;
	}
}

.worksSingleContents {
	height: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media (max-width: 767px) {
	.worksSingleContents {
		-webkit-box-ordinal-group: 4;
		-webkit-order: 3;
		-ms-flex-order: 3;
		order: 3;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-webkit-justify-content: space-between;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.worksSingleDefinition {
	margin-top: clamp(36px, 5.625vw, 81px);
}

.worksSingleDefinitionTtl {
	color: #009b73;
	font-size: clamp(1.1rem, (1.1805555556vw), 1.7rem);
	font-weight: 500;
	line-height: 1.7647058824;
}

.worksSingleDefinitionDesc {
	font-size: clamp(1.5rem, (1.5277777778vw), 2.2rem);
	line-height: 1.3636363636;
}

.worksSingleDefinitionDesc + .worksSingleDefinitionTtl {
	margin-top: clamp(23px, 2.5vw, 36px);
}

.worksSingleTxt {
	margin-top: clamp(28px, 3.3333333333vw, 48px);
	font-size: clamp(1.5rem, (1.1805555556vw), 1.7rem);
	line-height: 1.7647058824;
}

.worksSingleSliders {
	width: 69.0769230769%;
}

@media (max-width: 767px) {
	.worksSingleSliders {
		width: 100%;
		margin-top: 17px;
		-webkit-box-ordinal-group: 3;
		-webkit-order: 2;
		-ms-flex-order: 2;
		order: 2;
	}
}

.worksSingleSlider {
	height: clamp(233px, 41.6666666667vw, 600px);
	width: 100%;
	overflow: hidden;
	border-bottom-left-radius: clamp(16px, 2.5vw, 36px);
}

@media (max-width: 767px) {
	.worksSingleSlider {
		height: clamp(233px, 60.4954367666vw, 464px);
		max-height: 100vh;
		width: 100vw;
		margin-left: -19px;
	}
}

.worksSingleSlider .splide__pagination__page {
	opacity: 1;
	background-color: #fff;
	width: 9.16px;
	height: 9.16px;
	margin: 4px;
}

.worksSingleSlider .splide__pagination__page.is-active {
	background-color: #707070;
	-webkit-transform: scale(1);
	transform: scale(1);
}

.worksSingleSliderInner {
	height: 100%;
}

.worksSingleSliderList {
	height: 100%;
}

.worksSingleSliderItem {
	width: 100%;
	height: 100%;
}

.worksSingleSliderImg {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.worksSingleBack {
	margin-top: 32px;
	white-space: nowrap;
	color: #fff;
	background-color: #009b73;
	border-radius: 35px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: clamp(162px, 18.75vw, 270px);
	min-width: clamp(162px, 18.75vw, 270px);
	height: clamp(50px, 4.8611111111vw, 70px);
	position: relative;
	font-size: clamp(1.3rem, (1.4583333333vw), 2.1rem);
	font-weight: 500;
	line-height: 1;
}

@media (max-width: 767px) {
	.worksSingleBack {
		margin-top: 32px;
	}
}

.worksSingleBack::after {
	content: "";
	display: block;
	width: clamp(12px, 1.25vw, 18px);
	height: clamp(8px, 1.0416666667vw, 15px);
	background-image: url(./img/works/icon_back.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.worksSingleThumbnails {
	margin-top: 22px;
}

.worksSingleThumbnailsItem {
	width: clamp(103px, 16.0416666667vw, 231px);
	display: block;
	margin-right: clamp(13px, 2.0833333333vw, 30px);
	aspect-ratio: 231/171;
	opacity: 0.6;
	border: none !important;
}

.worksSingleThumbnailsItem.is-active {
	opacity: 1;
}

.worksSingleThumbnailsImg {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.companyPhilosophy {
	padding-top: clamp(170px, 13.8888888889vw, 200px);
	position: relative;
	z-index: 2;
}

#sustainability .companyPhilosophy {
	padding-top: clamp(40px, 13.8888888889vw, 80px);
}


@media (max-width: 767px) {
	.companyPhilosophy {
		padding-top: 44px;
	}
}

.companyPhilosophyInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
	position: relative;
}

@media (max-width: 767px) {
	.companyPhilosophyInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.companyPhilosophyAnchors {
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 100%;
	row-gap: 9px;
	-webkit-column-gap: clamp(9px, 1.0416666667vw, 15px);
	-moz-column-gap: clamp(9px, 1.0416666667vw, 15px);
	column-gap: clamp(9px, 1.0416666667vw, 15px);
	width: 100%;
}

.companyPhilosophyAnchor {
	width: calc((100% - clamp(9px, 1.0416666667vw, 15px) * 4) / 5);
	position: relative;
}

#sustainability .companyPhilosophyAnchor {
	width: calc((100% - clamp(9px, 1.0416666667vw, 15px) * 4) / 4);
	position: relative;
}

@media (max-width: 767px) {
	.companyPhilosophyAnchor {
		width: calc((100% - clamp(9px, 1.0416666667vw, 15px) * 1) / 2);
	}
}

.companyPhilosophyAnchor::after {
	position: absolute;
	top: 50%;
	right: clamp(9px, 1.0416666667vw, 15px);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	content: "";
	display: block;
	width: clamp(9px, 1.0416666667vw, 15px);
	height: clamp(6px, 0.625vw, 9px);
	background-image: url(./img/company/icon_expand.svg);
	background-repeat: no-repeat;
	background-size: contain;
}

.companyPhilosophyLink {
	font-size: clamp(1.3rem, (1.25vw), 1.8rem);
	font-weight: 500;
	line-height: 1.2222222222;
	width: 100%;
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	height: clamp(50px, 4.8611111111vw, 70px);
	background-color: #009b73;
	color: #fff;
	text-align: center;
}

#sustainability .companyPhilosophyLink {
	border-radius: 40px;
}

#sustainability .companyPhilosophyAnchor::after {
	right: 6%;
}



.companyPhilosophyTtl {
	font-size: clamp(2.7rem, (3.6111111111vw), 5.2rem);
	font-weight: 600;
	line-height: 1;
	color: #009b73;
}

.companyPhilosophyWrap {
	margin-top: clamp(33px, 5.2083333333vw, 75px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

@media (max-width: 767px) {
	.companyPhilosophyWrap {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.companyPhilosophyWrap + .companyPhilosophyWrap {
	margin-top: clamp(37px, 6.1111111111vw, 88px);
}

.companyPhilosophyTtlSecond {
	width: 14.9230769231%;
	min-width: 14.9230769231%;
	color: #009b73;
	font-size: clamp(1.1rem, (1.4583333333vw), 2.1rem);
	font-weight: 500;
	line-height: 1.5714285714;
}

.companyPhilosophyCatch {
	margin-top: -18px;
	font-size: clamp(2rem, (3.125vw), 4.5rem);
	line-height: 1.5111111111;
	font-family:  "Noto Serif JP", serif;
	font-weight: 600;
}

@media (max-width: 767px) {
	.companyPhilosophyCatch {
		line-height: 1.65;
	}
}

@media (max-width: 767px) {
	.companyPhilosophyCatch {
		margin-top: 5px;
	}
}

.companyPhilosophyCatch span {
	display: inline-block;
}

.companyPhilosophyStory {
	margin-top: clamp(50px, 6.0416666667vw, 87px);
	padding-top: clamp(11px, 2.2222222222vw, 32px);
	padding-right: clamp(12px, 1.6666666667vw, 24px);
	padding-left: clamp(12px, 1.6666666667vw, 24px);
	padding-bottom: clamp(11px, 2.2222222222vw, 32px);
	background-color: #eeeeef;
}

.companyPhilosophyTtlThird {
	font-size: clamp(2.3rem, (1.6666666667vw), 2.4rem);
	font-weight: 600;
	line-height: 1.375;
	color: #009b73;
}

.companyPhilosophyTxt {
	margin-top: clamp(13px, 1.5972222222vw, 23px);
	font-size: clamp(1.3rem, (1.0763888889vw), 1.55rem);
	line-height: 1.8709677419;
}

.companyPhilosophyTxt span {
	font-weight: 600;
}

@media (max-width: 767px) {
	.companyPhilosophyTxt {
		line-height: 1.9230769231;
	}
}

.companyPhilosophyList {
	margin-top: -15px;
}

@media (max-width: 767px) {
	.companyPhilosophyList {
		margin-top: 11px;
	}
}

.companyPhilosophyItem {
	font-size: clamp(1.4rem, (2.0833333333vw), 3rem);
	line-height: 2.1333333333;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	font-family:  "Noto Serif JP", serif;
	font-weight: 400;
}

.companyPhilosophyItem::before {
	content: "一．";
	display: inline-block;
}

.companyPhilosophyItem span {
	display: inline-block;
}

.emphasis {
	margin: 0 0.5em;
	font-size: clamp(1.6rem,(2.2vw), 3.2rem);
	font-weight: 700;
}

.companyLogo {
	margin-top: clamp(86px, 16.3888888889vw, 236px);
	position: relative;
}

.companyLogoInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	align-items: stretch;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	flex-wrap: wrap;
}

@media (max-width: 767px) {
	.companyLogoInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

@media (max-width: 767px) {
	.companyLogoInner {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.companyLogoWrap {
	width: 54%;
}

@media (max-width: 767px) {
	.companyLogoWrap {
		width: 100%;
		padding-right: 0;
		padding-bottom: 0;
	}
}

.companyLogoTtl {
	width: 100%;
	display: block;
	margin-bottom: 1em;
	font-size: clamp(2.6rem, (3.6111111111vw), 5.2rem);
	font-weight: bold;
	line-height: 1;
	color: #009b73;
}

.companyLogoTtlSecond {
	font-size: clamp(2.1rem, (1.875vw), 2.7rem);
	font-weight: 600;
	line-height: 1.5185185185;
}

.companyLogoTtlSecond span {
	display: inline-block;
}

.companyLogoTtlSecond br.-sp {
	display: none;
}

@media (max-width: 767px) {
	.companyLogoTtlSecond br.-sp {
		display: inline;
	}
}

.companyLogoTxt {
	margin-top: clamp(13px, 1.3888888889vw, 20px);
	font-size: clamp(1.5rem, (1.1805555556vw), 1.7rem);
	line-height: 1.7647058824;
	padding-bottom: 2em;
	border-bottom: 1px solid #b7b8b8;
	margin-bottom: 2em;
}

#logoColor {}

#logoColorList {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	gap: 0 6%;
}

#logoColorList li {
	width: 47%;
}

.colorName {
	margin-bottom: 0.5em;
	font-size: clamp(1.3rem, (1.6vw), 1.8rem);
	font-weight: 500;
}

#logoColorList li span {
	display: block;
	width: 100%;
	height: 160px;
	background: #009b73;
	border-radius: 20px;
}

#logoColorList li:last-child span {
	background: #00695f;
}


#companyLogoSymbol {
	width: 38%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.companyLogoImg {
	-o-object-fit: contain;
	object-fit: contain;
	width: 100%;
}

#companyLogoSymbol img:first-child {
	height: 30vh;
}

@media (max-width: 767px) {
	.colorName {
		font-size: 1.2rem;
	}

	#logoColorList li span {
		height: 14vh;
	}

	#companyLogoSymbol {
		width: 80%;
		margin-top: 30px;
		align-items: center;
	}

	.companyLogoImg {
		margin-top: 30px;
		width 100%;
		max-width: 350px;
	}
}

.companyAbout {
	margin-top: clamp(53px, 11.6666666667vw, 168px);
}

.companyAbout.-btm {
	padding-bottom: clamp(75px, 9.7222222222vw, 140px);
}

.companyAboutInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
	position: relative;
}

@media (max-width: 767px) {
	.companyAboutInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.companyAboutTtl {
	font-size: clamp(2.6rem, (3.6111111111vw), 5.2rem);
	font-weight: 600;
	line-height: 1;
	color: #009b73;
}

.companyAboutTable {
	margin-top: clamp(10px, 1.3888888889vw, 20px);
	width: 100%;
	border-bottom: 1px solid #b5b5b6;
}

.companyAboutTable tr {
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	padding-top: clamp(9px, 1.3888888889vw, 20px);
	border-top: 1px solid #b5b5b6;
	padding-bottom: clamp(9px, 1.25vw, 18px);
}

.companyAboutTable th,
.companyAboutTable td {
	font-size: clamp(1.1rem, (1.1805555556vw), 1.7rem);
	line-height: 1.4705882353;
}

.companyAboutTable th {
	width: 10%;
	text-align: left;
	display: flex;
	justify-content: space-between;
}

@media (max-width: 767px) {
	.companyAboutTable th {
		width: 14%;
	}
}

@media (max-width: 500px) {
	.companyAboutTable th {
		width: 18%;
	}
}

.companyAboutTable th span.-year {
	display: inline-block;
}

.companyAboutTable th span.-month {
/*	padding-left: clamp(0px, 1.5277777778vw, 22px);*/
}

@media (max-width: 767px) {
	.companyAboutTable th span.-month {
		padding-left: 0;
	}
}

.companyAboutTable th span.-hide {
	opacity: 0;
	pointer-events: none;
}

.companyAboutTable td {
	width: 83%;
	padding-left: 7%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

@media (max-width: 767px) {
	.companyAboutTable td {
		width: 79%;
		/*
		padding-left: 0;
*/
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

@media (max-width: 500px) {
	.companyAboutTable td {
		width: 75%;
	}
}

.companyAboutTable dt {
	font-weight: 400;
}

.companyAboutWrap {
	width: 50%;
	min-width: 50%;
}

.companyAboutWrap:nth-of-type(n + 3) {
	margin-top: clamp(15px, 2.6388888889vw, 38px);
}

@media (max-width: 767px) {
	.companyAboutWrap {
		width: 100%;
	}

	.companyAboutWrap:nth-of-type(n + 2) {
		margin-top: clamp(15px, 2.6388888889vw, 38px);
	}

	.companyAboutWrap.-nospace {
		margin-top: 0;
	}
}

.contactMain {
	margin-top: clamp(34px, 3.75vw, 54px);
}

.contactMainInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
}

@media (max-width: 767px) {
	.contactMainInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.contactMainTxt {
	font-size: clamp(1.5rem, (1.1805555556vw), 1.7rem);
	line-height: 1.7647058824;
	letter-spacing: 0.1em;
}

@media (max-width: 767px) {
	.contactMainTxt {
		letter-spacing: 0;
	}
}

.contactMainForm {
	margin-top: clamp(42px, 3.4722222222vw, 50px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	row-gap: clamp(24px, 1.9444444444vw, 28px);
}

.contactMainRow {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 100%;
	position: relative;
}

@media (max-width: 767px) {
	.contactMainRow {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
		row-gap: 5px;
	}
}

.contactMainTtl {
	margin-top: clamp(0px, 0.9027777778vw, 13px);
	font-size: clamp(1.3rem, (1.25vw), 1.8rem);
	line-height: 1.5;
	width: clamp(135px, 12.1527777778vw, 175px);
}

@media (max-width: 767px) {
	.contactMainTtl {
		width: 100%;
	}
}

.contactMainField {
	width: calc(100% - clamp(135px, 12.1527777778vw, 175px));
}

@media (max-width: 767px) {
	.contactMainField {
		width: 100%;
	}
}

.contactMainInput {
	overflow: visible;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	-webkit-appearance: none;
	border-radius: 0;
	background-color: #efefef;
	font-size: clamp(1.3rem, (1.25vw), 1.8rem);
	line-height: 1.5;
	padding-left: 1em;
	padding-right: 1em;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	height: clamp(37px, 3.8194444444vw, 55px);
	width: 100%;
}

.contactMainMessage {
	overflow: auto;
	-webkit-appearance: none;
	border-radius: 0px;
	-moz-appearance: none;
	appearance: none;
	border: none;
	-webkit-appearance: none;
	border-radius: 0;
	background-color: #efefef;
	font-size: clamp(1.3rem, (1.25vw), 1.8rem);
	line-height: 1.5;
	padding: 1em;
	min-height: clamp(120px, 12.4305555556vw, 179px);
	width: 100%;
}

.contactMainSubmit {
	margin: auto;
	overflow: visible;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	-webkit-appearance: none;
	border-radius: 0;
	margin-top: clamp(32px, 4.5138888889vw, 65px);
	white-space: nowrap;
	color: #fff;
	background-color: #009b73;
	border-radius: 35px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: clamp(162px, 18.75vw, 270px);
	min-width: clamp(162px, 18.75vw, 270px);
	height: clamp(50px, 4.8611111111vw, 70px);
	position: relative;
	cursor: pointer;
	font-size: clamp(1.3rem, (1.4583333333vw), 2.1rem);
	font-weight: 500;
	line-height: 1;
}

@media (max-width: 767px) {
	.contactMainSubmit {
		margin-top: 32px;
	}
}

.contactMainSubmit::after {
	content: "";
	display: block;
	width: clamp(5px, 0.5555555556vw, 8px);
	height: clamp(9px, 1.0416666667vw, 15px);
	background-image: url(./img/home/icon_arrow2.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.contactMainSubmit:hover {
	opacity: 0.7;
}

.contactInfo {
	margin-top: clamp(67px, 9.2361111111vw, 133px);
	padding-bottom: clamp(65px, 11.1111111111vw, 160px);
}

.contactInfoInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, 19.4444444444vw, 280px);
	padding-right: clamp(19px, 19.4444444444vw, 280px);
}

@media (max-width: 1053px) {
	.contactInfoInner {
		padding-left: clamp(19px, 10vw, 144px);
		padding-right: clamp(19px, 10vw, 144px);
	}
}

@media (max-width: 767px) {
	.contactInfoInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.contactInfoContainer {
	border-top: 1px solid #b5b5b6;
	padding-top: clamp(22px, 2.7083333333vw, 39px);
	padding-bottom: clamp(30px, 3.3333333333vw, 48px);
	padding-left: clamp(0px, 3.4722222222vw, 50px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.contactInfoContainer:last-of-type {
	border-bottom: 1px solid #b5b5b6;
}

@media (max-width: 767px) {
	.contactInfoContainer {
		padding-left: 0;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-webkit-justify-content: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
		row-gap: 12px;
	}
}

.contactInfoWrap {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.contactInfoIcon {
	width: clamp(47px, 6.5277777778vw, 94px);
	aspect-ratio: 1/1;
}

.contactInfoTtl {
	margin-left: clamp(9px, 0.8333333333vw, 12px);
	font-size: clamp(1.3rem, (1.3888888889vw), 2rem);
	font-weight: bold;
	line-height: 1.55;
	color: #000;
	white-space: nowrap;
}

.contactInfoDetails {
	padding-left: clamp(0px, 7.9166666667vw, 114px);
	row-gap: clamp(15px, 1.25vw, 18px);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media (max-width: 767px) {
	.contactInfoDetails {
		padding-left: 0;
	}
}

.contactDetailsDefinition {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-column-gap: clamp(18px, 1.3888888889vw, 20px);
	-moz-column-gap: clamp(18px, 1.3888888889vw, 20px);
	column-gap: clamp(18px, 1.3888888889vw, 20px);
}

.contactDetailsTerm {
	font-size: clamp(1.5rem, (1.25vw), 1.8rem);
	font-weight: 600;
	line-height: 1.5;
	color: #000;
}

.contactInfoTel {
	font-size: clamp(2.9rem, (2.5vw), 3.6rem);
	font-weight: bold;
	line-height: 1.5;
	color: #000;
}

.contactDetailsTxt {
	font-size: clamp(1.05rem, (1.0416666667vw), 1.5rem);
	line-height: 1.4;
	color: #000;
}

.contactInfoEmail {
	font-size: clamp(2.5rem, (2.0833333333vw), 3rem);
	font-weight: bold;
	line-height: 1.5;
	color: #000;
}

@media (max-width: 767px) {
	.contactInfoEmail {
		margin-top: 12px;
	}
}

.sustainabilityMain {
	margin-top: clamp(40px, 6.9444444444vw, 100px);
}

.sustainabilityMainInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(20px, (9.7222222222vw), 140px);
	padding-right: clamp(20px, (9.7222222222vw), 140px);
}

@media (max-width: 767px) {
	.sustainabilityMainInner {
		padding-left: 20px;
		padding-right: 20px;
	}
}

.sustainabilityMainHead {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

@media (max-width: 767px) {
	.sustainabilityMainHead {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
		row-gap: 28px;
	}
}

.sustainabilityMainWrap {
	width: 65%;
}

.sustainabilityMainHead img {
	width: 30%;
}

@media (max-width: 767px) {
	.sustainabilityMainWrap {
		width: 100%;
	}

	.sustainabilityMainHead img {
		width: 100%;
	}
}

.sustainabilityMainTtl {
	font-size: clamp(1.6rem, (2.05vw), 2.98rem);
	font-weight: 500;
	line-height: 1.5;
}

.sustainabilityLink {
	white-space: nowrap;
	color: #fff;
	background-color: #009b73;
	border-radius: 35px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 200px;
	min-width: 200px;
	height: clamp(65px, 4.8611111111vw, 70px);
	font-size: clamp(2rem, (1.4583333333vw), 2.1rem);
	font-weight: 500;
	line-height: 1;
	cursor: pointer;
	margin-top: 40px;
	position: relative;
}

@media (max-width: 767px) {
	.sustainabilityLink {
		width: clamp(250px, 18.75vw, 270px);
		min-width: clamp(250px, 18.75vw, 270px);
		margin: 40px auto 0;
	}
}

.sustainabilityLink::after {
	content: "";
	display: block;
	width: 8px;
	height: 15px;
	background-image: url(./img/home/icon_arrow2.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}


/* .sustainabilityMainTxt {
	margin-top: clamp(13px, 1.3194444444vw, 19px);
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.7647058824;
} */

.sustainabilityMainTxt {
	margin-top: clamp(13px, 1.3194444444vw, 19px);
	font-size: clamp(1.5rem, (1.1805555556vw), 1.7rem);
	line-height: 1.7647058824;
}

.sustainabilityMainTtlSecond {
	margin-top: clamp(60px, 7.2916666667vw, 105px);
	font-size: clamp(2.3rem, (2.4305555556vw), 3.5rem);
	font-weight: 500;
	line-height: 1.5142857143;
}

.sustainabilitySubBox {
	margin-top: 1em;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 0 2%;
}

.sustainabilitySubTit {
	margin-top: 2em;
	padding: 10px 20px;
	background: #efefef;
	font-size: 2.0rem;
	font-weight: 600;
}

.sustainabilitySubTxt {
	font-size: clamp(1.3rem, (1.1805555556vw), 1.5rem);
	line-height: 1.7647058824;
}

/*
.sustainabilityMainList {
	margin-top: 2em;
	width: 100%;
	display: flex;
	align-items: stretch;
	justify-content: space-between;
}

.sustainabilityMainItem {
	width: 48%;
}
*/

.sustainabilityMainList {
	margin-top: clamp(9px, 1.3888888889vw, 20px);
	width: 100%;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 100%;
	row-gap: 60px;
	-webkit-column-gap: clamp(19px, 4.5833333333vw, 66px);
	-moz-column-gap: clamp(19px, 4.5833333333vw, 66px);
	column-gap: clamp(19px, 4.5833333333vw, 66px);
}

.sustainabilityMainItem {
	/* 	width: calc((100% - clamp(19px, 4.5833333333vw, 66px) * 1) / 2); */
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

@media (max-width: 767px) {
	.sustainabilityMainList {
		display: flex;
		gap: 40px 0;
		flex-direction: column;
	}

	.sustainabilityMainItem {
		width: 100%;
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: start;
		-webkit-align-items: flex-start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
		row-gap: 10px;
	}
}

.sustainabilityMainBlock {
	width: calc(100% - clamp(160px, 18vw, 280px) - 25px);
	border-top: 1px solid #b5b5b6;
}

@media (max-width: 767px) {
	.sustainabilityMainBlock {
		width: 100%;
	}
}

/*
.sustainabilityMainTtlThird {
	margin-bottom: 0.5em;
	padding-bottom: 0.5em;
	border-bottom: 1px solid #b5b5b6;
	font-size: clamp(1.6rem, (1.5972222222vw), 2.3rem);
	line-height: 1.347826087;
}
*/

.sustainabilityMainTtlThird {
	margin-top: clamp(15px, 2.3611111111vw, 35px);
	font-size: clamp(1.8rem, (1.5972222222vw), 2.3rem);
	font-weight: 500;
	line-height: 1.347826087;
}

.sustainabilityMainImg {
	width: clamp(160px, 18vw, 280px);
	min-width: clamp(160px, 18vw, 280px);
	aspect-ratio: 280/250;
	-o-object-fit: cover;
	object-fit: cover;
}

.sustainabilityMainImg.smallImg {
	border: 1px solid #b5b5b6;
}

.sustainabilitySubImg {
	width: clamp(160px, 18vw, 280px);
	min-width: clamp(160px, 18vw, 280px);
	-o-object-fit: cover;
	object-fit: cover;
}


@media (max-width: 767px) {
	.sustainabilityMainImg {
		aspect-ratio: 318/191;
		width: 100%;
		min-width: 100%;
	}

	.sustainabilityMainImg.smallImg {
		object-fit: contain;
	}

	.sustainabilitySubImg {
		width: 100%;
		min-width: 100%;
	}
}

.sustainabilityMainHead + .sustainabilityMainTtlSecond {
	margin-top: 105px;
}

@media (max-width: 767px) {
	.sustainabilityMainHead + .sustainabilityMainTtlSecond {
		margin-top: 95px;
	}
}

.sustainabilityReport {
	margin-top: clamp(140px, 12.5vw, 180px);
	padding-bottom: clamp(52px, 9.9305555556vw, 143px);
}

.sustainabilityReportInner {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: clamp(19px, (9.7222222222vw), 140px);
	padding-right: clamp(19px, (9.7222222222vw), 140px);
}

@media (max-width: 767px) {
	.sustainabilityReportInner {
		padding-left: 19px;
		padding-right: 19px;
	}
}

.sustainabilityReportSubTtl {
	font-size: 3.5rem;
	font-weight: bold;
	text-align: center;
}

.sustainabilityReportTtl {
	margin-top: clamp(3px, 0.3472222222vw, 5px);
	font-size: clamp(1.1rem, (1.1805555556vw), 1.7rem);
	font-weight: 300;
	line-height: 1.9411764706;
	text-align: center;
}

@media (max-width: 767px) {
	.sustainabilityReportTtl {
		line-height: 1.6363636364;
	}
}

.sustainabilityReportList {
	width: 100%;
	margin-top: clamp(35px, 3.2638888889vw, 47px);
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	width: 100%;
	row-gap: clamp(28px, 3.6111111111vw, 52px);
	-webkit-column-gap: clamp(18px, 2.0833333333vw, 30px);
	-moz-column-gap: clamp(18px, 2.0833333333vw, 30px);
	column-gap: clamp(18px, 2.0833333333vw, 30px);
}

.sustainabilityReportItem {
	width: calc((100% - clamp(18px, 2.0833333333vw, 30px) * 3) / 4);
}

@media (max-width: 767px) {
	.sustainabilityReportItem {
		width: calc((100% - clamp(18px, 2.0833333333vw, 30px) * 1) / 2);
	}
}

.sustainabilityReportLink {
	position: relative;
	width: 100%;
}

.sustainabilityReportThumbnail {
	width: 100%;
	aspect-ratio: 265.5/200;
	-o-object-fit: cover;
	object-fit: cover;
}

@media (max-width: 767px) {
	.sustainabilityReportThumbnail {
		aspect-ratio: 318/240;
	}
}

.sustainabilityReportWrap {
	width: 100%;
	margin-top: clamp(9px, 0.9722222222vw, 14px);
	display: block;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	row-gap: clamp(8px, 0.7638888889vw, 11px);
}

.sustainabilityReportTag {
	background-color: #00a03a;
	color: #fff;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	min-width: clamp(85px, 8.3333333333vw, 120px);
	height: clamp(15px, 1.7361111111vw, 25px);
	border-radius: clamp(7px, 0.8680555556vw, 12.5px);
	font-size: clamp(1rem, (0.8333333333vw), 1.2rem);
	line-height: 1;
}

.sustainabilityReportTag span {
	white-space: nowrap;
}

.sustainabilityReportTime {
	white-space: nowrap;
	color: #595757;
	font-size: clamp(1rem, (1.0416666667vw), 1.5rem);
	line-height: 1.7333333333;
}

.sustainabilityReportTtlSecond {
	width: 100%;
	min-width: 100%;
	font-size: clamp(1.3rem, (1.3888888889vw), 2rem);
	font-weight: 500;
	line-height: 1.45;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #595757;
}

.sustainabilityReportAll {
	margin-top: clamp(41px, 3.8888888889vw, 56px);
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-webkit-justify-content: flex-end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.sustainabilityReportAllLink {
	font-size: 2rem;
	font-weight: 500;
	color: #009b73;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
}

.sustainabilityReportAllLink::before {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	background-image: url(./img/home/icon_dots.svg);
	background-repeat: no-repeat;
	background-size: contain;
	margin-right: 10px;
}

/* ポップアップ */
.popup-open {
	width: calc((100% - clamp(19px, 4.5833333333vw, 66px)* 1) / 2);
	cursor: pointer;
	/* マウスオーバーでカーソルの形状を変えることで、クリックできる要素だとわかりやすいように */
	transition: .6s;
}

.popup-open:hover {
	opacity: .6;
}

.popup-background {
	/*position size*/
	position: fixed;
	z-index: 100;
	top: 0;
	left: 0;
	height: 100vh;
	width: 100vw;

	/*design*/
	background-color: gray;
	opacity: 0.5
}

.popup {
	--width: 70vw;
	max-width: 1000px;
	min-height: 600px;
	z-index: 101;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	height: var(--height);
	width: var(--width);
	background-color: white;
	padding: 50px 0 30px;
}

.popup > .close-button {
	--size: 30px;
	position: absolute;
	top: -15px;
	right: -15px;
	height: var(--size);
	width: var(--size);
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #019A74;
	color: #fff;
	font-size: 20px;
	border-radius: 20px;
}

.popup > .popup-content {
	max-height: 80vh;
	padding-left: 70px;
	padding-right: 70px;
	font-feature-settings: "palt";
	overflow: auto;
}

.popup-content p {
	line-height: 1.8;
}

.popup-sustainability {
	color: #019A74;
	font-weight: 500;
	font-size: 2.0rem;
	margin-bottom: 65px;
	text-align: center;
}

.popup-ttl {
	margin-bottom: 25px;
	padding: 8px;
	font-size: 2.2rem;
	font-weight: 500;
	background: #EFEFEF;
}

.popup-subttl {
	margin-bottom: 30px;
	font-size: 2.0rem;
	font-weight: 500;
}

.popup-inner {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: 85px;
}

#popup4 .popup-inner,
#popup6 .popup-inner {
	margin-bottom: 0;
}

.popup-txt {
	width: 56%;
}

.popup-txt a {
	display: block;
	margin-bottom: 1em;
	color: #019A74;
}

.sdgsTit {
	margin: 50px auto 1em;
	font-size: 1.5rem;
	font-weight: 600;
}

.sdgs-icons {
	display: flex;
	align-items: center;
	gap: 0 2%;
}

#popup4 .sdgs-icons,
#popup6 .sdgs-icons {
	margin-bottom: 85px;
}

.sdgs-icons img {
	width: 18%;
}

.popup-innnerttl {
	padding-bottom: 0.5em;
	margin-bottom: 0.5em;
	border-bottom: 1px solid #b5b5b6;
	font-size: 2.2rem;
}

.popup-lead {
	margin-bottom: 1em;
	font-size: 2.0rem;
}

.popup-list {
	margin-bottom: 60px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 20px 0;
}

.popup-list li {
	width: 47%
}

.popup-tit {
	margin: 1em 0 0.5em;
	font-size: 2.2rem;
}

.popup-tit:first-child {
	margin-top: 0;
}

.popup-img {
	width: 38%;
}

.popup-img.w100 {
	width: 100%;
	margin-top: 40px;
}

.popup-logo {
	width: 50px;
	margin: 0 auto;
}

.popup-img img,
.popup-logo img {
	width: 100%;
	height: auto;
}

/*hide popup*/
.popup-flag {
	display: none;
}

.popup-flag:not(:checked) + .popup-background {
	display: none;
}

.popup-flag:not(:checked) + * + .popup {
	display: none;
}

html:has(label[open]) {
	overflow: hidden;
}

.popup-background {
	display: flex;
	overscroll-behavior: contain;
	overflow-y: scroll;
}

.nonScroll {
	height: calc(100vh + 1px);
	width: 1px;
	background-color: transparent;
}

@media (max-width: 767px) {
	.popup-open {
		width: 100%;
	}

	.popup {
		--width: 90vw;
		padding: 20px 0;
	}

	.popup > .popup-content {
		max-height: 90vh;
		padding: 0 5%;
	}

	.popup-content {
		font-size: 1.5rem;
		line-height: 1.6;
	}

	.popup-sustainability {
		font-size: 2.2rem;
		margin-bottom: 1em;
	}

	.popup-inner {
		margin-bottom: 40px;
		flex-direction: column;
		gap: 30px;
	}

	#popup4 .popup-inner,
	#popup6 .popup-inner {
		margin-bottom: 40px;
	}

	.popup-ttl {
		margin-bottom: 1em;
		padding: 8px 12px;
		font-size: 1.5rem;
	}

	.popup-subttl {
		font-size: 1.6rem;
		margin-bottom: 1em;
	}

	.popup-txt {
		width: 100%;
	}

	.popup-txt p,
	.popup-txt2 {
		font-size: 1.3rem;
		line-height: 2.0;
	}

	.popup-img {
		width: 100%;
	}

	#popup4 .sdgs-icons,
	#popup6 .sdgs-icons {
		margin-bottom: 20px;
	}

	.sdgsTit {
		margin-top: 20px;
	}

	#popup6 .sdgsTit {
		margin-top: -10px;
	}

	.popup-innnerttl {
		padding-bottom: 0.25em;
		margin-bottom: 0.25em;
		font-size: 1.6rem;
	}

	.popup-list {
		flex-direction: column;
	}

	.popup-list li {
		width: 100%;
	}

	.popup-lead {
		font-size: 1.5rem;
	}

	.popup-tit {
		font-size: 1.6rem;
		font-weight: 500;
	}
}

/*# sourceMappingURL=style.css.map */