@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
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;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

* {
  --min-viewport: 390;
  --max-viewport: 1440;
  /* a 傾き */
  --slope: calc((var(--max-size) - var(--min-size)) / (var(--max-viewport) - var(--min-viewport)));
  /* b 切片 */
  --intercept: calc(var(--min-size) - var(--slope) * var(--min-viewport));
  /* y = ax + b */
  --fluid-size: calc(var(--slope) * 100vw + var(--intercept) / 16 * 1rem);
  /* clamp( 最小サイズ , 可変サイズ , 最大サイズ) */
  --clamp-size: clamp(var(--min-size) / 16 * 1rem, var(--fluid-size), var(--max-size) / 16 * 1rem);
}

img {
  max-width: 100%;
}



svg {
  max-width: 100%;
}

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

.sp-only {
  display: none;
}
@media screen and (max-width: 768px) {
  .sp-only {
    display: block;
  }
}

html,
body {
  margin: 0;
  padding: 0;
  width: 100%;
  scroll-behavior: smooth;
}

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

body {
  overflow-x: hidden;
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #404040;
}

p {
  margin: 0;
  color: #191716;
}

a {
  color: inherit;
  text-decoration: none;
}

address {
  font-style: normal;
}

img {
  vertical-align: top;
  width: 100%;
}

input[type=text]:focus,
input[type=date]:focus,
input[type=tel]:focus,
input[type=email]:focus,
select:focus,
textarea:focus {
  outline: solid 2px var(--blue);
}

input[type=checkbox],
input[type=radio] {
  width: 16px;
  height: 16px;
}

input[type=radio] {
  -webkit-appearance: none;
  border-radius: 50%;
  border: 1px solid var(--blue);
}
input[type=radio]::before {
  content: "";
  display: block;
  width: 60%;
  height: 60%;
  margin: 20% auto;
  border-radius: 50%;
}

input[type=radio]:checked:before {
  background: var(--blue);
}

input[type=checkbox]:not(:checked) {
  -webkit-appearance: none;
  border-radius: 3px;
  border: 1px solid var(--blue);
}

.contactType2 {
  margin-top: 151px;
}
@media screen and (max-width: 768px) {
  .contactType2 {
    margin-top: 80px;
  }
}

.contactWrapper {
  display: flex;
  gap: 20px;
}
@media screen and (max-width: 1200px) {
  .contactWrapper {
    flex-direction: column;
    padding-left: 20px;
  }
}
@media screen and (max-width: 768px) {
  .contactWrapper {
    padding: 0;
  }
}

.contactLink {
  display: inline-block;
  width: 100%;
  max-width: 740px;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .contactLink {
    max-width: 100%;
  }
}

.contact {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #006e36;
  padding-block: 66px 55px;
  padding-inline: 50px 30px;
  width: 100%;
}
@media screen and (max-width: 576px) {
  .contact {
    padding-block: 26px 25px;
    padding-inline: 30px 30px;
  }
}

.contactTitleBox {
  display: flex;
  flex-direction: column;
}

.contactTitle {
  --min-size: 48;
  --max-size: 60;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  letter-spacing: 0px;
  color: #fff;
}

.contactSubTitle {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  line-height: 1.2222222222;
  letter-spacing: -0.9px;
  color: #fff;
}

.contact .contactButton {
  background-color: unset;
  border: solid 1px #fff;
}
.contact .contactButton::before {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

.snsInfoLinkIcon {
  width: 55px;
  height: auto;
}
@media screen and (max-width: 576px) {
  .snsInfoLinkIcon {
    width: 30px;
  }
}
.snsInfoLinkIcon-x{
  width: 50px;
  vertical-align: bottom;
}
@media screen and (max-width: 576px) {
  .snsInfoLinkIcon-x{
    width: 27px;
  }
}
.snsInfo {
  display: flex;
  justify-content: center;
  padding-block: 73px 72px;
  border: 1px solid #006e36;
  width: 100%;
  max-width: 740px;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .snsInfo {
    max-width: 100%;
  }
}
@media screen and (max-width: 576px) {
  .snsInfo {
    padding-block: 49px;
  }
}
@media screen and (max-width: 428px) {
  .snsInfo {
    flex-direction: column;
    align-items: center;
    padding-block: 23px;
  }
}

.snsInfoCol {
  display: flex;
  align-items: center;
  gap: 30px;
}
@media screen and (max-width: 1440px) {
  .snsInfoCol {
    gap: 20px;
  }
}
@media screen and (max-width: 428px) {
  .snsInfoCol {
    gap: 8px;
  }
}
.snsInfoCol:first-child {
  border-right: 1px solid #707070;
  padding-right: 50px;
}
@media screen and (max-width: 1440px) {
  .snsInfoCol:first-child {
    padding-right: 20px;
  }
}
@media screen and (max-width: 428px) {
  .snsInfoCol:first-child {
    padding-right: 0px;
    padding-bottom: 10px;
    border-right: none;
    border-bottom: 1px solid #707070;
  }
}
.snsInfoCol:nth-child(2) {
  padding-left: 44px;
}
@media screen and (max-width: 1440px) {
  .snsInfoCol:nth-child(2) {
    padding-left: 24px;
  }
}
@media screen and (max-width: 428px) {
  .snsInfoCol:nth-child(2) {
    padding-left: 0;
    padding-top: 10px;
  }
}

.snsInfoText {
  --min-size: 20;
  --max-size: 24;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2083333333;
  letter-spacing: 0px;
  color: #191716;
}

.snsInfoLink + .snsInfoLink {
  padding-left: 30px;
}
@media screen and (max-width: 1440px) {
  .snsInfoLink + .snsInfoLink {
    padding-left: 20px;
  }
}
@media screen and (max-width: 428px) {
  .snsInfoLink + .snsInfoLink {
    padding-left: 8px;
  }
}

.partsInfowrapper + .partsInfowrapper {
  margin-top: 58px;
}

.partsInfoLinkBox {
  display: flex;
  align-items: center;
  gap: 30px;
}

.partsInfoText {
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  letter-spacing: 0px;
  color: #006e36;
}

.partsInfoLinkBox .partsInfoButton {
  min-width: 40px;
  width: 40px;
  height: 40px;
  background-color: #006e36;
  border: solid 1px #006e36;
}
.partsInfoLinkBox .partsInfoButton::before {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

.partsInfoList {
  display: flex;
  flex-wrap: wrap;
  gap: 30px 20px;
  margin-top: 32px;
}

.partsInfoItem {
  display: inline-block;
  position: relative;
  width: fit-content;
}
.partsInfoItem::before {
  content: "";
  color: #006e36;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #006e36;
  position: absolute;
  top: 0.35em;
  left: 0;
}

.partsInfoItemText {
  display: inline-block;
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  font-weight: bold;
  letter-spacing: 0px;
  color: #191716;
  padding-left: 20px;
}

.l-wrapper {
  margin-inline: auto;
  padding-inline: 10.9%;
}
@media screen and (max-width: 768px) {
  .l-wrapper {
    padding-inline: 24px;
  }
}

.l-inner {
  max-width: 1500px;
}

.c-inner {
  max-width: 1500px;
  margin-inline: auto;
}
@media screen and (max-width: 1499px) {
  .c-inner {
    padding-inline: 56px;
  }
}
@media screen and (max-width: 768px) {
  .c-inner {
    max-width: 100%;
    padding-inline: 24px;
  }
}

.c-pageArrowButton {
  height: 50px;
  width: 50px;
  min-width: 50px;
  background: #fff;
  border: solid 1px #191716;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-right: 6px;
}
.c-pageArrowButton::before {
  content: "";
  height: 12px;
  width: 12px;
  border-top: 1px solid #191716;
  border-right: 1px solid #191716;
  transform: translateY(0%) rotate(45deg);
}

.c-TitleH2 {
  --min-size: 32;
  --max-size: 40;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  color: #006e36;
}

.c-buttonAnimetion .c-buttonUnderline {
  position: relative;
}
.c-buttonAnimetion .c-buttonUnderline::after {
  content: "";
  position: absolute;
  bottom: -7px;
  left: 0;
  width: 100%;
  height: 1px;
  transform-origin: right top;
  transition: transform 0.2s;
  transform: scale(1, 1);
  background-color: #191716;
}
.c-buttonAnimetion:hover .c-buttonUnderline::after {
  transform: scale(0, 1);
}
.c-buttonAnimetion .c-pageArrowButton {
  transition-duration: 0.3s;
}
.c-buttonAnimetion:hover .c-pageArrowButton {
  transform: scale(1.1);
}

.c-breadcrumb {
  font-size: 14px;
  margin-top: 20px;
}

.c-breadcrumb__breadcrumb-link {
  color: #006e36;
}

.c-page__mv {
  max-width: 100%;
  max-height: 700px;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .c-page__mv {
    height: fit-content;
    width: 100%;
    object-fit: cover;
  }
}
.c-page__mv img {
  height: 60vh;
  object-fit: cover;
}

.c-page__header {
  display: flex;
  align-items: center;
  gap: 1em;
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .c-page__header {
    flex-direction: column;
    align-items: baseline;
  }
}

.c-page__title {
  --min-size: 36;
  --max-size: 60;
  font-size: var(--clamp-size);
  color: #006e36;
  line-height: 1.6;
  letter-spacing: 0;
  font-weight: bold;
  position: relative;
}

.c-page__header-line {
  flex-grow: 1;
  height: 1px;
  background-color: #006e36;
}
@media screen and (max-width: 768px) {
  .c-page__header-line {
    display: none;
  }
}

.c-page__subtitle {
  --min-size: 14;
  --max-size: 18;
  font-size: var(--clamp-size);
  color: #191716;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  .c-page__subtitle {
    white-space: wrap;
  }
}

.c-page-contents__wrapper {
  margin-top: 100px;
  display: flex;
  justify-content: space-between;
  gap: 5%;
  align-items: flex-start;
}
@media screen and (max-width: 768px) {
  .c-page-contents__wrapper {
    flex-direction: column;
    row-gap: 50px;
  }
}

.c-page__nav {
  max-width: 198px;
  width: 15%;
  position: sticky;
  top: 120px;
  align-self: start;
  z-index: 10;
}
@media screen and (max-width: 768px) {
  .c-page__nav {
    max-width: 100%;
    width: 100%;
    position: static;
  }
}

.c-page__content {
  max-width: 1200px;
  width: 80%;
}
@media screen and (max-width: 768px) {
  .c-page__content {
    width: 100%;
  }
}

.c-page__nav-list {
  display: flex;
  flex-direction: column;
  /* row-gap: 30px; */
}
.c-page__nav-item{
  padding-block: 15px;
}

.c-page__nav-item a {
  position: relative;
  display: inline-block;
  font-size: 20px;
  font-weight: bold;
}
.sod__nav .c-page__nav-item a {
  background-color: #D0ECD5;
  padding-block: 5px;
  padding-inline: 8px;
  border-radius: 20px;
}
.sod__nav .c-page__nav-item:first-child a, .sod__nav .c-page__nav-item:last-child a {
  background-color: #fff;
  padding: 0;
}

.c-page__nav-item a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -24px;
  width: 18px;
  height: 6px;
  background: url(../../assets/img/construct/aside-direction.svg) no-repeat;
}

.c-page__section-title {
  position: relative;
  --min-size: 32;
  --max-size: 40;
  font-size: var(--clamp-size);
  color: #006e36;
  font-weight: bold;
  line-height: 1.625;
  letter-spacing: 0;
}

#l-header {
  position: fixed;
  z-index: 3;
  top: 15px;
  padding-inline: 50px;
  width: 100%;
  max-width: 100%;
}
@media screen and (max-width: 768px) {
  #l-header {
    padding-inline: 8px;
  }
}
.headerCotent {
  display: flex;
  justify-content: space-between;
  position: relative;
  border-radius: 40px;
  height: 87px;
  text-align: center;
}
@media screen and (max-width: 992px) {
  .headerCotent {
    display: inline-block;
    border-radius: unset;
    height: auto;
  }
}
.headerCotent::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 40px;
  background-color: #fff;
  opacity: 0.9;
  z-index: -1;
}
@media screen and (max-width: 992px) {
  .headerCotent::before {
    position: static;
    border-radius: unset;
    background-color: unset;
    opacity: 1;
  }
}

@media screen and (max-width: 992px) {
  .headerLogoImg {
    max-width: 150px;
    height: auto;
  }
}

.headerLogo {
  padding-top: 12px;
  padding-left: 30px;
  margin-right: 16px;
}
@media screen and (max-width: 992px) {
  .headerLogo {
    text-align: start;
    padding-top: 10px;
    padding-left: 0;
    margin-right: 0;
  }
}

.toggleNav {
  padding-top: 15px;
  padding-right: 20px;
}
@media screen and (max-width: 992px) {
  .toggleNav {
    position: fixed;
    right: -100%;
    top: 0;
    width: 100%;
    height: 100vh;
    transition: all 0.5s;
    z-index: 200;
    overflow-y: auto;
    padding: 10em 0 0;
  }
  .toggleNav.open {
    right: 0;
    transition: all 0.3s;
    background-color: #fff;
  }
}

.toggleNavList {
  display: flex;
  align-items: center;
  gap: 30px;
}
@media screen and (max-width: 992px) {
  .toggleNavList {
    flex-direction: column;
  }
}

.toggleNavLink {
  line-height: 0.8181818182;
  font-weight: bold;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  color: #191716;
}
@media (hover: hover) and (pointer: fine) {
  .toggleNavLink:hover {
    color: #006e36;
  }
}

.toggleNavButton {
  display: inline-block;
  width: 196px;
  border: 2px solid #006e36;
  background: #006e36;
  border: 2px solid #006e36;
  border-radius: 29px;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  color: #fff;
  line-height: 0.8181818182;
  padding-block: 0.944em 1em;
}
@media (hover: hover) and (pointer: fine) {
  .toggleNavButton:hover {
    color: #006e36;
    background: #fff;
  }
}

@media screen and (max-width: 992px) {
  .hamburger {
    position: fixed;
    right: 8px;
    top: 20px;
    width: 50px;
    height: 50px;
    z-index: 300;
  }
  .hamburgerLine {
    position: absolute;
    width: 35px;
    height: 5px;
    right: 15px;
    background-color: #404040;
    transition: all 0.5s;
    border-radius: 20px;
  }
  .hamburgerLine:nth-child(1) {
    top: 10px;
  }
  .hamburgerLine:nth-child(2) {
    top: 21px;
  }
  .hamburgerLine:nth-child(3) {
    top: 32px;
  }
  .open .hamburgerLine:nth-child(1) {
    transform: rotate(-45deg);
    top: 24px;
  }
  .open .hamburgerLine:nth-child(2) {
    opacity: 0;
    transition: all 0.1s;
  }
  .open .hamburgerLine:nth-child(3) {
    transform: rotate(45deg);
    top: 24px;
  }
}
.header02 {
  margin-top: 15px;
  padding-inline: 50px;
}
@media screen and (max-width: 992px) {
  .header02 {
    margin-top: 0;
  }

}
.l-footer {
  padding-top: 162px;
}
@media screen and (max-width: 768px) {
  .l-footer {
    padding-top: 100px;
    padding-inline: 16px;
  }
}

.footerLow01 {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 1200px) {
  .footerLow01 {
    flex-direction: column;
  }
}

.footerBox {
  display: flex;
  justify-content: flex-start;
  flex-direction: column;
  align-items: flex-start;
}

.footerLogoImg {
  display: inline-block;
  max-width: 192px;
  height: auto;
}

.footerInfo {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  margin-top: 26px;
}

.footerInfoAddress, .footerInfoTelephone {
  --min-size: 13;
  --max-size: 19;
  font-size: var(--clamp-size);
  line-height: 0.8421052632;
  letter-spacing: 0px;
  color: #191716;
}

.footerLawnInfo {
  display: flex;
  gap: 10px;
}
@media screen and (max-width: 1440px) {
  .footerLawnInfo {
    width: 60%;
  }
}
@media screen and (max-width: 1200px) {
  .footerLawnInfo {
    width: fit-content;
    margin-inline: auto;
    margin-top: 51px;
  }
}
@media screen and (max-width: 768px) {
  .footerLawnInfo {
    width: 90%;
    justify-content: center;
    flex-wrap: wrap;
  }
}

.footerLawnInfocolLink {
  display: flex;
  align-items: center;
  border: 1px solid #006e36;
  border-radius: 10px;
  padding-block: 13px;
  padding-inline: 17px 5px;
  max-width: 277px;
}
@media screen and (max-width: 1440px) {
  .footerLawnInfocolLink {
    padding-block: 2px;
  }
}
@media screen and (max-width: 1200px) {
  .footerLawnInfocolLink {
    padding-block: 13px;
  }
}
@media screen and (max-width: 768px) {
  .footerLawnInfocolLink {
    flex: 1 1 auto;
    width: 279px;
    max-width: 279px;
  }
}

@media screen and (max-width: 1440px) {
  .footerLawnInfoImg02 {
    max-height: 74px;
  }
}

.footerLawnCol01 .footerLawnInfoImg02 {
  max-width: 98px;
  margin-left: 9px;
}

.footerLawnCol02 .footerLawnInfoImg02 {
  margin-left: 5px;
}

.footerLawnInfoTextArea {
  padding-left: 22px;
}

.footerLawnInfoText {
  text-align: left;
  font-size: 16px;
  font-weight: bold;
  line-height: 0.8421052632;
  letter-spacing: 0px;
  color: #006e36;
}
@media screen and (max-width: 1440px) {
  .footerLawnInfoText {
    line-height: 1.3;
  }
}

.c-pageArrowButton.footerLawnInfoButton {
  min-width: 30px;
  width: 30px;
  height: 30px;
  margin-left: 10px;
  border: solid 1px #006e36;
}
.c-pageArrowButton.footerLawnInfoButton:before {
  content: "";
  height: 12px;
  width: 12px;
  border-top: 1px solid #006e36;
  border-right: 1px solid #006e36;
  transform: translateY(0%) rotate(45deg);
}
@media (hover: hover) and (pointer: fine) {
  .c-pageArrowButton.footerLawnInfoButton:hover {
    background: #006e36;
    border: solid 1px #006e36;
  }
  .c-pageArrowButton.footerLawnInfoButton:hover:before {
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}

.footerNav {
  margin-top: 51px;
}
@media screen and (max-width: 1200px) {
  .footerNav {
    justify-content: flex-start;
    flex-wrap: wrap;
    width: 90%;
    margin-inline: auto;
  }
}

.footerNavList {
  display: flex;
  gap: 30px;
}
@media screen and (max-width: 1200px) {
  .footerNavList {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 768px) {
  .footerNavList {
    gap: 16px;
  }
}

.footerNavListLink {
  --min-size: 14;
  --max-size: 18;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 0.8181818182;
  letter-spacing: 0px;
  color: #191716;
}

.footerLow03 {
  display: flex;
  justify-content: space-between;
  margin-top: 68px;
}
@media screen and (max-width: 1200px) {
  .footerLow03 {
    align-items: flex-end;
    padding-bottom: 8px;
  }
}
@media screen and (max-width: 576px) {
  .footerLow03 {
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }
}

.footerLow03List {
  display: flex;
  gap: 30px;
}
@media screen and (max-width: 1200px) {
  .footerLow03List {
    gap: 16px;
    flex-direction: column;
  }
}
@media screen and (max-width: 576px) {
  .footerLow03List {
    flex-direction: row;
  }
}

.footerLow03Item {
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 0.8421052632;
  letter-spacing: 0px;
  color: #191716;
}

.copyright {
  --min-size: 12;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 0.8421052632;
  letter-spacing: 0px;
  color: #191716;
}

.footerType2 {
  margin-top: 150px;
}
@media screen and (max-width: 768px) {
  .footerType2 {
    margin-top: 80px;
  }
}

.construct__top-image {
  margin-top: 50px;
  max-width: 1200px;
}

.construct__image {
  max-width: 386px;
  width: 31.6333333333%;
}
@media screen and (max-width: 768px) {
  .construct__image {
    width: 100%;
  }
}

.construct__detail {
  margin-top: 100px;
}

.construct__heading {
  --min-size: 32;
  --max-size: 40;
  font-size: var(--clamp-size);
  color: #404040;
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
}

.construct__text {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.6;
  color: #404040;
  margin-top: 30px;
}

.construct__section {
  margin-top: 100px;
}

.construct__section:first-child {
  margin-top: 0;
}

.construct__description {
  margin-top: 30px;
}

.construct__heading-sub {
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  line-height: 1.5833333333;
  color: #191716;
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  font-weight: Demibold;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .construct__heading-sub {
    text-align: left;
  }
}

.construct__gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 1.7%;
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .construct__gallery {
    flex-direction: column;
    row-gap: 21px;
    align-items: center;
  }
}

.construct__subsection-title {
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  line-height: 1.625;
  color: #191716;
  font-weight: bold;
  position: relative;
}

.construct__subsection .c-page__header-line {
  background-color: #949494;
}

.swiperLogos {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  bottom: 50px;
  width: 100%;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .swiperLogos {
    bottom: 0;
    padding-block: 16px;
    background: rgba(38, 39, 60, 0.69);
  }
}
.swiperLogoText {
  width: min(53%, 1000px);
  max-width: 1000px;
  height: auto;
  padding-left: clamp(1.25rem, -4.48rem + 11.923vw, 6.25rem);
}
@media screen and (max-width: 1200px) {
  .swiperLogoText {
    width: min(70%, 1000px);
  }
}
@media screen and (max-width: 768px) {
  .swiperLogoText {
    width: 100%;
    padding-left: 8px;
  }
}

.swiperLogoTextImg {
  width: 100%;
  height: auto;
  max-width: 100%;
}

.swiperLogoImg {
  max-width: 200px;
  height: auto;
  padding-right: clamp(1.563rem, -0.228rem + 3.726vw, 3.125rem);
}
@media screen and (max-width: 1200px) {
  .swiperLogoImg {
    max-width: 150px;
  }
}
@media screen and (max-width: 768px) {
  .swiperLogoImg {
    max-width: 70px;
    height: auto;
    padding-right: 8px;
  }
}

.top-about {
  position: relative;
  overflow: hidden;
}

.top-aboutBg {
  position: relative;
  background-color: #7FB85E;
  padding-bottom: 100px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .top-aboutBg {
  padding-bottom: 80px;
}
}

.top-aboutImgBox {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  z-index: -1;
}

.top-aboutImg {
  min-height: 1067px;
}
@media screen and (max-width: 1440px) {
  .top-aboutImg {
    min-height: auto;
  }
}
.top-aboutHead {
  display: flex;
  justify-content: space-between;
  padding-top: 205px;
}
@media screen and (max-width: 1440px) {
  .top-aboutHead {
    padding-top: clamp(6.25rem, -8.328rem + 23.49vw, 12.813rem);
  }
}
@media screen and (max-width: 768px) {
  .top-aboutHead {
    flex-direction: column;
    padding-top: 50px;
  }
}

.top-aboutTitle {
  display: flex;
  flex-direction: column;
  gap: 19px;
}

.top-aboutSubTitle {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2222222222;
  color: #191716;
}

.top-aboutLinkText {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2222222222;
  color: #191716;
}

.top-aboutLink {
  display: flex;
  align-items: center;
  gap: 21px;
}
@media screen and (max-width: 768px) {
  .top-aboutLink {
    justify-content: flex-end;
    margin-top: 32px;
  }
}
.top-aboutLink:hover .top-aboutLinkText {
  color: #006e36;
}
.top-aboutLink .c-pageArrowButton.top-aboutButton {
  border: solid 1px #006e36;
  background-color: #006e36;
}
.top-aboutLink .c-pageArrowButton.top-aboutButton::before {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

.top-aboutHeadTextArea {
  margin-top: clamp(2rem, -1.938rem + 4.375vw, 3.313rem);
}

.top-aboutHeadText {
  letter-spacing: 0px;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  line-height: 1.2222222222;
}
.top-aboutHeadText + .top-aboutHeadText {
  margin-top: 1.6em;
}

.top-aboutSwiperConteiner {
  overflow: hidden;
  width: 100%;
  margin-top: 156px;
}
@media screen and (max-width: 1440px) {
  .top-aboutSwiperConteiner {
    margin-top: clamp(4.75rem, -6.357rem + 17.897vw, 9.75rem);
  }
}

.top-aboutSwiper {
  position: relative;
}

.top-aboutSwiperImg {
  object-fit: cover;
}

.top-office {
  margin-top: 100px;
}
@media screen and (max-width: 1440px) {
  .top-office {
    margin-top: clamp(4.75rem, 1.418rem + 5.369vw, 6.25rem);
  }
}

.top-officeWrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 33px;
  border-bottom: 1px solid #191716;
}

.top-officeTitle {
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  line-height: 1.2;
  font-weight: bold;
  letter-spacing: 0px;
  color: #191716;
}

.top-officeText {
  letter-spacing: 0px;
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  padding-top: 17px;
}

.top-officeButton {
  transition: transform 0.2s;
  background: unset;
}

.top-officeLink:hover .top-officeButton {
  transition: transform 0.2s;
  transform: scale(1.1, 1.1);
}

.top-service {
  background-color: #006e36;
  padding-block: 100px;
}

@media screen and (max-width: 768px) {
.top-service {
  padding-block: 80px;
}
}

.top-serviceTitleArea {
  display: flex;
  flex-direction: column;
}

.top-serviceTitle {
  --min-size: 48;
  --max-size: 60;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  color: #fff;
}

.top-serviceSubTitle {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  line-height: 1.2222222222;
  color: #fff;
}

.top-seviceCard {
  display: inline-block;
  width: 100%;
  padding-block: 50px;
  border-top: 1px solid #ECE2D0;
}
.top-seviceCard:nth-child(1) {
  margin-top: 53px;
}
.top-seviceCard:last-child {
  border-bottom: 1px solid #ECE2D0;
}
@media (hover: hover) and (pointer: fine) {
  .top-seviceCard:hover .top-seviceImg {
    transition: transform 0.2s;
    transform: scale(0.95, 0.95);
  }
  .top-seviceCard:hover .top-serviceItemLinkText::after {
    transform: scale(0, 1);
  }
  .top-seviceCard:hover .top-serviceItemLink .top-serviceItemButton {
    transform: scale(1.1);
  }
}
.top-seviceCard .top-seviceItemTitle::before {
  content: "1";
  font-family: Century Gothic, CenturyGothic, AppleGothic, sans-serif;
}
.top-seviceCard:nth-of-type(2) .top-seviceItemTitle::before {
  content: "2";
  font-family: Century Gothic, CenturyGothic, AppleGothic, sans-serif;
}
.top-seviceCard:nth-of-type(3) .top-seviceItemTitle::before {
  content: "3";
  font-family: Century Gothic, CenturyGothic, AppleGothic, sans-serif;
}
.top-seviceCard:nth-of-type(4) .top-seviceItemTitle::before {
  content: "4";
  font-family: Century Gothic, CenturyGothic, AppleGothic, sans-serif;
}
.top-seviceCard:nth-of-type(5) .top-seviceItemTitle::before {
  content: "5";
  font-family: Century Gothic, CenturyGothic, AppleGothic, sans-serif;
}

.top-seviceItem {
  display: flex;
  justify-content: space-between;
  gap: 32px;
}
@media screen and (max-width: 768px) {
  .top-seviceItem {
    flex-direction: column-reverse;
  }
}

.top-seviceItemTextArea {
  display: grid;
  flex: 1 1 30%;
}

.top-seviceItemTitle {
  display: flex;
  align-items: center;
  gap: 20px;
  position: relative;
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  letter-spacing: 0px;
  color: #fff;
}
.top-seviceItemTitle::before {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 60px;
  border-radius: 50px;
  border: 1px solid #fff;
  font-size: 30px;
  line-height: 1.2;
  text-align: center;
  padding-top: 5px;
}

.top-seviceItemText {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  line-height: 1.2222222222;
  color: #fff;
  padding-top: 32px;
}

.top-seviceItemButtonArea {
  display: flex;
  align-items: flex-end;
}
@media screen and (max-width: 992px) {
  .top-seviceItemButtonArea {
    padding-top: 32px;
  }
}
@media screen and (max-width: 768px) {
  .top-seviceItemButtonArea {
    justify-content: flex-end;
  }
}

.top-serviceItemLink {
  display: flex;
  align-items: center;
  gap: 20px;
}

.top-serviceItemLinkText {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  line-height: 1.2222222222;
  color: #fff;
}
.top-serviceItemLinkText.c-buttonUnderline::after {
  background-color: #fff;
}

.top-serviceItemButton {
  background: unset;
  border: 1px solid #fff;
  color: #fff;
}
.top-serviceItemButton::before {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

@media screen and (max-width: 768px) {
  .top-seviceImgBox {
    margin-inline: auto;
  }
}

.top-seviceImg {
  width: 100%;
  height: fit-content;
  aspect-ratio: 611/350;
  object-fit: cover;
  max-width: 611px;
  transition: transform 0.2s;
}
@media screen and (max-width: 1200px) {
  .top-seviceImg {
    max-width: 460px;
    aspect-ratio: 460/264;
  }
}
@media screen and (max-width: 992px) {
  .top-seviceImg {
    max-width: 362px;
    aspect-ratio: 362/207;
  }
}
@media screen and (max-width: 768px) {
  .top-seviceImg {
    aspect-ratio: auto;
    max-width: 100%;
  }
}

.serviceLawnInfo {
  display: flex;
  gap: 8px;
  padding-top: 100px;
}
@media screen and (max-width: 992px) {
  .serviceLawnInfo {
    justify-content: center;
    flex-wrap: wrap;
    align-items: center;
  }
}
@media screen and (max-width: 768px) {
  .serviceLawnInfo {
    flex-direction: column;
  }
}

.serviceLawnInfocolLink {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #fff;
  border: 1px solid #006e36;
  border-radius: 10px;
  padding-block: 29px 25px;
  padding-inline: 19px 9px;
  width: 100%;
  max-width: 495px;
}
@media screen and (max-width: 1200px) {
  .serviceLawnInfocolLink {
    padding-block: 15px 12px;
    gap: 12px;
  }
}
@media screen and (max-width: 992px) {
  .serviceLawnInfocolLink {
    max-width: 300px;
  }
}
@media screen and (max-width: 768px) {
  .serviceLawnInfocolLink {
    max-width: 495px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .serviceLawnInfocolLink:hover .serviceLawnInfoButton {
    background: #006e36;
    border: 1px solid #fff;
  }
  .serviceLawnInfocolLink:hover .serviceLawnInfoButton.serviceLawnInfoButton::before {
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}

@media screen and (max-width: 992px) {
  .serviceLawnInfoImgBox .serviceLawnInfoImg01 {
    max-height: 60px;
  }
}
@media screen and (max-width: 992px) and (max-width: 768px) {
  .serviceLawnInfoImgBox .serviceLawnInfoImg01 {
    max-width: 90%;
    max-height: 122px;
    height: auto;
  }
}
@media screen and (max-width: 992px) {
  .serviceLawnInfoImgBox .serviceLawnInfoImg02 {
    max-height: 60px;
  }
}
@media screen and (max-width: 992px) and (max-width: 768px) {
  .serviceLawnInfoImgBox .serviceLawnInfoImg02 {
    max-height: 122px;
    height: auto;
  }
}

@media screen and (max-width: 1200px) {
  .serviceLawnInfoImg01 {
    max-width: 80%;
    height: auto;
  }
}
@media screen and (max-width: 992px) {
  .serviceLawnInfoImg01 {
    max-width: 100%;
  }
}

@media screen and (max-width: 1200px) {
  .serviceLawnInfoImg02 {
    max-width: 60%;
    height: auto;
  }
}
@media screen and (max-width: 992px) {
  .serviceLawnInfoImg02 {
    max-width: 100%;
  }
}

.serviceLawnCol01 .serviceLawnInfoImg02 {
  max-width: 162px;
  height: auto;
}

@media screen and (max-width: 1200px) {
  .serviceLawnCol03 .serviceLawnInfoImgBox {
    width: 50%;
  }
}

.fserviceLawnInfoTextArea {
  padding-left: 22px;
}

.serviceLawnInfoText {
  --min-size: 16;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  color: #006e36;
}

.serviceLawnInfoButton {
  min-width: 53px;
  height: 53px;
  border: 1px solid #006e36;
}
.serviceLawnInfoButton::before {
  border-top: 1px solid #006e36;
  border-right: 1px solid #006e36;
}
@media screen and (max-width: 768px) {
  .serviceLawnInfoButton {
    min-width: 32px;
    width: 32px;
    height: 32px;
  }
}

.top-news {
  position: relative;
  padding-block: 100px;
}
@media screen and (max-width: 768px) {
  .top-news {
    padding-block: 80px;
  }
}

.top-newsBg {
  position: absolute;
  z-index: -1;
}
.top-newsBg.__newsBg01 {
  top: 0;
  left: 0;
  max-width: 686px;
}
.top-newsBg.__newsBg02 {
  top: 0;
  right: 0;
  max-width: 686px;
}
.top-newsBg .top-newsBgImg {
  height: auto;
}

.top-newsWrap {
  display: flex;
  gap: 56px;
}
@media screen and (max-width: 768px) {
  .top-newsWrap {
    flex-direction: column;
  }
}

.top-newsHead {
  display: grid;
  flex: 1 1 20.9%;
}
@media screen and (max-width: 768px) {
  .top-newsHead {
    flex: auto;
    gap: 32px;
  }
}

.top-newsLinkArea {
  display: flex;
  align-items: flex-end;
}
@media screen and (max-width: 768px) {
  .top-newsLinkArea {
    justify-self: end;
  }
}

.top-newsLink {
  display: flex;
  align-items: center;
  gap: 20px;
}
@media (hover: hover) and (pointer: fine) {
  .top-newsLink:hover .top-newsButton {
    border: 1px solid #fff;
    background-color: #006e36;
  }
  .top-newsLink:hover .top-newsButton::before {
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}

.top-newsTitle {
  --min-size: 48;
  --max-size: 60;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  text-align: left;
  color: #006e36;
}

.top-newsContent {
  flex: 1 1 73.8%;
}

.top-newsLinkBox {
  display: block;
  border-top: 1px solid #AAA;
}
.top-newsLinkBox:last-child {
  border-bottom: 1px solid #AAA;
}

.top-newLlist {
  position: relative;
  display: flex;
  gap: 22px;
  padding-block: 31px;
}
@media screen and (max-width: 768px) {
  .top-newLlist {
    padding-right: 10px;
  }
}
.top-newLlist::after {
  content: "";
  position: absolute;
  top: 43%;
  right: 0;
  height: 12px;
  width: 12px;
  border-top: 1px solid #006e36;
  border-right: 1px solid #006e36;
  transform: translateY(0%) rotate(45deg);
}

.top-newsDay {
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.1875;
  color: #006e36;
}

.top-newsDetail {
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  color: #191716;
}

.greeting__section .c-page__header {
  margin-top: 0;
}

.company__img {
  position: relative;
}

.company__img-name {
  position: absolute;
  bottom: 0;
  right: 8px;
  color: #fff;
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.95;
}

.company__img-name span {
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  line-height: 1.625;
}

.greeting__detail {
  background: url(../../assets/img/company/greeting_bg.jpg) no-repeat;
  width: 100%;
  padding: 50px;
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .greeting__detail {
    padding: 20px;
  }
}

.company__greeting-name {
  margin-top: 50px;
  display: flex;
  flex-direction: column;
  row-gap: 10px;
  align-items: flex-end;
}

.company__greeting-jp {
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
}

.company__greeting-en {
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  letter-spacing: 1.6px;
  line-height: 1.625;
}

.motto__body {
  display: flex;
  align-items: center;
  gap: 4%;
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .motto__body {
    flex-direction: column;
  }
}

.motto__image {
  width: 46%;
  max-width: 574px;
}
@media screen and (max-width: 768px) {
  .motto__image {
    width: 100%;
  }
}

.motto__text-block {
  width: 50%;
  display: flex;
  flex-direction: column;
  row-gap: 50px;
}
@media screen and (max-width: 768px) {
  .motto__text-block {
    width: 100%;
    margin-top: 50px;
  }
}

.motto__heading {
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  --min-size: 24;
  --max-size: 40;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2.2;
  font-weight: 700;
}

.motto__text {
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  --min-size: 16;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2;
}

.information__table {
  margin-top: 50px;
  border-spacing: 0 10px; /* 横方向0、縦方向10pxのスペース */
  border-collapse: separate; /* デフォルトだが念のため指定 */
}

.information__table-body {
  max-width: 805px;
}

.information__table-heading {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  background: #d0ecd5;
  padding: 20px 0 20px 20px;
  max-width: 179px;
  width: 25%;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .information__table-heading {
    width: 30%;
  }
}

.information__table-data {
  --min-size: 14;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6111111111;
  padding-left: 50px;
}
@media screen and (max-width: 768px) {
  .information__table-data {
    padding-left: 16px;
  }
}

.information__map-area {
  margin-top: 50px;
  display: flex;
}
@media screen and (max-width: 768px) {
  .information__map-area {
    flex-direction: column;
  }
}

.information__map {
  position: relative;
  width: 50%;
  padding-top: 56.25%; /* 16:9の比率、必要に応じて変更 */
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .information__map {
    width: 100%;
  }
}

.information__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.information__image {
  max-width: 597px;
  width: 50%;
}
@media screen and (max-width: 768px) {
  .information__image {
    width: 100%;
  }
}

.timeline {
  position: relative;
  margin-left: 2em;
  padding-left: 6px;
  border-left: 1px solid #404040;
  margin-top: 50px;
}

.timeline__item {
  position: relative;
  padding-left: 70px;
  margin-bottom: 2em;
}

.timeline__marker {
  position: absolute;
  left: -12px;
  top: 0.8em;
  width: 10px;
  height: 10px;
  background-color: #006e36;
  border-radius: 50%;
}

.timeline__marker::after {
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  width: 60px;
  height: 1px;
  background: #949494;
  z-index: -2;
}

.timeline__year {
  font-weight: bold;
  color: #006e36;
  margin-bottom: 0.5em;
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
}

.timeline__year span {
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.3333333333;
}

.timeline__content p {
  margin: 0.3em 0;
  line-height: 1.6;
  font-size: 0.95rem;
}

.client__body {
  margin-top: 50px;
  display: flex;
  gap: 8%;
}
@media screen and (max-width: 768px) {
  .client__body {
    flex-direction: column;
  }
}

.client__list {
  width: 25.3333333333%;
  display: flex;
  flex-direction: column;
  row-gap: 18px;
}
@media screen and (max-width: 768px) {
  .client__list {
    width: 100%;
  }
}

.client__item {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2.7222222222;
  font-weight: bold;
  position: relative;
  padding-left: 1em;
  margin-left: 1em;
}

.client__item::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 1.2em;
  width: 10px;
  height: 10px;
  background-color: #006e36;
  border-radius: 50%;
}

.company-recruit__item {
  display: flex;
  background: #006e36;
  border-radius: 10px;
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .company-recruit__item {
    flex-direction: column;
  }
}

.company-recruit__item-img {
  max-width: 600px;
}

.company-recruit__item-text {
  color: #fff;
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2;
  padding: 83px 0 0 50px;
}
@media screen and (max-width: 768px) {
  .company-recruit__item-text {
    width: 100%;
    padding: 20px;
  }
}

.company-recruit__item-link {
  text-align: right;
}

.company-recruit__item-link a {
  color: #fff;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6111111111;
  text-decoration: underline;
  text-align: right;
  position: relative;
}
.company-recruit__item-link a .company-recruit__item-link a::after {
  content: ">";
  background: #fff;
  border-radius: 50%;
  color: #006e36;
  width: 50px;
  height: 50px;
  position: absolute;
  top: 50%;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.company__section {
  margin-top: 100px;
}

.sod {
  margin-top: 50px;
}

.sod__heading {
  --min-size: 24;
  --max-size: 40;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
  color: #006e36;
  font-weight: bold;
}

.sod__section {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4%;
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .sod__section {
    flex-direction: column;
  }
}

.sod__text {
  width: 59%;
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  max-width: 950px;
}
@media screen and (max-width: 768px) {
  .sod__text {
    width: 100%;
  }
}

.sod__image {
  width: 46%;
  max-width: 500px;
}
@media screen and (max-width: 768px) {
  .sod__image {
    width: 100%;
  }
}

.sod_contents {
  margin-top: 50px;
  display: flex;
  flex-direction: column;
  row-gap: 50px;
}

.sod_contents-subheading {
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
  font-weight: bold;
}

.sod_contents-text {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6111111111;
  padding-left: 2em;
  margin-top: 20px;
}

.sod__section2 {
  margin-top: 50px;
  align-items: baseline;
}

.sod__lineup-text {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6111111111;
  width: 54%;
  max-width: 650px;
}
@media screen and (max-width: 768px) {
  .sod__lineup-text {
    width: 100%;
  }
}

.sod__lineup-link {
  margin-top: 14px;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  color: #404040;
}

.sod__lineup-link a {
  color: #006e36;
  text-decoration: underline;
}

.line-bold {
  background: url(../img/sod/line-bold.jpg);
  width: 100%;
  height: 10px;
  margin: 50px 0;
}

.sod__item-inner {
  padding-bottom: 50px;
  border-bottom: dotted 2px #006e36;
}

.sod__subtitle {
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  --min-size: 32;
  --max-size: 40;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2.2;
  font-weight: 700;
}

.sod__subtitle span {
  --min-size: 28;
  --max-size: 34;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.5882352941;
  font-weight: 700;
}

.sod__subtitle-en {
  text-align: right;
}
@media screen and (max-width: 768px) {
  .sod__subtitle-en {
    text-align: left;
  }
}

.sod__item-image {
  margin-top: 50px;
}

.sod__caption {
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  color: #006e36;
  margin-top: 30px;
  font-weight: bold;
}

.sod__item-text {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  margin-top: 20px;
}

.sod__item-heading {
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2.1666666667;
  padding-left: 4%;
  padding-top: 50px;
}

.sod__item-size {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  font-weight: bold;
  text-align: right;
  margin-top: 30px;
}

.sod__item-caution {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  color: #de312f;
  margin-top: 50px;
}

.sod__other {
  display: flex;
  flex-wrap: wrap;
  gap: 2%;
}

.sod__other-item {
  width: 48%;
  max-width: 585px;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  .sod__other-item {
    width: 100%;
  }
}

.sod__other-item-heading {
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.7916666667;
  padding-top: 30px;
}

.sod__other-item-text {
  flex: 1;
}

.sod__gallery {
  display: grid;
  grid-template-columns: 60% 40%;
  grid-template-rows: auto auto;
  grid-column-gap: 16px;
  grid-row-gap: 20px;
  margin-top: 50px;

  @media (max-width: 768px) {
      display: flex;
      flex-direction: column;
      gap: 20px;
}}
.sod__gallery img {
  width: 100%;
  height: auto;
  object-fit: cover;
}


.sod__gallery-image1 {
  grid-area: 1/1/3/2;
  max-width: 720px;
  @media (max-width: 768px) {
    max-width: 100%;
  }
}

.sod__gallery-image2 {
  grid-area: 1/2/2/3;
  max-width: 464px;
  @media (max-width: 768px) {
    max-width: 100%;
  }
}

.sod__gallery-image3 {
  grid-area: 2/2/3/3;
  max-width: 464px;
  @media (max-width: 768px) {
    max-width: 100%;
  }
}

.sod__staff-heading {
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  --min-size: 28;
  --max-size: 40;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2;
  color: #006e36;
  margin-top: 50px;
}

.sod__logo {
  max-width: 100%;
  margin-right: 0;
  width: 100%;
  text-align: end;
}
@media screen and (max-width: 768px) {
  .sod__logo {
    margin-top: 20px;
  }
}

.sod__logo > img {
  max-width: 250px;
}

body {
  counter-reset: number 0;
}

.manage__header {
  margin-top: 0;
}

.manage-reason {
  margin-top: 30px;
}

.manage-reason__item {
  display: flex;
  gap: 2.5%;
  border-top: dotted 3px #ece2d0;
  padding: 30px 0;
}

.manage-reason__item::before {
  counter-increment: number 1;
  content: counter(number) ".";
  font-size: 124px;
  letter-spacing: 0;
  line-height: 1.1612903226;
  color: #ece2d0;
  font-family: YuMincho, "Hiragino Mincho ProN", serif;
  font-style: italic;
}
@media screen and (max-width: 768px) {
  .manage-reason__item::before {
    font-size: 60px;
  }
}

.manage-reason__item-heading {
  color: #006e36;
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  font-weight: bold;
}

.manage-reason__item-text {
  color: #191716;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6111111111;
  margin-top: 20px;
}

.manage-reason__text {
  color: #191716;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  margin-top: 30px;
  padding-top: 30px;
  border-top: dotted 3px #ece2d0;
}

.manage-kanriview__section {
  max-width: 1200px;
  margin-top: 100px;
}

.manage-kanriview__heading-wrapper {
  max-width: 1200px;
}

.manage-kanriview__heading {
  color: #191716;
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  position: relative;
  display: inline-block;
  margin-top: 50px;
  font-weight: bold;
}

.manage-kanriview__heading::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -24px;
  width: 18px;
  height: 6px;
  background: url(../../assets/img/construct/aside-direction.svg) no-repeat;
}

.manage-kanriview__swiper {
  margin-top: 30px;
}

.manage__link {
  color: #fff;
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
  text-align: center;
  max-width: 660px;
  width: 100%;
  background: #006e36;
  padding: 20px 0;
  border-radius: 10px;
  margin: 0 auto;
  display: inline-block;
  margin-top: 30px;
  display: block;
}

.manage-kanriview__contents {
  max-width: 1200px;
  border-bottom: 1px solid #DBDBDB;
  padding-bottom: 30px;
  margin-top: 50px;
}

.manage-kanriview__contents-heading {
  color: #fff;
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
  color: #191716;
  font-weight: bold;
}

.manage-kanriview__contents-text {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6111111111;
  color: #191716;
}

.quality__heading {
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  color: #006e36;
  font-weight: bold;
}

.quality__section {
  margin-top: 100px;
}

.quality__detail-heading {
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
  color: #191716;
  font-weight: bold;
  margin-top: 50px;
}
.quality__detail-lead{
  font-weight: bold;
  margin-block: 30px 20px;
}

.quality__detail-text {
  color: #191716;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  margin-top: 20px;
  max-width: 1150px;
  margin-left: 50px;
}

.quality__detail-link {
  color: #006e36;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
  margin-top: 20px;
  text-decoration: underline;
  font-weight: 300;
  margin-left: 50px;
}

.quality__detail-image {
  margin-top: 100px;
}

.quality__name {
  color: #006e36;
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2;
  text-align: right;
  font-weight: bold;
}
.quality__nav-item a{
  background-color: #D0ECD5;
    padding-block: 5px;
    padding-inline: 8px;
    border-radius: 20px;
}

.managing-contractor__steps {
  display: flex;
  flex-direction: column;
  row-gap: 85px;
  margin-top: 50px;
}

.managing-contractor__step {
  display: flex;
  align-items: center;
  gap: 4%;
  position: relative;
}

.managing-contractor__step::after {
  content: "";
  background: url(../../assets/img/managing-contractor/direction.svg) no-repeat;
  width: 25px;
  height: 25px;
  position: absolute;
  bottom: -58px;
  left: 32px;
}

.managing-contractor__steps .managing-contractor__step:last-child::after {
  background: none;
}

.managing-contractor__image {
  width: 95px;
  height: 95px;
}

@media screen and (max-width: 768px) {
  .managing-contractor__text-block {
    width: 80%;
  }
}

.managing-contractor__step-title {
  color: #006e36;
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2;
  font-weight: bold;
}

.managing-contractor__step-description {
  color: #191716;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6111111111;
  max-width: 1152px;
}

.managing-contractor__footer-image {
  margin-top: 100px;
}

.managing-contractor__worries-section {
  margin-top: 100px;
}

.managing-contractor__worries-heading {
  color: #191716;
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2;
  font-weight: bold;
  text-align: center;
}

.managing-contractor__worries-inner {
  margin-top: 30px;
  display: flex;
  gap: 8%;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .managing-contractor__worries-inner {
    flex-direction: column;
    row-gap: 30px;
  }
}

.managing-contractor__worries-card {
  max-width: 550px;
  width: 50%;
  background: #fff;
  box-shadow: 5px 5px 11px rgba(0, 0, 0, 0.3019607843);
  border-radius: 10px;
  padding: 10px;
}
@media screen and (max-width: 768px) {
  .managing-contractor__worries-card {
    width: 100%;
  }
}

.managing-contractor__worries-card-inner {
  background: linear-gradient(180deg, rgba(0, 110, 54, 0) 0%, #006E36 100%), url(../../assets/img/managing-contractor/img02.jpg) no-repeat center center;
  max-width: 530px;
  margin: 0 auto;
}

.managing-contractor__worries-card-inner:nth-child(2) {
  background: linear-gradient(180deg, rgba(0, 110, 54, 0) 0%, #006E36 100%), url(../../assets/img/managing-contractor/img03.jpg) no-repeat center center;
}

.managing-contractor__worries-card-texts {
  text-align: center;
  bottom: 0;
  padding-top: 124px;
  padding-bottom: 10px;
  position: relative;
}

.managing-contractor__worries-card-texts::after {
  content: "＞";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  border: solid 1px #fff;
  position: absolute;
  right: 10px;
  bottom: 12%;
}

.managing-contractor__worries-card-title {
  color: #fff;
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
}

.managing-contractor__worries-card-subtitle {
  color: #fff;
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6;
}

.managing-contractor__worries-card-subtitle {
  position: relative;
  display: inline-block;
  padding: 6px; /* 文字と線の間隔調整 */
  font-size: 1.4rem;
  text-align: center;
}

.managing-contractor__worries-card-subtitle::before,
.managing-contractor__worries-card-subtitle::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 99px;
  height: 1px;
  background-color: #fff;
}

.managing-contractor__worries-card-subtitle::before {
  left: 0;
  transform: translate(-100%, -50%);
}

.managing-contractor__worries-card-subtitle::after {
  right: 0;
  transform: translate(100%, -50%);
}

.managing-contractor__worries-card-description {
  color: #191716;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.6111111111;
  padding: 20px;
}

.managing-contractor__performance-lead {
  color: #191716;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2.45;
  font-weight: bold;
}

.managing-contractor__performance-list {
  display: flex;
  flex-wrap: wrap;
  gap: 30px 3%;
  margin-top: 30px;
}

.managing-contractor__performance-item {
  border: 1px solid #404040;
  padding: 30px 3%;
  width: 50%;
  max-width: 580px;
}
@media screen and (max-width: 768px) {
  .managing-contractor__performance-item {
    width: 100%;
    max-width: 100%;
  }
}

.managing-contractor__performance-course {
  color: #191716;
  --min-size: 20;
  --max-size: 22;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2.2272727273;
  font-weight: bold;
}

.managing-contractor__performance-details {
  margin-top: 20px;
}

.managing-contractor__performance-info {
  color: #191716;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2;
}

.managing-contractor__performance-note-wrapper {
  margin-top: 50px;
}

.managing-contractor__performance-note {
  color: #191716;
  --min-size: 20;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2.0416666667;
  font-weight: bold;
}

.managing-contractor__performance-text {
  margin-top: 20px;
}

.managing-contractor__link {
  font-weight: bold;
  text-decoration: underline;
}

.managing-contractor__performance-label {
  color: #191716;
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.7777777778;
}

.managing-contractor__performance-list-text {
  color: #191716;
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 2;
}

.manage-kanriview__item-wide {
  margin-top: 30px;
}

.manage-kanriview__item {
  margin-top: 70px;
}

.garden_sod-header {
  margin-top: 0;
  margin-bottom: 60px;
}

.garden_sod-detail + .garden_sod-flexWrap {
  margin-top: 50px;
}

.garden_sod-textLink {
  color: #006e36;
  text-decoration: underline;
  border-bottom: 1px solid #006e36;
}

.garden_sod-detailText {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
}

.garden_sod-detailNotice {
  display: block;
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  color: #949494;
  margin-top: 32px;
}

.garden_sod-notice {
  display: block;
  --min-size: 12;
  --max-size: 14;
  font-size: var(--clamp-size);
  line-height: 1.2142857143;
  color: #949494;
  margin-top: 24px;
}
.garden_sod-notice + .garden_sod-flexWrap {
  margin-top: 50px;
}

.garden_sod-sectionSubTitle {
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  color: #fff;
  background: #006e36;
  padding-block: 21px 19px;
  padding-left: 20px;
  margin-block: 100px 50px;
}
@media screen and (max-width: 768px) {
  .garden_sod-sectionSubTitle {
    padding-inline: 11px;
    margin-block: 50px 32px;
  }
}

.garden_sod-flexWrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 50px;
}
.garden_sod-flexWrap + .garden_sod-flexWrap {
  margin-top: 50px;
}
.garden_sod-flexWrap + .garden_sod-detail {
  margin-top: 50px;
}
@media screen and (max-width: 992px) {
  .garden_sod-flexWrap {
    flex-direction: column;
    gap: 24px;
  }
}

.garden_sod-flexImg {
  aspect-ratio: 550/350;
  width: 100%;
  max-width: 550px;
  height: fit-content;
}
@media screen and (max-width: 768px) {
  .garden_sod-flexImg {
    max-width: 100%;
  }
}

.garden_sod-flexTextArea {
  max-width: 600px;
  width: 50%;
}
@media screen and (max-width: 992px) {
  .garden_sod-flexTextArea {
    width: 78%;
  }
}
@media screen and (max-width: 768px) {
  .garden_sod-flexTextArea {
    width: 100%;
    max-width: 100%;
  }
}

.garden_sod-flexText {
  --min-size: 16;
  --max-size: 18;
  font-size: var(--clamp-size);
  line-height: 1.2222222222;
}

.garden_sod-text {
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
}

.garden_sod-colImgWrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px;
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .garden_sod-colImgWrap {
    justify-items: center;
    grid-template-columns: repeat(1, 1fr);
    gap: 24px;
  }
}

.garden_sod-colImgBox {
  width: cla;
}

.garden_sod-colImg {
  aspect-ratio: 390/273;
  width: 100%;
  max-width: 390px;
  height: fit-content;
}
@media screen and (max-width: 768px) {
  .garden_sod-colImg {
    max-width: 100%;
  }
}

.garden_sod-colImgCapture {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
}

.garden_mente-sectionSubTitle {
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  color: #fff;
  background: #006e36;
  padding-block: 21px 19px;
  padding-left: 20px;
  margin-block: 60px 50px;
}
@media screen and (max-width: 768px) {
  .garden_mente-sectionSubTitle {
    padding-inline: 11px;
    margin-block: 50px 32px;
  }
}

.garden_menteText {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
}

.garden_mente-link {
  color: #006e36;
  border-bottom: 1px solid #006e36;
}

.garden_menteNote {
  display: inline-block;
  --min-size: 13;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  color: #949494;
  margin-top: 24px;
}

.garden_mente-sectionSubTitle {
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  color: #fff;
  background: #006e36;
  padding-block: 21px 19px;
  padding-left: 20px;
  margin-block: 60px 50px;
}
@media screen and (max-width: 768px) {
  .garden_mente-sectionSubTitle {
    padding-inline: 11px;
    margin-block: 50px 32px;
  }
}

.sod_faq-wrap {
  margin-top: 57px;
}

.sod_faq-details{
  margin-top: -87px;
  padding-top: 87px;
}
.sod_faq-details + .sod_faq-details {
  margin-top: -30px;
}
@media screen and (max-width: 768px) {
  .sod_faq-details{
    padding-top: 0;
  }
  .sod_faq-details + .sod_faq-details {
    margin-top: 40px;
  }
}

.sod_faq-summary {
  /* display: list-item;以外を指定してデフォルトの三角形アイコンを消します */
  display: block;
}

.sod_faq-summary::-webkit-details-marker {
  /* Safariで表示されるデフォルトの三角形アイコンを消します */
  display: none;
}

.sod_faq-summaryInner {
  cursor: pointer;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  position: relative;
  padding-block: 16px;
  padding-inline: 95px 24px;
  font-weight: bold;
  color: #fff;
  background-color: #006e36;
  --min-size: 16;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
}
@media screen and (max-width: 768px) {
  .sod_faq-summaryInner {
    padding-inline: 63px 24px;
  }
}
@media screen and (max-width: 576px) {
  .sod_faq-summaryInner {
    padding-inline: 57px 24px;
  }
}
@media screen and (max-width: 428px) {
  .sod_faq-summaryInner {
    padding-inline: 48px 24px;
  }
}

.sod_faq-Q {
  position: absolute;
  top: 16px;
  left: 20px;
}
@media screen and (max-width: 768px) {
  .sod_faq-Q {
    left: 10px;
  }
}

.sod_faq-icon {
  display: block;
  position: relative;
  width: 20px;
  margin-left: 6px;
  flex-shrink: 0;
  transform-origin: center 43%;
  transition: transform 0.4s;
}
@media screen and (max-width: 768px) {
  .sod_faq-icon {
    width: 10px;
  }
}

/* is-openedクラスが付与されたときのスタイル */
.sod_faq-details.is-opened .sod_faq-icon::before {
  transform: rotate(90deg);
  display: none;
}
.sod_faq-details.is-opened .sod_faq-icon ::after {
  transform: rotate(-90deg);
}

/* アイコンのバーのスタイル */
.sod_faq-icon::before,
.sod_faq-icon::after {
  content: "";
  position: absolute;
  display: block;
  width: 30px;
  height: 3px;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .sod_faq-icon::before,
  .sod_faq-icon::after {
    width: 20px;
    height: 2px;
  }
}

.sod_faq-icon::before {
  left: 0;
  transform: rotate(90deg);
}

.isod_faq-con::after {
  right: 0;
  transform: rotate(-90deg);
}

/* --------アコーディオンの中身のスタイル-------- */
.sod_faq-content {
  overflow: hidden;
  background-color: #fff;
}

.sod_faq-contentInner {
  padding: 20px 50px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  border: 1px solid #707070;
}
@media screen and (max-width: 768px) {
  .sod_faq-contentInner {
    padding: 16px;
  }
}
.sod_faq-contentText{
  line-height: 1.5;
}

.sodInfo-text {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
  letter-spacing: 0px;
  margin-top: 50px;
}

.sodInfo-cardCotainer {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  margin-top: 112px;
}
@media screen and (max-width: 1200px) {
  .sodInfo-cardCotainer {
    justify-items: center;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 576px) {
  .sodInfo-cardCotainer {
    margin-top: 62px;
    justify-items: center;
    grid-template-columns: repeat(1, 1fr);
  }
}

.sodInfo-card {
  max-width: 320px;
}
@media screen and (max-width: 1200px) {
  .sodInfo-card {
    max-width: 400px;
  }
}
@media screen and (max-width: 768px) {
  .sodInfo-card {
    max-width: 100%;
  }
}
@media (hover: hover) and (pointer: fine) {
  .sodInfo-card:hover .sodInfo-cardImg {
    transition: transform 0.2s;
    transform: scale(0.95, 0.95);
  }
}

.sodInfo-cardImg {
  aspect-ratio: 350/250;
  width: 100%;
  object-fit: cover;
  height: fit-content;
  max-width: 350px;
}
@media screen and (max-width: 1200px) {
  .sodInfo-cardImg {
    max-width: 400px;
  }
}
@media screen and (max-width: 768px) {
  .sodInfo-cardImg {
    max-width: 100%;
  }
}

.sodInfo-cardLinkArea {
  padding-top: 20px;
}

.sodInfo-cardLink {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 20px;
}

.sodInfo-cardLinkText {
  color: #006e36;
}
.sodInfo-cardLinkText::after {
  background-color: #006e36 !important;
}

.sodInfo-cardButton {
  border: solid 1px #006e36;
}
.sodInfo-cardButton::before {
  border-top: 1px solid #006e36;
  border-right: 1px solid #006e36;
}

.turfgrass-header {
  margin-top: 0;
}

.turfgrass-section {
  margin-top: 100px;
}
@media screen and (max-width: 768px) {
  .turfgrass-section {
    margin-top: 50px;
  }
}

.turfgrass-sectionTop .turfgrass-Text {
  margin-top: 57px;
}

.turfgrass-colorNum01 {
  background-color: #ECE2D0;
}

.turfgrass-colorNum02 {
  background-color: #DAD0EC;
}

.turfgrass-colorNum03 {
  background-color: #D0E1EC;
}

.turfgrass-colorNum04 {
  background-color: #ECD9D0;
}

.turfgrass-colorNum05 {
  background-color: #D0EBEC;
}

.turfgrass-colorNum06 {
  background-color: #D0ECD5;
}

.tableNum01 {
  border: 1px solid #ECE2D0;
}

.tableNum02 {
  border: 1px solid #DAD0EC;
}

.tableNum03 {
  border: 1px solid #D0E1EC;
}

.tableNum04 {
  border: 1px solid #ECD9D0;
}

.tableNum05 {
  border: 1px solid #D0EBEC;
}

.tableNum06 {
  border: 1px solid #D0ECD5;
}

.turfgrass-Num01 {
  padding-block: 100px 20px;
  padding-inline: 20px;
}

.turfgrass-sectionSubTitle {
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  width: 100%;
  text-align: center;
  padding-block: 21px 22px;
}

.turfgrass-Text {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
}

.turfgrass-readText {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  --min-size: 24;
  --max-size: 40;
  font-size: var(--clamp-size);
  line-height: 2.2;
}

.turfgrass-tableWrapper td, .turfgrass-tableWrapper th {
  text-align: center;
  vertical-align: middle;
  border-collapse: collapse;
}
.turfgrass-tableWrapper .tableNum01 td, .turfgrass-tableWrapper .tableNum01 th {
  border: 1px solid #ECE2D0;
}
.turfgrass-tableWrapper .tableNum01 .turfgrass-tableDetail {
  padding-inline: 20px;
  color: #191716;
}
.turfgrass-tableWrapper .tableNum01 .turfgrass-tableColHead {
  height: 210px;
}
.turfgrass-tableWrapper .tableNum01 .turfgrass-tableColHead.turfgrass-table3Col {
  width: 20%;
}
.turfgrass-tableWrapper .tableNum01 .turfgrass-table3Col {
  width: 40%;
}
.turfgrass-tableWrapper .tableNum02 td, .turfgrass-tableWrapper .tableNum02 th {
  border: 1px solid #DAD0EC;
}
.turfgrass-tableWrapper .tableNum02 .turfgrass-tableColHead {
  height: 118px;
}
.turfgrass-tableWrapper .tableNum02 .turfgrass-tableColHead.turfgrass-table3Col {
  width: 25%;
}
.turfgrass-tableWrapper .tableNum02 .turfgrass-table3Col {
  width: 35%;
}
.turfgrass-tableWrapper .tableNum02 .turfgrass-tableDetail {
  padding-inline: 18px;
}
.turfgrass-tableWrapper .tableNum03 td, .turfgrass-tableWrapper .tableNum03 th {
  border: 1px solid #D0E1EC;
}
.turfgrass-tableWrapper .tableNum03 .turfgrass-tableColHead {
  width: 30%;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum03 .turfgrass-tableColHead {
    padding-block: 12px;
    width: 100%;
  }
}
.turfgrass-tableWrapper .tableNum03 .turfgrass-tableRowList {
  padding-block: 30px;
  padding-inline: 30px;
}
.turfgrass-tableWrapper .tableNum03 .turfgrass-tableRowList + .turfgrass-tableRowList {
  border-top: 1px solid #D0E1EC;
}
.turfgrass-tableWrapper .tableNum03 .turfgrass-tableRowList .turfgrass-Text {
  text-align: left;
  padding: 0;
}
.turfgrass-tableWrapper .tableNum03 .turfgrass-tableRowList .turfgrass-Text b {
  display: block;
  text-align: center;
}
.turfgrass-tableWrapper .tableNum03 .turfgrass-tableRowList .turfgrass-Text + .turfgrass-Text {
  margin-top: 23px;
}
.turfgrass-tableWrapper .tableNum04 td, .turfgrass-tableWrapper .tableNum04 th {
  border: 1px solid #ECD9D0;
}
.turfgrass-tableWrapper .tableNum04 .turfgrass-tableColHead {
  width: 30%;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum04 .turfgrass-tableColHead {
    width: 100%;
    padding-block: 12px;
  }
}
.turfgrass-tableWrapper .tableNum04 .turfgrass-tableRowList {
  padding-block: 30px;
  padding-inline: 30px;
}
.turfgrass-tableWrapper .tableNum04 .turfgrass-tableRowList + .turfgrass-tableRowList {
  border-top: 1px solid #ECD9D0;
}
.turfgrass-tableWrapper .tableNum04 .turfgrass-tableRowList .turfgrass-Text {
  text-align: left;
  padding: 0;
}
.turfgrass-tableWrapper .tableNum04 .turfgrass-tableRowList .turfgrass-Text b {
  display: block;
  text-align: center;
}
.turfgrass-tableWrapper .tableNum04 .turfgrass-tableRowList .turfgrass-Text + .turfgrass-Text {
  margin-top: 23px;
}
.turfgrass-tableWrapper .tableNum05 td, .turfgrass-tableWrapper .tableNum05 th {
  border: 1px solid #D0EBEC;
}
.turfgrass-tableWrapper .tableNum05 .tableNum05_Col1 {
  width: 17%;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .tableNum05_Col1 {
    width: 100%;
  }
}
.turfgrass-tableWrapper .tableNum05 .tableNum05_Col2 {
  width: 44%;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .tableNum05_Col2 {
    width: 100%;
  }
}
.turfgrass-tableWrapper .tableNum05 .tableNum05_Col3 {
  width: 14%;
  height: 145px;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .tableNum05_Col3 {
    width: 100%;
    height: auto;
  }
}
.turfgrass-tableWrapper .tableNum05 .tableNum05_Col4 {
  width: 25%;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .tableNum05_Col4 {
    width: 100%;
  }
}
.turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowName {
  display: flex;
  flex-direction: column;
  align-self: center;
  padding-inline: 20px;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowName {
    padding-block: 16px;
  }
}
.turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowNameText {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
  font-weight: bold;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowNameText {
    text-align: center;
  }
}
.turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowNameNotice {
  display: inline-block;
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  padding-top: 14px;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowNameNotice {
    text-align: center;
  }
}
.turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowImgBox {
  padding-block: 20px 47px;
  padding-inline: 20px;
  border-left: 1px solid #D0EBEC;
}
.turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowImg {
  aspect-ratio: 450/315;
  width: 100%;
  max-width: 450px;
  height: fit-content;
  object-fit: cover;
}
.turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowTextHead {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
  font-weight: bold;
  align-self: center;
  padding-inline: 8px;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowTextHead {
    padding-block: 16px;
  }
}
.turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowTextDetail {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
  padding-inline: 8px;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowTextDetail {
    padding-block: 16px;
  }
}
.turfgrass-tableWrapper .tableNum05 .turfgrass-tableRowTextDetail span {
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  letter-spacing: 0px;
  color: #DE312F;
}
.turfgrass-tableWrapper .tableNum06 td, .turfgrass-tableWrapper .tableNum06 th {
  border: 1px solid #D0ECD5;
}
.turfgrass-tableWrapper .turfgrass-Text {
  padding-block: 50px 55px;
  text-align: center;
  padding-inline: 16px;
}
.turfgrass-tableWrapper .turfgrass-Text b {
  font-weight: bold;
}
.turfgrass-tableWrapper .turfgrass-tableColHead {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
  font-weight: bold;
}
.turfgrass-tableWrapper .turfgrass-tableRowHead {
  font-weight: bold;
  padding-block: 32px 31px;
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.2;
}
.turfgrass-tableWrapper .turfgrass-tableDetail {
  --min-size: 14;
  --max-size: 18;
  font-size: var(--clamp-size);
  line-height: 1.2222222222;
}
@media screen and (max-width: 768px) {
  .turfgrass-tableWrapper .turfgrass-flexSp {
    display: flex;
    flex-direction: column;
  }
}

.turfgrass-flexBox {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: 42px;
}

.turfgrass-flexBoxImg {
  aspect-ratio: 570/389;
  width: 100%;
  max-width: 570px;
  object-fit: cover;
  height: fit-content;
}

.turfgrass-sup {
  font-size: 10px;
  color: #DE312F;
  vertical-align: super;
}

.turfgrass-body {
  border: 1px solid #D0ECD5;
  padding-block: 50px 86px;
  padding-inline: 20px;
}

.turfgrass-supNotice {
  display: inline-block;
  margin-top: 24px;
  --min-size: 13;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  color: #DE312F;
}

.sdgs__main-title {
  color: #006e36;
  --min-size: 32;
  --max-size: 40;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
  font-weight: bold;
  text-align: center;
}

.sdgs__lead {
  margin-top: 50px;
}

.sdgs__section {
  margin-top: 50px;
}

.sdgs__section-title {
  color: #191716;
  --min-size: 18;
  --max-size: 24;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
  font-weight: bold;
}

.sdgs__section-content {
  margin-top: 20px;
}

.sdgs__section-inner {
  display: flex;
  gap: 16px;
}
@media screen and (max-width: 768px) {
  .sdgs__section-inner {
    flex-direction: column;
  }
}

.sdgs__image {
  max-width: 550px;
  width: 36%;
}

.sdgs__section-subtitle {
  margin-top: 1rem;
}

.sdgs__list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 1rem;
}

.sdgs__pdf {
  margin-top: 50px;
}

.sdgs__pdf-link {
  color: #006e36;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.3;
  font-weight: bold;
  text-decoration: underline;
}

.sdgs__pdf-link span {
  color: #006e36;
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  letter-spacing: 0;
  line-height: 1.625;
  font-weight: bold;
}

.recruit__section {
  margin-top: 100px;
  font-size: 20px;
  letter-spacing: 0;
  line-height: 1.6;
}

.sns__section {
  margin-top: 100px;
  margin-bottom: 100px;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  color: #191716;
  line-height: 1.6;
}

.sns__section-heading {
  font-weight: bold;
  margin-top: 2rem;
}

.sns__section-info {
  margin-top: 2rem;
}

.p {
  display: inline-block;
}

.contact__section {
  max-width: 1000px;
  margin: 0 auto;
  margin-top: 100px;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  color: black;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .contact__section {
    margin-top: 50px;
  }
}

.contact__required {
  display: inline-block;
  color: #de312f;
  border: 1px solid #de312f;
  font-weight: bold;
  margin-left: 10px;
  font-size: 14px;
  line-height: 1;
  padding: 2px 4px;
}

.contact__item {
  margin-top: 50px;
}

.contact__question {
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  color: #191716;
  line-height: 1.6;
  font-weight: bold;
}

.contact__answer {
  border: 1px solid #949494;
  border-radius: 5px;
  height: 79px;
  margin-top: 20px;
  width: 100%;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  font-weight: 200;
  padding-left: 20px;
}

.contact__section-heading {
  --min-size: 28;
  --max-size: 30;
  font-size: var(--clamp-size);
  line-height: 1.6;
  border-bottom: 1px solid #191716;
  padding-bottom: 10px;
  display: block;
}

.contact__section-info {
  margin-top: 1rem;
}

.contact__privacypolicy {
  margin-top: 50px;
}

.contact__privacypolicy-text {
  border: 1px solid #949494;
  padding: 20px 40px 20px 20px;
  overflow-y: scroll;
  max-height: 160px;
  margin-top: 30px;
  --min-size: 12;
  --max-size: 14;
  font-size: var(--clamp-size);
}

.contact__privacypolicy-agree {
  margin-top: 30px;
  text-align: center;
  display: block;
}

.wpcf7-form input[type=submit] {
  width: 100%;
  max-width: 240px;
  display: block;
  color: #fff;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  line-height: 1.6;
  background: #006e36;
  text-align: center;
  margin: 0 auto;
  padding: 17px 0;
  margin-top: 50px;
}

.contact__answer-textarea {
  height: 150px;
  border: 1px solid #949494;
  border-radius: 5px;
  margin-top: 20px;
  width: 100%;
  --min-size: 18;
  --max-size: 20;
  font-size: var(--clamp-size);
  font-weight: 200;
  padding-left: 20px;
  padding-top: 20px;
}

.wpcf7-form input[type=checkbox] {
  color: #949494;
  border: solid 1px;
  width: 16px;
  height: 16px;
  vertical-align: baseline;
  margin: 0;
  padding: 0;
}


.news-Wrap {
  padding-top: 111px;
  max-width: 1200px;
  width: 100%;
  margin-inline: auto;
  padding-bottom: 100px;
}
@media screen and (max-width: 1200px) {
  .news-Wrap {
    padding-top: 80px;
  }
}

.news-LinkBox {
  display: block;
  border-top: 1px solid #AAA;
}

.news-Wrap .news-LinkBox:last-of-type {
  border-bottom: 1px solid #AAA;
}

.news-list {
  position: relative;
  display: flex;
  gap: 22px;
  padding-block: 31px;
}
@media screen and (max-width: 768px) {
  .news-list {
    padding-right: 10px;
  }
}
.news-list::after {
  content: "";
  position: absolute;
  top: 43%;
  right: 0;
  height: 12px;
  width: 12px;
  border-top: 1px solid #006e36;
  border-right: 1px solid #006e36;
  transform: translateY(0%) rotate(45deg);
}

.news-Day {
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.1875;
  color: #006e36;
}

.news-Detail {
  --min-size: 14;
  --max-size: 16;
  font-size: var(--clamp-size);
  line-height: 1.1875;
  color: #191716;
}

.single_news-sectionSubTitle {
  display: flex;
  justify-content: space-between;
  align-items: center;
  --min-size: 24;
  --max-size: 30;
  font-size: var(--clamp-size);
  font-weight: bold;
  line-height: 1.2;
  color: #fff;
  background: #006e36;
  padding-block: 21px 19px;
  padding-inline: 20px;
  margin-block: 50px 30px;
}

.single_news-sectionSubTitleTime {
  --min-size: 16;
  --max-size: 20;
  font-size: var(--clamp-size);
  font-weight: 400;
}

.news-pagination {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  margin-top: 36px;
}
.news-pagination .page-numbers {
  font-size: 20px;
}
.news-pagination .prev {
  font-size: 20px;
}
.news-pagination .news {
  font-size: 20px;
}/*# sourceMappingURL=style.css.map */

.js-accordion-text {
  display: -webkit-box;
  -webkit-line-clamp: 3; /* 表示する行数 */
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: all 0.3s ease;
}

.js-accordion-text.open {
  -webkit-line-clamp: unset;
}
.manage-kanriview__swiper {
  position: relative;
}

.manage-kanriviewSwiper {
  width: 100%;
  overflow: hidden;
}
.c-page__section{
  scroll-margin-top: 87px;
}
    /* 
フェードイン
=================================== */
.js-fade {
  opacity: 0;
  transition-duration: 1200ms;
  transition-property: opacity, transform;
  transform: translate(0, 80px);    /* 出現位置 */

}
.js-fadein {
/*要素を表示させる*/
opacity: 1;
visibility: visible;
/*元の位置に戻す*/
transform: translate(0, 0);
}

.managing-contractor__quality-text{
  margin-top: 50px;
}
.managing-contractor__quality-text a{
  color: rgb(0, 110, 54);
  text-decoration: underline;
}
.u-color-red{
  color: #de312f;
}
.u-bold{
  font-weight: bold;
}
.u-text-center{
  text-align: center;
}
.u-mt10{
  margin-top: 10px!important;
}
.u-mt25{
  margin-top: 25px!important;
}
.u-mt50{
  margin-top: 50px!important;
}