@charset "UTF-8";
/* CSS Remedy */
*,
*::before,
*::after {
  box-sizing: border-box;
  min-height: 0vw;
}

html {
  line-sizing: normal;
}

pre {
  white-space: pre-wrap;
}

hr {
  height: 0;
  overflow: visible;
  box-sizing: content-box;
}

audio,
canvas,
embed,
iframe,
object,
svg {
  display: block;
  vertical-align: middle;
  max-width: 100%;
}

audio:not([controls]) {
  display: none;
}

picture {
  display: contents;
}

source {
  display: none;
}

canvas,
img,
svg {
  height: auto;
}

audio {
  width: 100%;
}

img {
  border-style: none;
}

svg {
  overflow: hidden;
}

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

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

/*reboot*/
@media (prefers-reduced-motion: no-preference) {
  :root {
    scroll-behavior: smooth;
  }
}
body {
  margin: 0;
  font-size: 1rem;
  font-weight: 400;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

[tabindex="-1"]:focus:not(:focus-visible) {
  outline: 0 !important;
}

hr {
  margin: 1rem 0;
  color: inherit;
  background-color: currentColor;
  border: 0;
  opacity: 0.25;
}

hr:not([size]) {
  height: 1px;
}

h6,
.h6,
h5,
.h5,
h4,
.h4,
h3,
.h3,
h2,
.h2,
h1,
.h1 {
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 500;
}

ol,
ul,
dl {
  margin-top: 0;
  margin-bottom: 0;
}

ol,
ul {
  padding-left: 2rem;
}

dd {
  margin-bottom: 0;
  margin-left: 0;
}

b,
strong {
  font-weight: bolder;
}

mark,
.mark {
  padding: 0.2em;
  background-color: #fcf8e3;
}

sub,
sup {
  position: relative;
  font-size: 0.75em;
  line-height: 0;
  vertical-align: baseline;
}

/*sub {
	bottom: -0.25em;
}*/
sup {
  top: -0.5em;
}

a {
  color: #0d6efd;
  text-decoration: underline;
}

a:hover {
  color: #0a58ca;
}

a:not([href]):not([class]),
a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}

a > code {
  color: inherit;
}

kbd {
  padding: 0.2rem 0.4rem;
  font-size: 0.875em;
  color: #fff;
  background-color: #212529;
  border-radius: 0.2rem;
}

kbd kbd {
  padding: 0;
  font-size: 1em;
  font-weight: 700;
}

figure {
  margin: 0 0 1rem;
}

table {
  caption-side: bottom;
  border-collapse: collapse;
}

caption {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  color: #6c757d;
  text-align: left;
}

th {
  text-align: inherit;
  text-align: -webkit-match-parent;
}

thead,
tbody,
tfoot,
tr,
td,
th {
  border-color: inherit;
  border-style: solid;
  border-width: 0;
}

label {
  display: inline-block;
}

button {
  border-radius: 0;
}

button:focus:not(:focus-visible) {
  outline: 0;
}

input,
button,
select,
optgroup,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

button,
select {
  text-transform: none;
}

[role=button] {
  cursor: pointer;
}

select {
  word-wrap: normal;
}

[list]::-webkit-calendar-picker-indicator {
  display: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button:not(:disabled),
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled) {
  cursor: pointer;
}

::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

textarea {
  resize: vertical;
}

fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}

legend {
  float: left;
  width: 100%;
  padding: 0;
  margin-bottom: 0.5rem;
  font-size: calc(1.275rem + 0.3vw);
  line-height: inherit;
}

@media (min-width: 1200px) {
  legend {
    font-size: 1.5rem;
  }
}
legend + * {
  clear: left;
}

::-webkit-datetime-edit-fields-wrapper,
::-webkit-datetime-edit-text,
::-webkit-datetime-edit-minute,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-year-field {
  padding: 0;
}

::-webkit-inner-spin-button {
  height: auto;
}

[type=search] {
  outline-offset: -2px;
  -webkit-appearance: textfield;
}

::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-color-swatch-wrapper {
  padding: 0;
}

::file-selector-button {
  font: inherit;
}

::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button;
}

output {
  display: inline-block;
}

iframe {
  border: 0;
}

summary {
  display: list-item;
  cursor: pointer;
}

progress {
  vertical-align: baseline;
}

[hidden] {
  display: none !important;
}

/*original*/
html {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

img {
  max-width: 100%;
  vertical-align: middle;
}

table {
  border-collapse: collapse;
}

em,
i {
  font-style: normal;
}

@font-face {
  font-family: "fontello";
  src: url("../font/fontello.eot?9764789");
  src: url("../font/fontello.eot?9764789#iefix") format("embedded-opentype"), url("../font/fontello.woff?9764789") format("woff"), url("../font/fontello.ttf?9764789") format("truetype"), url("../font/fontello.svg?9764789#fontello") format("svg");
  font-weight: normal;
  font-style: normal;
}
/*$primarycolor: #0073C3;*/
/*$secondarycolor: #30A038;*/
/*---------------------------------------------------
	common
---------------------------------------------------*/
html,
body {
  height: 100%;
}

body {
  background-color: #EFEFEF;
  font-family: "dnp-shuei-mgothic-std", sans-serif;
  color: #242424;
  line-height: 2;
  letter-spacing: 0.2rem;
  font-feature-settings: "palt" 1;
}

a,
a:hover {
  text-decoration: none;
  color: #242424;
}

a:hover:not(.nansei-kankyo-logo):not(.--btn-contact):not(.mv-pickup-nav .btn) {
  color: inherit;
  opacity: 0.65;
  transition: color 0.5s, opacity 0.5s;
}

ul {
  list-style: none;
  padding-left: 0;
}

:root {
  --mp1: 1rem;
  --mp15: 1.5rem;
  --mp2: 2rem;
  --mp25: 2.5rem;
  --mp35: 3.5rem;
  --mp5: 5rem;
  --mp6: 6rem;
  --mp7: 7rem;
  --mp10: 10rem;
  --header-height: 7rem;
  --nav-height: 900px;
  --toggle-size: 60px;
  --fade-range: calc(2.5rem + ((1vw - 0.2rem) * 1));
}

[class^=container] {
  position: relative;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
@media screen and (min-width: 992px) {
  [class^=container] {
    padding-right: var(--mp25);
    padding-left: var(--mp25);
    max-width: calc(1400px + var(--mp25) * 2);
  }
}
@media screen and (max-width: 991.98px) {
  [class^=container] {
    padding-right: var(--mp15);
    padding-left: var(--mp15);
  }
}

.container_s {
  max-width: calc(1200px + var(--mp15) * 2);
}

.text-center {
  text-align: center !important;
}

.text-start {
  text-align: start !important;
}

.text-end {
  text-align: end !important;
}

.text-l {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
}

.text-m {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}

.text-s {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}

p {
  margin-top: 0;
  margin-bottom: 0.65rem;
  padding: 0;
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}

em {
  color: #30A038;
}

.icon {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  font-variant: normal;
  text-transform: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon.--mr {
  margin-right: 0.3rem;
  margin-right: clamp(0.3rem, 0.191rem + 0.55vw, 0.6rem);
}

@media screen and (min-width: 768px) {
  .br-pc {
    display: block;
  }
}
@media screen and (max-width: 575.98px) {
  .br-pc {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .br-md {
    display: none;
  }
}
@media screen and (max-width: 575.98px) {
  .br-md {
    display: block;
  }
}

/*---------------------------------------------------
	form
---------------------------------------------------*/
input,
textarea {
  font-size: 16px;
  padding: 0.5rem 1rem;
  border: none;
  width: 100%;
  background-color: #EFEFEF;
  border-radius: 0.75rem;
}

.form {
  display: grid;
  row-gap: 1.5rem;
  row-gap: clamp(1.5rem, 1.3rem + 1vw, 2.5rem);
  max-width: 992px;
  margin: 0 auto 5rem;
  margin: 0 auto calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
.form__group__label {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  line-height: 1.6;
}
.form .form-check {
  display: grid;
  row-gap: 0.75rem;
}
.form .form-check label {
  display: inline-block;
}
.form .form-check input[type=radio] {
  appearance: none;
  display: none;
  opacity: 0;
  width: 1px;
  position: absolute;
  height: 1px;
}
.form .form-check input[type=radio] + span {
  --radio-size: 1.5rem;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  cursor: pointer;
  padding: 0.5rem 1rem 0.5rem 2.75rem;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  background: #EFEFEF;
}
.form .form-check input[type=radio] + span::after, .form .form-check input[type=radio] + span::before {
  position: absolute;
  content: "";
  display: block;
  border-radius: 50%;
  top: 0;
  bottom: 0;
  margin: auto 10px auto 0;
}
.form .form-check input[type=radio] + span::before {
  width: var(--radio-size);
  height: var(--radio-size);
  background: #fff;
  border: 1px solid #999999;
  left: 9px;
}
.form .form-check input[type=radio] + span::after {
  width: calc(var(--radio-size) * 0.5);
  height: calc(var(--radio-size) * 0.5);
  background: #999999;
  left: 15px;
  opacity: 0;
}
.form .form-check input[type=radio]:checked + span::before {
  border: 1px solid #30A038;
}
.form .form-check input[type=radio]:checked + span::after {
  background: #30A038;
  opacity: 1;
}
@media screen and (min-width: 768px) {
  .form__group {
    display: grid;
    grid-template-columns: 15rem 1fr;
    column-gap: 1rem;
  }
  .form__group__label {
    text-align: end;
  }
  .form__group__label span {
    display: block;
  }
}
.form button,
.form input[type=submit] {
  margin: 0 auto;
  border: none;
  max-width: 300px;
}

/*---------------------------------------------------
	badge
---------------------------------------------------*/
.badge {
  display: inline-block;
  padding: 0.2rem 0.4rem;
  border-radius: 0.25rem;
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  font-weight: bold;
  line-height: 1;
}

/*---------------------------------------------------
	btn
---------------------------------------------------*/
.btn__block {
  display: grid;
  padding: 5rem 0;
  padding: calc(5rem + (1vw - 0.2rem) * 2) 0;
  justify-items: center;
}

.btn {
  position: relative;
  display: block;
}

[class*="--btn-icon"] {
  padding-left: var(--mp35) !important;
  padding-right: var(--mp35) !important;
}
[class*="--btn-icon"]::after {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  font-family: "fontello";
}

.--btn-icon-r::after {
  right: 1rem;
}
.--btn-icon-l::after {
  left: 1rem;
}

.--icon-arrow-down::after {
  content: "\f107";
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.--icon-arrow-next::after {
  content: "\e80d";
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.--icon-arrow-prev::after {
  content: "\e80e";
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.--icon-contact::after {
  content: "\f1d9";
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
  left: 2rem !important;
}

/*---------------------------------------------------
	parts
---------------------------------------------------*/
.--primary {
  color: white;
  background-color: #30A038;
}

.--secondarycolor {
  color: white;
  background-color: #0073C3;
}

.--accentcolor {
  background-color: #FFE619;
}

.--white {
  color: #30A038;
  background-color: white;
}

.--gray {
  color: white;
  background-color: #999999;
}

.--graylight {
  color: #242424;
  background-color: #E3E3E3;
}

.--black {
  color: white;
  background-color: #242424;
}

.--rounded {
  padding: 0.8rem 1rem;
  text-align: center;
  border-radius: 5rem;
}

.--outline {
  border: 1px solid #242424;
}

.--btn-size-m {
  min-width: 16rem;
  min-width: clamp(16rem, 16rem + (1vw - 0.2rem) * 6.5, 22.5rem);
}

.--btn-size-s {
  display: inline-block;
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  line-height: 1;
}

/*---------------------------------------------------
	typography
---------------------------------------------------*/
.cont-tit {
  --b: 2px;
  position: relative;
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
  line-height: 1.8;
  letter-spacing: 0.4rem;
  border-bottom: var(--b) solid #E3E3E3;
}
.cont-tit::before {
  position: absolute;
  left: 0;
  bottom: calc(var(--b) * -1);
  width: 4rem;
  height: inherit;
  content: "";
  border-bottom: var(--b) solid #30A038;
}

.cont-tit-secondary {
  position: relative;
  padding: 0.5rem 0 0.5rem 1.5rem;
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
  line-height: 1.8;
  border-left: 6px solid #30A038;
}

.cont-tit-tertiary {
  position: relative;
  padding-left: 2rem;
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
}
.cont-tit-tertiary::before {
  position: absolute;
  top: 0;
  left: 0;
  color: #30A038;
  content: "■";
}

.h2 {
  margin-top: var(--mp25);
  margin-bottom: 2rem;
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
}

@media screen and (min-width: 768px) {
  .lead {
    font-size: 1.125rem;
    font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
    text-align: center;
  }
}
@media screen and (max-width: 575.98px) {
  .lead {
    font-size: 1rem;
    font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  }
}

.summary {
  --summary-space: clamp(1.5rem, 1.3rem + 1vw, 2.5rem);
  padding-top: 1.5rem;
  padding-top: var(--summary-space);
  padding-bottom: 1.5rem;
  padding-bottom: var(--summary-space);
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}
@media screen and (min-width: 768px) {
  .summary {
    text-align: center;
  }
}
@media screen and (max-width: 575.98px) {
  .summary {
    letter-spacing: 0.1rem;
  }
}

.alert {
  padding: 1rem var(--mp15);
  background-color: #FFE619;
  border-radius: 0.75rem;
}
.alert h4 {
  padding-bottom: 0.6rem;
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
}

.--tit-border {
  border-bottom: 1px solid #E3E3E3;
}

/*---------------------------------------------------
	pagenation
---------------------------------------------------*/
ul.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 0.4rem;
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  color: white;
}
ul.breadcrumb li {
  color: white;
}
ul.breadcrumb li::after {
  margin-right: 0.6rem;
  margin-left: 0.6rem;
  content: ">";
}
ul.breadcrumb li:last-child::after {
  margin: 0;
  content: "";
}
ul.breadcrumb li a {
  color: white;
}

.pagenation {
  display: grid;
  justify-items: center;
  row-gap: 5rem;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
}
.pagenation__list {
  padding: 0.5rem;
  border-radius: 5rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: 0.5rem;
  background-color: white;
}
.pagenation__list a, .pagenation__list .current, .pagenation__list a:hover {
  --a-size: clamp(2rem, 1.8rem + 1vw, 3rem);
  border-radius: 50%;
  width: 2rem;
  width: var(--a-size);
  height: 2rem;
  height: var(--a-size);
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  text-align: center;
  line-height: 2rem;
  line-height: var(--a-size);
  letter-spacing: 0;
  transition: all 0.2s;
}
.pagenation__list .current, .pagenation__list a:hover {
  color: white !important;
  background-color: #0073C3;
}
.pagenation__post {
  position: relative;
  display: grid;
}
.pagenation__post a {
  padding: 1rem;
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  background-color: white;
  border-radius: 0.75rem;
}
.pagenation__post a.prev, .pagenation__post a.next {
  position: relative;
}
.pagenation__post a.prev::before, .pagenation__post a.next::before {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  font-family: "fontello";
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.pagenation__post a.prev {
  padding-left: 2.8rem;
}
.pagenation__post a.prev::before {
  left: 1rem;
  content: "\f100";
}
.pagenation__post a.next {
  padding-right: 2.8rem;
}
.pagenation__post a.next::before {
  right: 1rem;
  content: "\f101";
}
@media screen and (min-width: 992px) {
  .pagenation__post {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 20%;
  }
}
@media screen and (max-width: 991.98px) {
  .pagenation__post {
    row-gap: var(--mp15);
  }
}
.pagenation__back {
  display: grid;
  justify-items: center;
}

/*---------------------------------------------------
	responsive_scroll
---------------------------------------------------*/
.responsive_scroll {
  min-height: 8.5rem;
}
.responsive_scroll li {
  padding-bottom: 0.5rem;
}

.scroll-hint-text {
  letter-spacing: 0.1rem;
}

@media screen and (max-width: 767.98px) {
  .responsive_scroll {
    display: block;
    width: 100%;
    padding-bottom: 1rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .responsive_scroll::-webkit-scrollbar {
    height: 10px;
  }
  .responsive_scroll::-webkit-scrollbar-track {
    border-radius: 5rem;
  }
  .responsive_scroll::-webkit-scrollbar-thumb {
    background: #30A038;
    border: none;
    border-radius: 5rem;
  }
  .responsive_scroll::-webkit-scrollbar-thumb:hover {
    background: #30A038;
  }
  .responsive_scroll.--bar_white::-webkit-scrollbar-track {
    background: white;
  }
  .responsive_scroll.--bar_gray::-webkit-scrollbar-track {
    background: #E3E3E3;
  }
  .responsive_scroll li {
    white-space: nowrap;
  }
  .responsive_scroll table {
    white-space: nowrap;
  }
}
/*---------------------------------------------------
	animation
---------------------------------------------------*/
.fade {
  position: relative;
  display: block;
}

.--in_toUp,
.--in_toRight,
.--in_toLeft,
.--in_toDown {
  --in-duration: 1s;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--in-duration), visibility var(--in-duration), transform var(--in-duration);
}

.--in_toUp.scroll,
.--in_toDown.scroll {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.--in_toLeft.scroll,
.--in_toRight.scroll {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
}

.--in_toUp {
  transform: translateY(var(--fade-range));
}

.--in_toLeft {
  transform: translateX(var(--fade-range));
}

.--in_toRight {
  transform: translateX(calc(var(--fade-range) * -1));
}

.--in_toDown {
  transform: translateY(calc(var(--fade-range) * -1));
}

.--in-delay1 {
  animation-delay: 500ms;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
}

.--in-delay2 {
  animation-delay: 1s;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
}

.--in-delay3 {
  animation-delay: 1500ms !important;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
}

.--in-delay4 {
  animation-delay: 2s;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
}

/*---------------------------------------------------
	parallax
---------------------------------------------------*/
.paraslimy-body {
  position: relative;
  z-index: 1;
  perspective: 250px;
  transform: translateZ(0);
  transform-style: preserve-3d;
  overflow: hidden;
}

.paraslimy-bg {
  position: absolute;
  z-index: -1;
  top: -12.5%;
  left: -12.5%;
  right: auto;
  bottom: auto;
  width: 215%;
  height: 215%;
  min-height: 200vh;
  transform: translateZ(-250px);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
}

/*---------------------------------------------------
	footer
---------------------------------------------------*/
footer .btn.--btn-contact {
  position: relative;
  z-index: 2;
  transition: 0.3s;
  overflow: hidden;
  border-radius: 0.75rem;
  background-color: white;
}
footer .btn.--btn-contact::after {
  position: absolute;
  z-index: -1;
  content: "ContactUs";
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  font-size: 3.25rem;
  font-size: clamp(3.25rem, 1.15rem + 10.5vw, 13.75rem);
  color: #E3E3E3;
}
footer .btn.--btn-contact .tit {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
}
footer .btn.--btn-contact p {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
footer .btn.--btn-contact .icon {
  --icon-size: 2.5rem;
  width: var(--icon-size);
  height: var(--icon-size);
  text-align: center;
  line-height: var(--icon-size);
  color: #30A038;
  border-radius: 50%;
  border: 1px solid #E3E3E3;
}
footer .btn.--btn-contact::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  content: "";
  width: 100%;
  height: 100%;
  background-color: #30A038;
  transform-origin: 50% 0%;
  transform: scaleY(0);
  -webkit-transition: transform 0.3s ease;
  -moz-transition: transform 0.3s ease;
  transition: transform 0.3s ease;
}
footer .btn.--btn-contact:hover {
  color: white;
}
footer .btn.--btn-contact:hover span,
footer .btn.--btn-contact:hover i.icon {
  color: white;
}
footer .btn.--btn-contact:hover::before {
  transform-origin: 50% 100%;
  transform: scaleY(1);
}
footer .footer {
  position: relative;
  --space: calc(10rem + ((1vw - 0.2rem) * 5));
  margin-top: calc(var(--space) * -1);
  padding-top: var(--space);
  background-color: #242424;
}
footer .footer__inner {
  display: grid;
  padding-top: var(--mp25);
  padding-bottom: var(--mp25);
  color: white;
}
footer .footer__inner a {
  color: white;
}
footer .footer__company {
  display: grid;
  row-gap: 1rem;
}
footer .footer__company--logo img {
  width: 16rem;
  height: auto;
}
footer .footer__nav ul {
  display: flex;
  column-gap: 1rem;
}
footer .footer__nav ul li {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
footer .footer__nav p.copyright {
  margin: 0;
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
}
@media screen and (min-width: 992px) {
  footer .btn.--btn-contact {
    padding: var(--mp6) calc(1.5rem + (1vw - 0.2rem) * 3.5);
    width: 100%;
    height: 100%;
  }
  footer .btn.--btn-contact::after {
    top: -6rem;
    top: calc(clamp(6rem, 1.733rem + 6.89vw, 10rem) * -1);
    right: -0.4rem;
  }
  footer .btn.--btn-contact span {
    display: flex;
    justify-content: space-between;
  }
  footer .footer__inner {
    grid-template-columns: 1fr 1fr;
  }
  footer .footer__company p {
    font-size: 1rem;
    font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  }
  footer .footer__nav {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: right;
  }
  footer .footer__nav ul {
    justify-content: end;
  }
  footer .footer__nav p.copyright {
    text-align: right;
  }
}
@media screen and (max-width: 991.98px) {
  footer .btn.--btn-contact {
    padding: calc(2rem + (1vw - 0.2rem) * 4) var(--mp2);
  }
  footer .btn.--btn-contact::after {
    top: -2.5rem;
    top: calc(clamp(2.5rem, 0.936rem + 7.36vw, 5.5rem) * -1);
    right: -0.1rem;
    right: calc(clamp(0.1rem, -0.056rem + 0.74vw, 0.4rem) * -1);
  }
  footer .footer__inner {
    row-gap: var(--mp15);
  }
  footer .footer__company--logo {
    margin: 0 auto;
  }
  footer .footer__company p {
    font-size: 0.875rem;
    font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
    letter-spacing: 0.1rem;
  }
  footer .footer__nav {
    display: grid;
    row-gap: var(--mp25);
  }
  footer .footer__nav ul {
    justify-content: center;
  }
  footer .footer__nav ul li {
    letter-spacing: 0.1rem;
  }
  footer .footer__nav p.copyright {
    text-align: center;
  }
}

/*---------------------------------------------------
	header
---------------------------------------------------*/
/* common part */
.header {
  z-index: 10;
  width: 100%;
}
.header__inner {
  background-color: white;
  box-shadow: 0px 3px 6px 0px rgba(36, 36, 36, 0.25);
}
.header__inner__logo h1 a {
  display: block;
  background: url(../images/nansei-kankyo-logo.svg) center center/contain no-repeat;
}
.header__inner__logo h1 a span {
  display: none;
}

/* 992px or more */
@media screen and (min-width: 992px) {
  .header {
    position: absolute;
    top: calc(var(--header-height) * -1);
    margin: var(--header-height) auto 0;
    height: 0;
    -webkit-transition: 0.35s ease-in-out;
    -moz-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
  }
  .header__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    width: 100%;
    height: var(--header-height);
    border-top: 8px solid #0073C3;
  }
  .header__inner__logo h1 {
    padding-left: var(--mp25);
  }
  .header__inner__logo h1 a {
    --logo-w: clamp(14rem, 7.6rem + 10.33vw, 20rem);
    width: var(--logo-w);
    height: calc(var(--logo-w) * 0.147);
  }
  .header__inner nav ul {
    display: flex;
    padding-right: var(--mp25);
  }
  .header__inner nav ul li > a {
    display: block;
    padding-left: calc(0.4rem + (1vw - 0.62rem) * 1.0345);
    padding-right: calc(0.4rem + (1vw - 0.62rem) * 1.0345);
    line-height: var(--header-height);
  }
  .header__inner nav ul li .--home {
    visibility: hidden;
    display: inline-block;
    height: 0;
    width: 0;
    overflow: hidden;
    opacity: 0;
  }
  .header__inner nav ul li.lang {
    display: flex;
    align-items: center;
  }
  .header__inner nav ul li.lang a {
    font-size: 0.625rem;
    font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
    letter-spacing: 0;
    line-height: 2rem;
    border: 1px solid #E3E3E3;
    border-radius: 5rem;
  }
  .header.fixed {
    position: fixed;
    z-index: 20;
    top: 0;
    margin-top: 0;
    -webkit-transition: top 0.5s ease-in-out;
    -moz-transition: top 0.5s ease-in-out;
    transition: top 0.5s ease-in-out;
  }
  .nav-toggle,
  .pickup-nav {
    display: none;
  }
  .child_menu {
    visibility: hidden;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background-color: white;
    opacity: 0;
    transition: 0.85s top, 0.25s opacity;
    -webkit-transition: 0.85s top, 0.25s opacity;
    -moz-transition: 0.85s top, 0.25s opacity;
  }
  .child_menu__inner {
    margin: 0 auto;
    padding: var(--mp25) var(--mp15);
    max-width: 1400px;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
  }
  .child_menu__inner a {
    display: grid;
    align-items: center;
    border-right: 1px solid #E3E3E3;
  }
  .child_menu__inner a:last-child {
    border-right: none;
  }
  .child_menu__inner a i[class^=business] {
    margin: 1.5rem auto;
    width: 3.5rem;
    height: 3.5rem;
    background-repeat: no-repeat;
    background-size: contain;
  }
  .child_menu__inner a .business1 {
    background-image: url("../images/business1.svg");
  }
  .child_menu__inner a .business2 {
    background-image: url("../images/business2.svg");
  }
  .child_menu__inner a .business3 {
    background-image: url("../images/business3.svg");
  }
  .child_menu__inner a .business4 {
    background-image: url("../images/business4.svg");
  }
  .child_menu__inner a .business5 {
    background-image: url("../images/business5.svg");
  }
  .child_menu__inner a .business6 {
    background-image: url("../images/business6.svg");
  }
  .child_menu__inner a .tit {
    font-size: 0.875rem;
    font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
    text-align: center;
  }
  .child_menu__inner a span {
    display: block;
    font-size: 0.625rem;
    font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
    letter-spacing: 0;
    font-family: "futura-pt", sans-serif;
    font-weight: 300;
    letter-spacing: 0;
    color: #30A038;
  }
  .menu:hover .child_menu {
    visibility: visible;
    top: 100%;
    opacity: 1;
    box-shadow: 0 3px 6px -4px rgba(36, 36, 36, 0.5);
  }
  /* main visual */
  #mv .mvheader .header__inner {
    background-color: inherit;
    box-shadow: none;
    -webkit-transition: 0.35s ease-in-out;
    -moz-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
  }
  #mv .mvheader .header__inner__logo h1 a {
    background-image: url(../images/nansei-kankyo-logo-white.svg) !important;
  }
  #mv .mvheader .header__inner nav a,
  #mv .mvheader .header__inner span {
    color: white;
  }
  #mv .mvheader .header__inner .child_menu a .business1 {
    background-image: url("../images/business1-mv.svg");
  }
  #mv .mvheader .header__inner .child_menu a .business2 {
    background-image: url("../images/business2-mv.svg");
  }
  #mv .mvheader .header__inner .child_menu a .business3 {
    background-image: url("../images/business3-mv.svg");
  }
  #mv .mvheader .header__inner .child_menu a .business4 {
    background-image: url("../images/business4-mv.svg");
  }
  #mv .mvheader .header__inner .child_menu a .business5 {
    background-image: url("../images/business5-mv.svg");
  }
  #mv .mvheader .header__inner .child_menu a .business6 {
    background-image: url("../images/business6-mv.svg");
  }
  #mv .mvheader .header__inner .menu:hover .child_menu {
    z-index: -1;
    background-color: rgba(36, 36, 36, 0.75);
    margin-top: calc(var(--header-height) * -1);
    padding-top: var(--header-height);
  }
}
/* 991px or less */
@media screen and (max-width: 991.98px) {
  .header {
    position: fixed;
    top: 0;
    margin-top: 0;
  }
  .header__inner {
    display: grid;
    align-items: center;
    height: var(--toggle-size);
  }
  .header__inner__logo h1 {
    padding-left: var(--mp15);
  }
  .header__inner__logo h1 a {
    width: 14rem;
    height: 2.058rem;
  }
  .header__inner .nav-toggle {
    position: absolute;
    z-index: 20;
    right: 0;
    top: 0;
    width: var(--toggle-size);
    height: var(--toggle-size);
    background-color: #0073C3;
    padding: 0.5rem 14px;
  }
  .header__inner .nav-toggle div {
    position: relative;
    width: calc(var(--toggle-size) - 1rem);
    height: calc(var(--toggle-size) - 1rem);
    color: white;
  }
  .header__inner .nav-toggle div p {
    position: absolute;
    bottom: 0;
    font-size: 8px;
    line-height: 1;
    margin: 0;
    letter-spacing: 0;
  }
  .header__inner nav {
    position: absolute;
    z-index: -1;
    top: calc(var(--nav-height) * -1);
    left: 0;
    width: 100%;
    background-color: #0073C3;
    color: white;
    -webkit-transition: 0.5s ease-in-out;
    -moz-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out;
    display: grid;
    align-items: center;
    row-gap: var(--mp15);
    padding: var(--mp15) var(--mp25);
    overflow-y: auto;
  }
  .header__inner nav ul li {
    font-size: 1rem;
    font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
    border-bottom: 1px solid #E3E3E3;
  }
  .header__inner nav ul li a {
    display: block;
    line-height: 3.25rem;
    color: white;
  }
  .header__inner nav ul li a .--home {
    padding-left: 0.4rem;
  }
  .header__inner nav ul li:last-child {
    border: none;
  }
  .header__inner nav ul li.lang {
    display: inline-block;
    margin-top: 1rem;
  }
  .header__inner nav ul li.lang a {
    padding-left: 2rem;
    padding-right: 2rem;
    font-size: 0.625rem;
    font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
    letter-spacing: 0;
    line-height: 2rem;
    border: 1px solid #E3E3E3;
    border-radius: 5rem;
  }
  .header__inner nav .pickup-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: var(--mp15);
  }
  .header__inner nav .pickup-nav a.btn {
    --pt: .6rem;
    position: relative;
    display: grid;
    align-items: center;
    padding: var(--pt) calc(var(--pt) + 1rem) var(--pt) var(--pt);
    background-color: white;
    border-radius: 0.75rem;
    overflow: hidden;
  }
  .header__inner nav .pickup-nav a.btn span {
    font-size: 0.875rem;
    font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
    line-height: 1.4;
  }
  .header__inner nav .pickup-nav a.btn small {
    display: block;
    font-size: 0.625rem;
    font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
    letter-spacing: 0;
    color: #30A038;
  }
  .header__inner nav .pickup-nav a.btn::before {
    z-index: 1;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 0;
    font-family: "fontello";
    font-size: 0.875rem;
    font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
    content: "\f105";
    font-size: 1rem;
  }
  .header__inner nav .pickup-nav a.btn::after {
    position: absolute;
    top: 0;
    right: 0;
    content: "";
    width: 1rem;
    height: 100%;
    background-color: #FFE619;
  }
  .nav-toggle {
    display: block;
  }
  .nav-toggle span {
    display: block;
    position: absolute;
    left: 0;
    height: 4px;
    width: 2rem;
    background-color: white;
    -webkit-transition: 0.35s ease-in-out;
    -moz-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
  }
  .nav-toggle span:nth-child(1) {
    top: 0;
  }
  .nav-toggle span:nth-child(2) {
    top: 11px;
  }
  .nav-toggle span:nth-child(3) {
    top: 22px;
  }
  .open .nav-toggle span:nth-child(1) {
    top: 11px;
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg);
  }
  .open .nav-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  .open .nav-toggle span:nth-child(3) {
    top: 11px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg);
  }
  .open nav {
    -moz-transform: translateY(calc(var(--nav-height) + var(--toggle-size)));
    -webkit-transform: translateY(calc(var(--nav-height) + var(--toggle-size)));
    transform: translateY(calc(var(--nav-height) + var(--toggle-size)));
  }
  .child_menu {
    display: none;
    height: 0;
    overflow: hidden;
  }
}
/*---------------------------------------------------
	メインビジュアル
---------------------------------------------------*/
.nansei-kankyo-mv {
  position: relative;
  height: 100dvh;
  /*height: calc(var(--vh, 1vh) * 100);*/
  overflow: hidden;
  min-height: 50vh;
}
.nansei-kankyo-mv img {
  width: 100%;
  object-fit: cover;
  object-position: center;
}
@media screen and (min-width: 992px) {
  .nansei-kankyo-mv img {
    height: 100%;
  }
}
@media screen and (max-width: 991.98px) {
  .nansei-kankyo-mv img {
    height: calc(100dvh - var(--mp2) * 2 - 5rem);
  }
}
.nansei-kankyo-mv .mv-pickup-nav a.btn {
  position: relative;
  display: grid;
  align-items: center;
  z-index: 2;
  transition: 0.3s;
  background-color: white;
  border-radius: 0.75rem;
  overflow: hidden;
}
.nansei-kankyo-mv .mv-pickup-nav a.btn::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  content: "";
  width: 100%;
  height: 100%;
  background-color: #0073C3;
  transform-origin: 50% 0%;
  transform: scaleY(0);
  -webkit-transition: transform 0.3s ease;
  -moz-transition: transform 0.3s ease;
  transition: transform 0.3s ease;
}
.nansei-kankyo-mv .mv-pickup-nav a.btn::after {
  position: absolute;
  top: 0;
  right: 0;
  font-family: "fontello";
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  content: "\f105";
  width: 1rem;
  height: 100%;
  display: grid;
  place-items: center;
  background-color: #E3E3E3;
}
.nansei-kankyo-mv .mv-pickup-nav a.btn:hover::before {
  transform-origin: 50% 100%;
  transform: scaleY(1);
}
.nansei-kankyo-mv .mv-pickup-nav a.btn div {
  padding: 0.8rem 1rem;
}
.nansei-kankyo-mv .mv-pickup-nav a.btn div span {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  line-height: 1.4;
}
.nansei-kankyo-mv .mv-pickup-nav a.btn div small {
  display: block;
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  color: #0073C3;
}
.nansei-kankyo-mv .mv-pickup-nav a.btn div:hover {
  color: white;
}
.nansei-kankyo-mv .mv-pickup-nav a.btn div:hover small {
  color: white;
}
@media screen and (min-width: 992px) {
  .nansei-kankyo-mv .mv-pickup-nav {
    position: absolute;
    right: var(--mp25);
    bottom: var(--mp25);
    display: grid;
    row-gap: var(--mp15);
  }
  .nansei-kankyo-mv .mv-pickup-nav a.btn {
    width: 16rem;
  }
}
@media screen and (max-width: 991.98px) {
  .nansei-kankyo-mv .mv-pickup-nav {
    padding: var(--mp2);
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--mp15);
    justify-items: center;
    align-items: center;
  }
  .nansei-kankyo-mv .mv-pickup-nav a.btn {
    width: 100%;
    height: 5rem;
  }
}
@media screen and (max-width: 575.98px) {
  .nansei-kankyo-mv {
    line-height: 1.2;
  }
}

/*---------------------------------------------------
	company
---------------------------------------------------*/
.company {
  display: grid;
  row-gap: 5rem;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
}
.company__heading {
  position: relative;
  text-align: center;
  overflow: hidden;
}
@media screen and (max-width: 991.98px) {
  .company__heading {
    padding-left: var(--mp15);
    padding-right: var(--mp15);
  }
}
.company__heading::before {
  content: "Who we are";
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  font-size: 3rem;
  font-size: clamp(3rem, 1.6rem + 7vw, 10rem);
  line-height: 1;
  color: white;
  white-space: nowrap;
}
.company__heading .lead {
  margin-top: -1rem;
}

.--lang {
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  line-height: 1.6;
}
@media screen and (max-width: 991.98px) {
  .--lang {
    margin-top: -2rem;
  }
}
.--lang .lead {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.1rem + 0.75vw, 2rem);
}
.--lang .cont-tit {
  letter-spacing: 0;
}
.--lang .lang__cont main .company-prof .col,
.--lang .lang__cont main .qualified-list__inner .col .name,
.--lang .lang__cont main .qualified-list__inner .col .widgettitle,
.--lang .responsive_scroll,
.--lang p {
  font-size: 1.25rem !important;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem) !important;
}

/*****************************/
@media screen and (min-width: 992px) {
  .divide-col {
    column-gap: 2.5rem;
    column-gap: clamp(2.5rem, -5.517rem + 12.93vw, 10rem);
    grid-template-columns: 1fr 260px;
  }
}

@media screen and (min-width: 992px) {
  .divide-col,
  .lang__cont {
    position: relative;
    display: grid;
  }
}
@media screen and (max-width: 991.98px) {
  .divide-col,
  .lang__cont {
    display: grid;
    row-gap: var(--mp25);
  }
}
.divide-col main,
.lang__cont main {
  display: grid;
  row-gap: 5rem;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
}
.divide-col main .company-prof,
.lang__cont main .company-prof {
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
.divide-col main .company-prof .col,
.lang__cont main .company-prof .col {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}
.divide-col main .company-prof .col div:first-child,
.lang__cont main .company-prof .col div:first-child {
  display: grid;
  place-items: center;
  line-height: 3;
  background-color: white;
  border-radius: 0.75rem;
}
.divide-col main .company-prof .address,
.lang__cont main .company-prof .address {
  display: grid;
  padding: var(--mp35) 1.5rem;
  padding: var(--mp35) clamp(1.5rem, 1.1rem + 2vw, 3.5rem);
}
.divide-col main .company-prof .address .desc a.btn,
.lang__cont main .company-prof .address .desc a.btn {
  color: white;
}
.divide-col main .company-prof .address .desc a.--outline,
.lang__cont main .company-prof .address .desc a.--outline {
  border-color: white;
}
.divide-col main .company-prof .address .desc a::after,
.lang__cont main .company-prof .address .desc a::after {
  color: white;
}
.divide-col main .company-prof .address .desc dl,
.lang__cont main .company-prof .address .desc dl {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: 1rem;
}
.divide-col main .company-prof .address .desc dl .cat,
.lang__cont main .company-prof .address .desc dl .cat {
  display: block;
  padding: 0.2rem 0;
  width: var(--mp5);
  line-height: 1;
  text-align: center;
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  border-radius: 5rem;
}
.divide-col main .company-prof .address .desc dl a,
.lang__cont main .company-prof .address .desc dl a {
  color: white;
}
.divide-col main .qualified-list,
.lang__cont main .qualified-list {
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
.divide-col main .qualified-list__inner .col,
.lang__cont main .qualified-list__inner .col {
  text-align: center;
}
.divide-col main .qualified-list__inner .col .name,
.divide-col main .qualified-list__inner .col .widgettitle,
.lang__cont main .qualified-list__inner .col .name,
.lang__cont main .qualified-list__inner .col .widgettitle {
  position: relative;
  padding: 1rem 1rem 1.75rem;
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  background-color: white;
  border-radius: 0.75rem;
}
.divide-col main .qualified-list__inner .col .name::after,
.divide-col main .qualified-list__inner .col .widgettitle::after,
.lang__cont main .qualified-list__inner .col .name::after,
.lang__cont main .qualified-list__inner .col .widgettitle::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  font-family: "fontello";
  content: "\f107";
}
.divide-col main .qualified-list__inner .col .people,
.divide-col main .qualified-list__inner .col .textwidget,
.lang__cont main .qualified-list__inner .col .people,
.lang__cont main .qualified-list__inner .col .textwidget {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  padding-top: 1rem;
  padding-bottom: 2rem;
}
.divide-col main .business-registration,
.divide-col main .affiliation,
.divide-col main .certification,
.lang__cont main .business-registration,
.lang__cont main .affiliation,
.lang__cont main .certification {
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
.divide-col main .nda,
.lang__cont main .nda {
  --nda-space: clamp(1rem, 0.7rem + 1.5vw, 2.5rem);
}
.divide-col main .nda__card,
.lang__cont main .nda__card {
  position: relative;
  padding: 1rem;
  padding: var(--nda-space);
  background-color: white;
  border-radius: 0.75rem;
  box-shadow: 0 3px 10px 0 rgba(36, 36, 36, 0.25);
}
.divide-col main .nda__card::before,
.lang__cont main .nda__card::before {
  --clip-size: clamp(2.5rem, 2.25rem + 1.25vw, 3.75rem);
  position: absolute;
  display: block;
  top: -0.8rem;
  left: 2.5rem;
  left: clamp(2.5rem, 12.5vw, 15rem);
  content: "";
  width: 2.5rem;
  width: var(--clip-size);
  height: 2.5rem;
  height: var(--clip-size);
  background: url(../images/clip.svg) top left/contain no-repeat;
}
.divide-col main .nda__heading,
.lang__cont main .nda__heading {
  text-align: center;
  border-bottom: 1px solid #E3E3E3;
  padding-top: 1rem;
  padding-top: var(--nda-space);
  padding-bottom: 1rem;
  padding-bottom: var(--nda-space);
}
.divide-col main .nda__heading h2,
.lang__cont main .nda__heading h2 {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
}
.divide-col main .nda__heading small,
.lang__cont main .nda__heading small {
  line-height: 1;
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  color: #999999;
}
.divide-col main .nda__inner,
.lang__cont main .nda__inner {
  padding-top: 1rem;
  padding-top: var(--nda-space);
  padding-bottom: 1rem;
  padding-bottom: var(--nda-space);
}
.divide-col main .nda__inner .tum,
.lang__cont main .nda__inner .tum {
  display: block;
  width: 100%;
  height: 100%;
  background: url(../images/nda.webp) center center/cover no-repeat;
  border-radius: 0.75rem;
  overflow: hidden;
}
.divide-col main .nda__inner .note,
.lang__cont main .nda__inner .note {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}
.divide-col main .services-list,
.lang__cont main .services-list {
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
.divide-col main .services-list__inner,
.lang__cont main .services-list__inner {
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
.divide-col main .services-list__inner .col,
.lang__cont main .services-list__inner .col {
  overflow: hidden;
  background-color: white;
  border-radius: 0.75rem;
}
.divide-col main .services-list__inner .col .desc,
.lang__cont main .services-list__inner .col .desc {
  padding: var(--mp25);
}
.divide-col main .services-list__inner .col .desc h2,
.lang__cont main .services-list__inner .col .desc h2 {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
}
.divide-col main .page__post,
.lang__cont main .page__post {
  display: grid;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.divide-col main .page__post .call,
.divide-col main .page__post .btn,
.lang__cont main .page__post .call,
.lang__cont main .page__post .btn {
  margin: 0 auto;
}
.divide-col main .page__post .call,
.lang__cont main .page__post .call {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
}
@media screen and (min-width: 992px) {
  .divide-col aside,
  .lang__cont aside {
    order: 2;
    position: -webkit-sticky;
    position: sticky;
    height: calc((var(--mp35) + 1rem) * 6);
    top: calc(var(--header-height) + 2rem);
    display: grid;
    row-gap: 1rem;
  }
  .divide-col aside a,
  .lang__cont aside a {
    white-space: nowrap;
    height: var(--mp35);
  }
  .divide-col main,
  .lang__cont main {
    order: 1;
    height: 100%;
  }
  .divide-col main .company-prof .col,
  .lang__cont main .company-prof .col {
    display: grid;
    align-items: center;
    grid-template-columns: 220px 1fr;
    column-gap: var(--mp25);
  }
  .divide-col main .company-prof .address,
  .lang__cont main .company-prof .address {
    grid-template-columns: 1fr 1fr;
    column-gap: var(--mp25);
    border-radius: 0.75rem;
  }
  .divide-col main .company-prof .address iframe,
  .lang__cont main .company-prof .address iframe {
    width: 100%;
    height: 100%;
    aspect-ratio: 1.777777;
    object-fit: cover;
  }
  .divide-col main .qualified-list__inner,
  .lang__cont main .qualified-list__inner {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: var(--mp15);
    row-gap: var(--mp15);
  }
  .divide-col main .nda__inner,
  .lang__cont main .nda__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: var(--mp25);
  }
  .divide-col main .services-list__inner,
  .lang__cont main .services-list__inner {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--mp25);
    row-gap: var(--mp25);
  }
}
@media screen and (max-width: 991.98px) {
  .divide-col aside,
  .lang__cont aside {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(3, 1fr);
    grid-column-gap: 1rem;
    grid-row-gap: 0.5rem;
    height: calc((var(--mp25) + 0.5rem) * 3);
  }
  .divide-col aside a,
  .lang__cont aside a {
    white-space: nowrap;
    height: var(--mp25);
    padding: 0 !important;
    display: grid;
    place-items: center;
    letter-spacing: 0;
    font-size: 0.875rem;
    font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  }
  .divide-col main .company-prof .col,
  .lang__cont main .company-prof .col {
    display: grid;
    row-gap: 0.5rem;
  }
  .divide-col main .company-prof .col div:first-child,
  .lang__cont main .company-prof .col div:first-child {
    width: 100%;
  }
  .divide-col main .company-prof .address,
  .lang__cont main .company-prof .address {
    margin-left: calc(var(--mp15) * -1);
    margin-right: calc(var(--mp15) * -1);
    display: grid;
    row-gap: 1rem;
  }
  .divide-col main .company-prof .address iframe,
  .lang__cont main .company-prof .address iframe {
    order: 2;
    width: 100%;
    height: 100%;
    aspect-ratio: 1.777777;
    object-fit: cover;
  }
  .divide-col main .company-prof .address .desc,
  .lang__cont main .company-prof .address .desc {
    order: 1;
    display: grid;
    row-gap: 0.5rem;
  }
  .divide-col main .nda__inner,
  .lang__cont main .nda__inner {
    display: grid;
    row-gap: var(--mp25);
  }
  .divide-col main .nda__inner .tum,
  .lang__cont main .nda__inner .tum {
    display: block;
    width: 100%;
    height: 100%;
    aspect-ratio: 1.777777;
    object-fit: cover;
    background: url(../images/nda.webp) center center/cover no-repeat;
  }
}

@media screen and (min-width: 992px) {
  ::-webkit-full-page-media,
  :future,
  :root .address iframe {
    height: 20rem !important;
  }
}
@media screen and (max-width: 991.98px) {
  ::-webkit-full-page-media,
  :future,
  :root .address iframe {
    height: 10rem !important;
  }
}
/*---------------------------------------------------
	foreign languages
---------------------------------------------------*/
/*---------------------------------------------------
	recruit
---------------------------------------------------*/
.recruit {
  display: grid;
  row-gap: 5rem;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
}
.recruit__heading {
  position: relative;
  text-align: center;
  overflow: hidden;
}
.recruit__heading::before {
  content: "Our Organization";
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  font-size: 3rem;
  font-size: clamp(3rem, 1.6rem + 7vw, 10rem);
  line-height: 1;
  color: white;
  white-space: nowrap;
}
.recruit__heading .lead {
  margin-top: -1rem;
}
.recruit__img {
  display: grid;
  place-items: center;
}
.recruit__img::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(36, 36, 36, 0.5);
  content: "";
}
.recruit__img h2 {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
  color: white;
  letter-spacing: 1rem;
  z-index: 1;
}
.recruit__cont {
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
.recruit__cont--nav {
  display: flex;
  align-items: center;
}
.recruit__cont--post {
  display: grid;
}
.recruit__cont--post .col {
  display: grid;
  padding-top: var(--mp25);
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}
.recruit__cont .apply {
  display: grid;
  margin-top: var(--mp25);
}
.recruit__cont .apply--tit, .recruit__cont .apply--desc {
  display: grid;
  place-items: center;
  text-align: center;
  padding-top: 2rem;
  padding-bottom: 2rem;
}
.recruit__cont .apply--tit {
  color: white;
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
  background-color: #0073C3;
  border-radius: 0.75rem;
}
.recruit__cont .apply--desc h4 {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .recruit__img {
    height: 400px;
  }
  .recruit__img .paraslimy-bg {
    background-image: url("../images/recruit__img.webp");
  }
  .recruit__cont--nav {
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 1%;
    row-gap: 1rem;
  }
  .recruit__cont--post {
    row-gap: var(--mp25);
  }
  .recruit__cont--post .col {
    grid-template-columns: 260px 1fr;
    border-top: 1px solid #E3E3E3;
  }
  .recruit__cont .apply {
    grid-template-columns: 1fr 1fr;
    column-gap: 10%;
  }
  .recruit__cont .apply--tit {
    width: 100%;
    height: 100%;
    width: 100%;
    height: 100%;
    aspect-ratio: 1.777777;
    object-fit: cover;
  }
}
@media screen and (max-width: 767.98px) {
  .recruit__img {
    height: 44vh;
  }
  .recruit__img .paraslimy-bg {
    background-image: url("../images/recruit__img-800.webp");
  }
  .recruit__cont--nav {
    flex-direction: column;
    row-gap: 1rem;
  }
  .recruit__cont--post .col div:first-child {
    padding: 0.4rem 1rem;
    background-color: #EFEFEF;
    border-bottom: 1px solid #999999;
  }
  .recruit__cont--post .col div:last-child {
    padding-top: 1rem;
  }
}

/*---------------------------------------------------
	link
---------------------------------------------------*/
.link-list {
  display: grid;
  row-gap: 2rem;
  max-width: 992px;
  margin: 2.5rem auto;
  margin: calc((5rem + (1vw - 0.2rem) * 2) * 0.5) auto;
}
.link-list .thum {
  border: 1px solid #E3E3E3;
}
.link-list .thum a {
  display: grid;
  place-items: center;
  padding-top: 0.8rem;
  padding-bottom: 0.8rem;
  width: 100%;
  height: 100%;
}
.link-list .thum.--noimage {
  text-align: center;
}
.link-list article h2 {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}
.link-list article h2 + a {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 992px) {
  .link-list article {
    display: grid;
    grid-template-columns: 320px 1fr;
    align-items: center;
    column-gap: 2rem;
  }
}
/*---------------------------------------------------
	contact us
---------------------------------------------------*/
.contact-flow {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  column-gap: 0.1rem;
  column-gap: clamp(0.1rem, -0.227rem + 1.64vw, 1rem);
  align-items: center;
  width: 20rem;
  width: clamp(20rem, 18.182rem + 9.09vw, 25rem);
  margin: 3.75rem auto;
  margin: calc((5rem + (1vw - 0.2rem) * 2) * 0.75) auto;
}
.contact-flow .step {
  --step-size: 100%;
  position: relative;
  z-index: 0;
  width: var(--step-size);
  height: var(--step-size);
  display: grid;
  place-items: center;
}
.contact-flow .step::before {
  position: absolute;
  width: var(--step-size);
  height: var(--step-size);
  background-color: #EFEFEF;
  border-radius: 50%;
  content: "";
  z-index: -1;
}
.contact-flow .step.--current::before {
  background-color: rgba(48, 160, 56, 0.25);
}

.mw_wp_form_confirm .form__group__col {
  padding: 0.6rem 0.4rem 0.6rem 1rem;
  min-height: 1rem;
  background-color: #EFEFEF;
  border-radius: 0.75rem;
}
@media screen and (min-width: 992px) {
  .mw_wp_form_confirm .form__group__col {
    margin-left: 1rem;
  }
}

/*---------------------------------------------------
	page / single
	Default settings
---------------------------------------------------*/
.cover {
  position: relative;
}
@media screen and (min-width: 992px) {
  .cover {
    padding-top: calc(var(--header-height) + 1rem);
  }
}
@media screen and (max-width: 991.98px) {
  .cover {
    padding-top: calc(var(--toggle-size) + 1rem);
  }
}
.cover::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 15rem;
  height: clamp(15rem, 12.4rem + 13vw, 28rem);
  background-color: #0073C3;
  content: "";
}
.cover .hero {
  position: relative;
}
.cover .hero__heading {
  position: absolute;
  width: 13.75rem;
  width: clamp(13.75rem, 12rem + 8.75vw, 22.5rem);
  border-radius: 0.75rem;
  background-color: white;
}
.cover .hero__heading span {
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  color: #30A038;
}
.cover .hero img {
  width: 100%;
  height: 100%;
  border-radius: 0.75rem;
  object-fit: cover;
}
@media screen and (min-width: 992px) {
  .cover .hero {
    padding-top: 0.5rem;
  }
  .cover .hero__heading {
    --out: clamp(0.031rem, -0.948rem + 2.04vw, 1.5rem);
    bottom: -0.062rem;
    bottom: calc(var(--out) * -2);
    left: -0.031rem;
    left: calc(var(--out) * -1);
    padding: 0.062rem;
    padding: calc(var(--out) * 2);
    line-height: 1.6;
  }
  .cover .hero__heading h2 {
    padding-top: 0.124rem;
    padding-top: calc(var(--out) * 4);
    font-size: 1.25rem;
    font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
    white-space: nowrap;
  }
}
@media screen and (max-width: 991.98px) {
  .cover .hero__heading {
    bottom: -3rem;
    left: 1rem;
    padding: 1rem;
    line-height: 1.2;
  }
  .cover .hero__heading h2 {
    padding-top: 1.5rem;
    font-size: 1.125rem;
    font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
  }
}

/*****************************/
/* wrap */
.wrap {
  position: relative;
  margin-bottom: 5rem;
  margin-bottom: calc(5rem + (1vw - 0.2rem) * 2);
}
@media screen and (min-width: 992px) {
  .wrap {
    margin-top: 5rem;
    margin-top: calc(5rem + (1vw - 0.2rem) * 2);
  }
}
@media screen and (max-width: 991.98px) {
  .wrap {
    margin-top: 6rem;
    margin-top: calc(5rem + (1vw - 0.2rem) * 2 + 1rem);
  }
}

/*****************************/
/*	sdg_icon_list	*/
.sdg_icon_list {
  margin-top: 2.5rem;
  margin-top: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
  margin-bottom: var(--mp25);
  padding-top: 2.5rem;
  padding-top: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
  display: grid;
  gap: var(--mp25);
  border-top: 1px solid #E3E3E3;
}
@media screen and (min-width: 992px) {
  .sdg_icon_list {
    grid-template-columns: repeat(6, 1fr);
  }
}
@media screen and (min-width: 576px) and (max-width: 991.98px) {
  .sdg_icon_list {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (max-width: 575.98px) {
  .sdg_icon_list {
    grid-template-columns: repeat(2, 1fr);
  }
}

/*---------------------------------------------------
	page
---------------------------------------------------*/
.page {
  display: grid;
  row-gap: 5rem;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
  /* post */
}
.page__post {
  padding: var(--mp5);
  background-color: white;
  border-radius: 0.75rem;
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  overflow: auto;
}
.page__post p {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}
@media screen and (max-width: 575.98px) {
  .page__post {
    margin-left: calc(var(--mp15) * -1);
    margin-right: calc(var(--mp15) * -1);
    padding: var(--mp25) var(--mp15);
    border-radius: 0;
  }
}

/*---------------------------------------------------
	news - single - archive
---------------------------------------------------*/
.news {
  display: grid;
  row-gap: 5rem;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
  /* archive */
  /* post */
}
.news__list {
  display: grid;
}
.news__list .article {
  background-color: white;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 3px 10px 0 rgba(36, 36, 36, 0.25);
}
.news__list .article__inner {
  display: grid;
  row-gap: 0.25rem;
  row-gap: clamp(0.25rem, 0.25rem + (1vw - 0.2rem) * 0.75, 1rem);
  align-content: space-between;
  padding: 0.75rem;
  padding: clamp(0.75rem, 0.75rem + (1vw - 0.2rem) * 0.75, 1.5rem);
}
.news__list .article__inner h3 {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  overflow: hidden;
  line-height: 1.4;
}
.news__list .article__inner .detail {
  display: flex;
  justify-content: space-between;
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  letter-spacing: 0;
}
.news__list .article__inner .detail .date {
  color: #999999;
}
.news__list .article .thum img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1.333333;
  object-fit: contain;
}
.news__post {
  padding: var(--mp5);
  background-color: white;
  border-radius: 0.75rem;
  overflow: auto;
}
.news__post__heading .tag {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.news__post__heading h2 {
  margin-top: 1rem;
}
.news__post__heading .date {
  margin-top: 0.5rem;
  text-align: end;
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  color: #999999;
  letter-spacing: 0.1rem;
}
.news__post__cont {
  margin-top: var(--mp25);
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  word-break: break-all;
}
.news__post__cont a {
  color: #30A038;
}
.news__post__cont .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.news__post__cont .alignright {
  float: right;
  margin-left: 1.5em;
}
.news__post__cont .alignleft {
  float: left;
  margin-right: 1.5em;
}
@media screen and (min-width: 992px) {
  .news__list {
    grid-template-columns: repeat(3, 1fr);
    column-gap: var(--mp25);
    row-gap: var(--mp25);
  }
}
@media screen and (min-width: 576px) and (max-width: 991.98px) {
  .news__list {
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--mp15);
    row-gap: var(--mp15);
  }
}
@media screen and (max-width: 575.98px) {
  .news__list {
    row-gap: var(--mp15);
  }
  .news__list .article {
    max-width: 640px;
    margin: 0 auto;
  }
  .news__post {
    margin-left: calc(var(--mp15) * -1);
    margin-right: calc(var(--mp15) * -1);
    padding: var(--mp15);
    border-radius: 0;
  }
}

/*---------------------------------------------------
	index
---------------------------------------------------*/
/* index news */
.news__index__heading {
  position: relative;
  margin-bottom: var(--mp25);
  padding-top: 5rem;
  padding-top: clamp(5rem, 5rem + (1vw - 0.2rem) * 5, 10rem);
  overflow: hidden;
}
.news__index__heading::before {
  position: absolute;
  bottom: -0.6rem;
  bottom: calc(clamp(0.6rem, 0.6rem + (1vw - 0.2rem) * 1.9, 2.5rem) * -1);
  right: 0;
  content: "News";
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  font-size: 3.25rem;
  font-size: clamp(3.25rem, 1.15rem + 10.5vw, 13.75rem);
  line-height: 1;
  color: white;
}
.news__index__inner {
  display: grid;
}
.news__index__inner .article {
  background-color: white;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 3px 10px 0 rgba(36, 36, 36, 0.25);
}
.news__index__inner .article.--usually {
  display: grid;
  grid-template-columns: 38% 1fr;
}
.news__index__inner .article .thum {
  position: relative;
}
.news__index__inner .article .thum .new {
  z-index: 1;
  --w: calc(3rem + ((1vw - 0.2rem) * 0.4));
  --h: calc(4rem + ((1vw - 0.2rem) * 0.5));
  display: block;
  position: absolute;
  top: -1rem;
  left: 1rem;
  width: var(--w);
  height: var(--h);
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  text-align: center;
  color: red;
  line-height: calc(var(--h) - 0.5rem);
  letter-spacing: 0;
  background: url(../images/ribbon.svg) top left/var(--w) var(--h) no-repeat;
}
.news__index__inner .article .thum img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1.333333;
  object-fit: cover;
}
.news__index__inner .article__block {
  display: grid;
  row-gap: 0.25rem;
  row-gap: clamp(0.25rem, 0.25rem + (1vw - 0.2rem) * 0.75, 1rem);
  align-content: space-between;
  padding: 0.75rem;
  padding: clamp(0.75rem, 0.75rem + (1vw - 0.2rem) * 0.75, 1.5rem);
}
.news__index__inner .article__block h3 {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  overflow: hidden;
  line-height: 1.4;
}
.news__index__inner .article__block .detail {
  display: flex;
  justify-content: space-between;
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  flex-wrap: wrap;
}
.news__index__inner .article__block .detail .date {
  color: #999999;
}
@media screen and (min-width: 992px) {
  .news__index__inner {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(3, max-content);
    grid-column-gap: var(--mp25);
    grid-row-gap: var(--mp25);
    grid-template-areas: "--post1 --post2" "--post1 --post3" "--post1 --post4";
  }
  .news__index__inner .article.--post1 {
    grid-area: --post1;
  }
  .news__index__inner .article.--post2 {
    grid-area: --post2;
  }
  .news__index__inner .article.--post3 {
    grid-area: --post3;
  }
  .news__index__inner .article.--post4 {
    grid-area: --post4;
  }
  .news__index__inner .article.--latest {
    display: grid;
  }
}
@media screen and (max-width: 991.98px) {
  .news__index__inner {
    row-gap: var(--mp15);
  }
  .news__index__inner .article {
    max-width: 640px;
    margin: 0 auto;
  }
}

/* index business */
.business {
  position: relative;
}
.business::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 80%;
  height: calc(100% - 2.25rem);
  height: calc(100% - clamp(4.5rem, 4.5rem + (1vw - 0.2rem) * 9.25, 13.75rem) * 0.5);
  background-color: #E3E3E3;
  border-radius: 0 0.75rem 0.75rem 0;
  content: "";
  margin-top: 2.25rem;
  margin-top: calc(clamp(4.5rem, 4.5rem + (1vw - 0.2rem) * 9.25, 13.75rem) * 0.5);
}
.business__heading {
  position: relative;
}
.business__heading::before {
  content: "BUSINESS";
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  font-size: 3.25rem;
  font-size: clamp(3.25rem, 1.15rem + 10.5vw, 13.75rem);
  line-height: 1;
  color: white;
}
.business__heading h2 {
  margin-top: -1.5rem;
  margin-top: calc(clamp(1.5rem, 1.5rem + (1vw - 0.2rem) * 2, 3.5rem) * -1);
  padding-left: 1.5rem;
  padding-left: clamp(1.5rem, 1.5rem + (1vw - 0.2rem) * 1, 2.5rem);
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
}
.business .splide {
  margin-top: 2.5rem;
  margin-top: clamp(2.5rem, 2.5rem + (1vw - 0.2rem) * 2.5, 5rem);
}
.business .splide__slide {
  background-color: white;
  border-radius: 0.75rem;
  overflow: hidden;
}
.business .splide__slide .desc {
  display: grid;
  row-gap: var(--mp1);
  padding: var(--mp15);
}
.business .splide__slide .desc .heading {
  display: grid;
  row-gap: 0.75rem;
  text-align: center;
  line-height: 1;
}
.business .splide__slide .desc .heading img {
  margin: 0 auto 1rem;
  width: auto;
  height: var(--mp25);
}
.business .splide__slide .desc .heading h2 {
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
}
.business .splide__slide .desc .heading span {
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  color: #30A038;
}
.business .splide__slide .desc p {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.business .splide__arrows {
  margin-top: -1rem;
  position: relative;
}
.business .splide__arrow {
  --arrow-size: clamp(3rem, calc(3rem + ((1vw - 0.2rem) * 1.5)), 4.5rem);
  --arrow-space: clamp(0.75rem, calc(0.75rem + ((1vw - 0.2rem) * 2.25)), 3rem);
  border: none;
  border-radius: 50%;
  background-color: #0073C3;
  width: 3rem;
  width: var(--arrow-size);
  height: 3rem;
  height: var(--arrow-size);
  text-align: center;
  color: white;
  letter-spacing: 0;
}
.business .splide__arrow--prev {
  position: absolute;
  left: 0.75rem;
  left: var(--arrow-space);
}
.business .splide__arrow--next {
  position: absolute;
  right: 0.75rem;
  right: var(--arrow-space);
}

/* index support */
.support {
  display: grid;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
  margin-top: 5rem;
  margin-top: calc(5rem + (1vw - 0.2rem) * 2);
}
.support__heading {
  position: relative;
  text-align: center;
}
.support__heading::before {
  content: "SUPPORT";
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  font-size: 3.25rem;
  font-size: clamp(3.25rem, 1.15rem + 10.5vw, 13.75rem);
  line-height: 1;
  color: white;
}
.support__heading h2 {
  margin-top: -1.5rem;
  margin-top: calc(clamp(1.5rem, 1.5rem + (1vw - 0.2rem) * 2, 3.5rem) * -1);
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
}
.support__inner .box {
  background-color: white;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 3px 10px 0 rgba(36, 36, 36, 0.25);
}
.support__inner .box.--support1 .tit {
  background-color: #0073C3;
}
.support__inner .box.--support2 .tit {
  background-color: #30A038;
}
.support__inner .box .tit {
  padding: var(--mp15) 0;
  text-align: center;
  line-height: 1.4;
}
.support__inner .box .tit h3 {
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
  color: white;
}
.support__inner .box .tit span {
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  color: #FFE619;
}
.support__inner .box .detail {
  display: grid;
  row-gap: var(--mp1);
  padding: var(--mp15);
}
.support__inner .box .detail img {
  margin: 0 auto 1rem;
  width: auto;
  height: var(--mp5);
}
@media screen and (min-width: 768px) {
  .support__img {
    height: 400px;
  }
  .support__img .paraslimy-bg {
    background-image: url("../images/support__img.webp");
  }
  .support__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: var(--mp25);
    align-items: start;
  }
  .support__inner .--support2 {
    margin-top: var(--fade-range);
  }
}
@media screen and (max-width: 767.98px) {
  .support__img {
    height: 45vh;
  }
  .support__img .paraslimy-bg {
    background-image: url("../images/support__img-800.webp");
  }
  .support__inner {
    display: grid;
    row-gap: var(--mp25);
  }
  .support__inner .--support1 {
    margin-left: -1rem;
  }
  .support__inner .--support2 {
    margin-right: -1rem;
  }
}

/* index service */
.service {
  position: relative;
  margin-top: 5rem;
  margin-bottom: 5rem;
  margin-top: calc(5rem + (1vw - 0.2rem) * 2);
  margin-bottom: calc(5rem + (1vw - 0.2rem) * 2);
}
.service::before {
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  height: calc(100% - 2.4375rem);
  height: calc(100% - clamp(3.25rem, 3.25rem + (1vw - 0.2rem) * 5, 8.25rem) * 0.75);
  background-color: white;
  content: "";
  margin-top: 2.4375rem;
  margin-top: calc(clamp(3.25rem, 3.25rem + (1vw - 0.2rem) * 5, 8.25rem) * 0.75);
}
.service__inner {
  display: grid;
}
.service__inner--img {
  position: relative;
}
.service__inner--img .image {
  position: absolute;
  border-radius: 0.75rem;
  overflow: hidden;
}
.service__inner--cont {
  display: grid;
  row-gap: 1.625rem;
  row-gap: calc(clamp(3.25rem, 3.25rem + (1vw - 0.2rem) * 5, 8.25rem) * 0.5);
  justify-items: center;
  align-content: space-between;
  padding-bottom: 2.4375rem;
  padding-bottom: calc(clamp(3.25rem, 3.25rem + (1vw - 0.2rem) * 5, 8.25rem) * 0.75);
}
.service__inner--cont .heading::before {
  content: "Service × Results";
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  font-size: 3.25rem;
  font-size: clamp(3.25rem, 3.25rem + (1vw - 0.2rem) * 5, 8.25rem);
  line-height: 1;
  color: #E3E3E3;
}
.service__inner--cont .heading img {
  margin: 2rem auto 0;
  height: 8rem;
  height: clamp(8rem, 8rem + (1vw - 0.2rem) * 4, 12rem);
  display: block;
}
.service__inner--cont .heading .aid {
  margin: 1rem auto;
  width: 260px;
  text-align: center;
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
  color: white;
  background-color: #0073C3;
  border-radius: 5rem;
}
.service__inner--cont .detail {
  display: grid;
  row-gap: var(--mp15);
  justify-items: center;
  align-content: space-between;
}
@media screen and (min-width: 992px) {
  .service::before {
    width: 80%;
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .service__inner {
    grid-template-columns: 1fr 65%;
    align-items: start;
  }
  .service__inner--img {
    width: 100%;
    max-width: 600px !important;
    height: 100%;
  }
  .service__inner--img .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .service__inner--img .image:nth-child(1) {
    top: 0;
    left: var(--mp15);
    height: auto;
    max-width: 600px;
  }
  .service__inner--img .image:nth-child(2) {
    top: clamp(12.5rem, -0.834rem + 21.53vw, 25rem);
    right: calc(clamp(7.5rem, 2.166rem + 8.61vw, 12.5rem) * -1);
    width: 40%;
  }
  .service__inner--img .image:nth-child(3) {
    top: clamp(25rem, 4.732rem + 32.72vw, 44rem);
    right: calc(clamp(6rem, 3.066rem + 4.74vw, 8.75rem) * -1);
    width: 38%;
  }
  .service__inner--cont .detail {
    width: 50%;
  }
}
@media screen and (max-width: 991.98px) {
  .service::before {
    width: 100%;
  }
  .service__inner {
    flex-direction: column;
  }
  .service__inner--img {
    width: 100%;
    height: 85vw;
  }
  .service__inner--img .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .service__inner--img .image:nth-child(1) {
    top: 0;
    left: var(--mp15);
    height: auto;
    max-width: 50vw;
  }
  .service__inner--img .image:nth-child(2) {
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 25vw;
    width: 25vw;
  }
  .service__inner--img .image:nth-child(3) {
    bottom: 5.5vw;
    right: 22vw;
    width: 20vw;
  }
  .service__inner--cont .detail {
    padding-left: var(--mp15);
    padding-right: var(--mp15);
  }
}
@media screen and (min-width: 576px) and (max-width: 991.98px) {
  .service__inner--cont .detail {
    width: 26.25rem;
    width: clamp(26.25rem, 17.596rem + 24.04vw, 32.5rem);
  }
}

/*---------------------------------------------------
	business
---------------------------------------------------*/
.cover-business {
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 992px) {
  .cover-business {
    height: 32.5vw;
    padding-top: calc(var(--header-height) + 1rem);
  }
}
@media screen and (max-width: 991.98px) {
  .cover-business {
    height: 47.5vh;
    padding-top: calc(var(--toggle-size) + 1rem);
  }
}
.cover-business::before, .cover-business::after {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  content: "";
}
.cover-business::after {
  background-color: rgba(36, 36, 36, 0.5);
}
.cover-business.--business001::before {
  background: url("../images/business-thum001.webp") center center/cover no-repeat;
}
.cover-business.--business002::before {
  background: url("../images/business-thum002.webp") center center/cover no-repeat;
}
.cover-business.--business003::before {
  background: url("../images/business-thum003.webp") center center/cover no-repeat;
}
.cover-business.--business004::before {
  background: url("../images/business-thum004.webp") center center/cover no-repeat;
}
.cover-business.--business005::before {
  background: url("../images/business-thum005.webp") center center/cover no-repeat;
}
.cover-business.--business006::before {
  background: url("../images/business-thum006.webp") center center/cover no-repeat;
}
.cover-business__inner {
  display: grid;
  place-items: center;
  height: calc(100% - 2rem);
}
.cover-business__inner .heading {
  text-align: center;
  color: white;
}
.cover-business__inner .heading i {
  display: block;
  width: 4rem;
  height: 4rem;
  margin: 0 auto;
  background-color: white;
  background-image: none;
}
.cover-business__inner .heading i.business-icon1 {
  -webkit-mask: url("../images/business1.svg") no-repeat center center/contain;
  mask: url("../images/business1.svg") no-repeat center center/contain;
}
.cover-business__inner .heading i.business-icon2 {
  -webkit-mask: url("../images/business2.svg") no-repeat center center/contain;
  mask: url("../images/business2.svg") no-repeat center center/contain;
}
.cover-business__inner .heading i.business-icon3 {
  -webkit-mask: url("../images/business3.svg") no-repeat center center/contain;
  mask: url("../images/business3.svg") no-repeat center center/contain;
}
.cover-business__inner .heading i.business-icon4 {
  -webkit-mask: url("../images/business4.svg") no-repeat center center/contain;
  mask: url("../images/business4.svg") no-repeat center center/contain;
}
.cover-business__inner .heading i.business-icon5 {
  -webkit-mask: url("../images/business5.svg") no-repeat center center/contain;
  mask: url("../images/business5.svg") no-repeat center center/contain;
}
.cover-business__inner .heading i.business-icon6 {
  -webkit-mask: url("../images/business6.svg") no-repeat center center/contain;
  mask: url("../images/business6.svg") no-repeat center center/contain;
}
.cover-business__inner .heading h2 {
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
  padding: 0.4rem 1rem;
  margin-bottom: 0.8rem;
  border-bottom: 1px solid white;
}
.cover-business__inner .heading span {
  display: block;
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
}

.business__list {
  display: grid;
}
.business__list .col {
  background-color: white;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 3px 10px 0 rgba(36, 36, 36, 0.25);
  cursor: pointer;
}
.business__list .col .desc {
  display: grid;
  row-gap: 0.75rem;
  row-gap: clamp(0.75rem, 0.266rem + 2.28vw, 3rem);
  align-content: space-between;
  padding: 0.75rem;
  padding: clamp(0.75rem, 0.2rem + 2.75vw, 3.5rem);
}
.business__list .col .desc .heading {
  display: grid;
  row-gap: 0.75rem;
  text-align: center;
  line-height: 1;
}
.business__list .col .desc .heading img {
  margin: 0 auto 1rem;
  width: auto;
  height: 2.5rem;
  height: clamp(2.5rem, 2.3rem + 1vw, 3.5rem);
}
.business__list .col .desc .heading h2 {
  font-size: 1.125rem;
  font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
}
.business__list .col .desc .heading span {
  font-size: 0.625rem;
  font-size: clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  letter-spacing: 0;
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  color: #30A038;
}
.business__list .col .desc p {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
@media screen and (min-width: 992px) {
  .business__list {
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--mp35);
    row-gap: var(--mp35);
    align-items: start;
  }
  .business__list .col:nth-child(even) {
    margin-top: var(--fade-range);
  }
}
@media screen and (max-width: 991.98px) {
  .business__list {
    max-width: 576px;
    margin: 0 auto;
    row-gap: var(--mp25);
  }
  .business__list .col .desc .heading {
    padding-top: 0.6rem;
  }
}

.business__cont {
  display: grid;
  row-gap: 5rem;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
}
.business__cont__heading {
  position: relative;
  display: grid;
  row-gap: 2.5rem;
  row-gap: clamp(2.5rem, 2rem + 2.5vw, 5rem);
}
.business__cont__heading p {
  max-width: 767.98px;
}
.business__cont__card {
  position: relative;
  width: 100%;
  height: 100%;
  background-color: white;
}
@media screen and (max-width: 991.98px) {
  .business__cont__card .card__inner.--sp__order .card__inner--img {
    order: 1;
  }
  .business__cont__card .card__inner.--sp__order .desc {
    order: 2;
  }
}
.business__cont__block {
  display: grid;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
@media screen and (min-width: 992px) {
  .business__cont__container {
    margin-left: auto;
    margin-right: auto;
    padding-right: var(--mp25);
    padding-left: var(--mp25);
    max-width: calc(1400px + var(--mp25) * 2);
    width: 100%;
  }
}
.business__cont .card__heading {
  position: relative;
}
.business__cont .card__heading h2 {
  position: absolute;
  display: inline-block;
  top: -1.5rem;
  top: calc(clamp(1.5rem, 1.2rem + 1.5vw, 3rem) * -1);
  left: 1rem;
  left: clamp(1rem, 0.57rem + 2.03vw, 3rem);
  padding: 1rem 1.5rem;
  color: white;
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
  line-height: 1;
  background-color: #30A038;
  border-radius: 0.75rem;
}
.business__cont .achievement {
  overflow: hidden;
  padding: 1.5rem;
  padding: clamp(1.5rem, 1.3rem + 1vw, 2.5rem);
  background-color: #EFEFEF;
  border-radius: 0.75rem;
}
.business__cont .achievement .cont-tit-tertiary {
  padding-bottom: 0.8rem;
}
.business__cont .achievement ul {
  list-style: disc;
  margin-left: 1.5rem;
}
.business__cont .achievement ul li {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.business__cont .dl {
  display: grid;
  row-gap: 1rem;
  row-gap: clamp(1rem, 0.7rem + 1.5vw, 2.5rem);
}
.business__cont .dl .dl-col {
  display: grid;
  row-gap: 0.75rem;
  row-gap: clamp(0.75rem, 0.6rem + 0.75vw, 1.5rem);
  align-items: start;
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.business__cont .dl .dl-col div:nth-child(1) {
  display: inline-block;
  padding: 0.4rem 1.25rem;
  text-align: center;
  background-color: #E3E3E3;
  border-radius: 5rem;
}
@media screen and (max-width: 991.98px) {
  .business__cont .dl .dl-col div:nth-child(1) {
    width: 46%;
  }
}
@media screen and (min-width: 992px) {
  .business__cont .dl .dl-col {
    grid-template-columns: 30% 1fr;
    column-gap: var(--mp25);
  }
}
@media screen and (min-width: 992px) {
  .business__cont__card.--bgLeft .card__inner, .business__cont__card.--bgRight .card__inner {
    padding-top: calc(5rem + (1vw - 0.2rem) * 2);
    padding-bottom: calc(5rem + (1vw - 0.2rem) * 2);
  }
  .business__cont__card.--bgLeft {
    margin-left: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    border-radius: 0 0.75rem 0.75rem 0;
  }
  .business__cont__card.--bgLeft .card__inner {
    padding-right: calc(5rem + (1vw - 0.2rem) * 2);
    padding-left: calc(5rem + (1vw - 0.2rem) * 2);
  }
  .business__cont__card.--bgLeft .card__inner.--pdLeft {
    padding-left: calc((5rem + (1vw - 0.2rem) * 2) * 2) !important;
  }
  .business__cont__card.--bgRight {
    margin-left: calc(5rem + (1vw - 0.2rem) * 2);
    width: calc(100% - (5rem + (1vw - 0.2rem) * 2)) !important;
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont__card.--bgRight .card__inner {
    padding-left: calc(5rem + (1vw - 0.2rem) * 2);
  }
  .business__cont__card.--bgRight .card__inner.--pdRight {
    padding-right: calc(5rem + (1vw - 0.2rem) * 2) !important;
  }
  .business__cont__card.--bgCenter {
    border-radius: 0.75rem;
  }
  .business__cont__card.--bgCenter .card__inner {
    padding: calc(5rem + (1vw - 0.2rem) * 2);
  }
}
@media screen and (max-width: 991.98px) {
  .business__cont__card .card__inner {
    padding: var(--mp35) var(--mp15);
  }
}
.business__cont.--business001 .tit {
  display: grid;
  row-gap: 1.25rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.business__cont.--business001 .splide {
  margin-bottom: calc((5rem + (1vw - 0.2rem) * 2) * -1);
}
.business__cont.--business001 .card__inner {
  display: grid;
  align-items: start;
  row-gap: var(--mp25);
}
.business__cont.--business001 .card__inner .desc {
  display: grid;
  row-gap: var(--mp15);
}
.business__cont.--business001 .card__inner .desc h2 {
  display: grid;
  grid-template-columns: 3rem 1fr;
  column-gap: 1rem;
}
.business__cont.--business001 .card__inner .desc h2 em {
  display: inline-block;
  color: white;
  text-align: center;
  line-height: 3rem;
  font-family: "futura-pt", sans-serif;
  font-weight: 300;
  letter-spacing: 0;
  background-color: #30A038;
  border-radius: 0.75rem;
}
.business__cont.--business001 .card__inner--img {
  position: relative;
  overflow-x: clip;
}
.business__cont.--business001 .card__inner--img img {
  position: absolute;
}
@media screen and (min-width: 992px) {
  .business__cont.--business001 .business__cont__heading {
    grid-template-columns: 1fr 300px;
  }
  .business__cont.--business001 .business__cont__heading .heading-img {
    position: relative;
  }
  .business__cont.--business001 .business__cont__heading .heading-img img {
    position: absolute;
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .business__cont__heading .heading-img img:nth-child(1) {
    top: -3rem;
    right: 1rem;
    width: clamp(8.75rem, 8.5rem + 1.25vw, 10rem);
  }
  .business__cont.--business001 .business__cont__heading .heading-img img:nth-child(2) {
    top: 7rem;
    left: 1.5rem;
    width: clamp(7.5rem, 7.25rem + 1.25vw, 8.75rem);
  }
  .business__cont.--business001 .card__inner {
    grid-template-columns: 1fr 1fr;
    column-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
  .business__cont.--business001 .card__inner:first-child {
    border-top-right-radius: 0 !important;
  }
  .business__cont.--business001 .card__inner--img img.marin1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1.25);
    right: 0;
    width: 800px;
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business001 .card__inner--img img.marin2 {
    top: clamp(8.75rem, -5.918rem + 23.68vw, 22.5rem);
    right: var(--mp25);
    width: 45%;
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img img.non_native1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1.25);
    left: 0;
    width: 800px;
    border-radius: 0 0.75rem 0.75rem 0;
  }
  .business__cont.--business001 .card__inner--img img.non_native2 {
    top: clamp(8.75rem, -3.251rem + 19.38vw, 20rem);
    right: clamp(1rem, -2.2rem + 5.17vw, 4rem);
    width: clamp(8.75rem, 6.75rem + 3.23vw, 10.625rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img img.non_native3 {
    top: clamp(18.75rem, 2.749rem + 25.83vw, 33.75rem);
    right: clamp(9rem, 3.666rem + 8.61vw, 14rem);
    width: clamp(8.75rem, 6.083rem + 4.31vw, 11.25rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img img.greening1, .business__cont.--business001 .card__inner--img img.greening2, .business__cont.--business001 .card__inner--img img.greening3, .business__cont.--business001 .card__inner--img img.greening4 {
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img img.greening2, .business__cont.--business001 .card__inner--img img.greening3, .business__cont.--business001 .card__inner--img img.greening4 {
    width: 10rem;
  }
  .business__cont.--business001 .card__inner--img img.greening1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1.25);
    left: clamp(0rem, -4.267rem + 6.89vw, 4rem);
    width: clamp(22rem, 12.133rem + 15.93vw, 31.25rem);
  }
  .business__cont.--business001 .card__inner--img img.greening2 {
    top: clamp(13rem, 5.533rem + 12.06vw, 20rem);
    left: clamp(2rem, -4.4rem + 10.33vw, 8rem);
  }
  .business__cont.--business001 .card__inner--img img.greening3 {
    top: clamp(21rem, 17.8rem + 5.17vw, 24rem);
    left: clamp(9rem, 0.466rem + 13.78vw, 17rem);
  }
  .business__cont.--business001 .card__inner--img img.greening4 {
    top: clamp(30rem, 26.8rem + 5.17vw, 33rem);
    left: clamp(4rem, -4.534rem + 13.78vw, 12rem);
  }
  .business__cont.--business001 .card__inner--img img.eco_road1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1.25);
    left: 0;
    width: 640px;
    border-radius: 0 0.75rem 0.75rem 0;
  }
  .business__cont.--business001 .card__inner--img img.eco_road2 {
    top: clamp(8.5rem, 4.766rem + 6.03vw, 12rem);
    right: clamp(1rem, -2.2rem + 5.17vw, 4rem);
    width: clamp(12.5rem, 7.166rem + 8.61vw, 17.5rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img img.water1, .business__cont.--business001 .card__inner--img img.water2 {
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img img.water1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1.25);
    left: clamp(0rem, -4.267rem + 6.89vw, 4rem);
    width: clamp(22rem, 12.133rem + 15.93vw, 31.25rem);
  }
  .business__cont.--business001 .card__inner--img img.water2 {
    top: clamp(21rem, 15.666rem + 8.61vw, 26rem);
    left: clamp(6rem, -5.734rem + 18.95vw, 17rem);
    width: clamp(15rem, 9.666rem + 8.61vw, 20rem);
  }
  .business__cont.--business001 .card__inner--img img.weather1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1.25);
    left: 0;
    width: 800px;
    border-radius: 0 0.75rem 0.75rem 0;
  }
  .business__cont.--business001 .card__inner--img img.overseas1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1.25);
    right: 0;
    width: 800px;
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business001 .eco_road--img {
    --ecoimg: clamp(18.5rem, 4.632rem + 22.39vw, 31.5rem);
    padding-left: calc((5rem + (1vw - 0.2rem) * 2) * 2);
  }
  .business__cont.--business001 .eco_road--img div {
    position: relative;
    max-width: 1200px;
    width: 100%;
    margin: calc(5rem + (1vw - 0.2rem) * 2) auto 0;
    height: calc(var(--ecoimg) * 0.85);
  }
  .business__cont.--business001 .eco_road--img div img {
    position: absolute;
    width: 38%;
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .eco_road--img div img.eco_road3 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -0.5);
    left: 0;
  }
  .business__cont.--business001 .eco_road--img div img.eco_road4 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -0.1);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
  }
  .business__cont.--business001 .eco_road--img div img.eco_road5 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    right: 0;
  }
}
@media screen and (max-width: 991.98px) {
  .business__cont.--business001 .heading-img {
    display: none;
  }
  .business__cont.--business001 .card__inner--img {
    position: relative;
    margin-left: calc(var(--mp15) * -1);
    margin-right: calc(var(--mp15) * -1);
  }
  .business__cont.--business001 .card__inner--img.--sp__marin {
    height: 10rem;
    height: clamp(10rem, 0.222rem + 46.01vw, 28.75rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__marin img.marin1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    right: 0;
    width: 65%;
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__marin img.marin2 {
    top: 2.5rem;
    top: clamp(2.5rem, -1.411rem + 18.4vw, 10rem);
    left: var(--mp15);
    width: 40%;
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__non_native {
    height: 18rem;
    height: clamp(18rem, 7.831rem + 47.85vw, 37.5rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__non_native img.non_native1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    left: 0;
    width: 75%;
    border-radius: 0 0.75rem 0.75rem 0;
  }
  .business__cont.--business001 .card__inner--img.--sp__non_native img.non_native2 {
    top: 4rem;
    top: clamp(4rem, -2.258rem + 29.45vw, 16rem);
    left: 14.5rem;
    left: clamp(14.5rem, -0.101rem + 68.71vw, 42.5rem);
    width: 6rem;
    width: clamp(6rem, 2.871rem + 14.72vw, 12rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__non_native img.non_native3 {
    top: 11rem;
    top: clamp(11rem, 0.049rem + 51.53vw, 32rem);
    left: 9rem;
    left: clamp(9rem, -3.515rem + 58.9vw, 33rem);
    width: 9rem;
    width: clamp(9rem, 7.436rem + 7.36vw, 12rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__greening {
    height: 18rem;
    height: clamp(18rem, 11.742rem + 29.45vw, 30rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__greening img.greening2, .business__cont.--business001 .card__inner--img.--sp__greening img.greening3, .business__cont.--business001 .card__inner--img.--sp__greening img.greening4 {
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__greening img.greening2, .business__cont.--business001 .card__inner--img.--sp__greening img.greening3, .business__cont.--business001 .card__inner--img.--sp__greening img.greening4 {
    width: 7rem;
    width: clamp(7rem, 5.436rem + 7.36vw, 10rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__greening img.greening1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    right: 0;
    width: 12.5rem;
    width: clamp(12.5rem, 2.331rem + 47.85vw, 32rem);
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__greening img.greening2 {
    top: 0;
    left: 0.25rem;
    left: clamp(0.25rem, -5.877rem + 28.83vw, 12rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__greening img.greening3 {
    top: 5rem;
    top: clamp(5rem, 2.914rem + 9.82vw, 9rem);
    left: 4rem;
    left: clamp(4rem, -4.865rem + 41.72vw, 21rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__greening img.greening4 {
    top: 11rem;
    top: clamp(11rem, 7.35rem + 17.18vw, 18rem);
    left: 2rem;
    left: clamp(2rem, -4.779rem + 31.9vw, 15rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__eco_road {
    height: 13.5rem;
    height: clamp(13.5rem, 1.767rem + 55.21vw, 36rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__eco_road img.eco_road1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    left: 0;
    width: 75%;
    border-radius: 0 0.75rem 0.75rem 0;
  }
  .business__cont.--business001 .card__inner--img.--sp__eco_road img.eco_road2 {
    top: clamp(5rem, 0.307rem + 22.09vw, 14rem);
    right: var(--mp25);
    width: 40%;
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__water {
    height: 15rem;
    height: clamp(15rem, 8.742rem + 29.45vw, 27rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__water img.water1, .business__cont.--business001 .card__inner--img.--sp__water img.water2 {
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__water img.water1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    right: var(--mp15);
    width: 14rem;
    width: clamp(14rem, 8.264rem + 26.99vw, 25rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__water img.water2 {
    top: 8.75rem;
    top: clamp(8.75rem, 8.098rem + 3.07vw, 10rem);
    left: 2rem;
    left: clamp(2rem, -6.344rem + 39.26vw, 18rem);
    width: 10rem;
    width: clamp(10rem, 5.437rem + 21.47vw, 18.75rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__weather {
    height: 11.5rem;
    height: clamp(11.5rem, 4.982rem + 30.67vw, 24rem);
  }
  .business__cont.--business001 .card__inner--img.--sp__weather img.weather1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    width: 16rem;
    width: clamp(16rem, 7.135rem + 41.72vw, 33rem);
    right: 0;
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business001 .card__inner--img.--sp__overseas {
    height: 7rem;
    height: calc(clamp(16rem, 7.135rem + 41.72vw, 33rem) * 0.75 - (5rem + (1vw - 0.2rem) * 2));
  }
  .business__cont.--business001 .card__inner--img.--sp__overseas img.overseas1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    width: 16rem;
    width: clamp(16rem, 7.135rem + 41.72vw, 33rem);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .eco_road--img div {
    position: relative;
    height: 25rem;
    height: clamp(25rem, 16.135rem + 41.72vw, 42rem);
  }
  .business__cont.--business001 .eco_road--img div img {
    position: absolute;
    width: 13rem;
    width: clamp(13rem, 7.264rem + 26.99vw, 24rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business001 .eco_road--img div img.eco_road3 {
    top: 0;
    left: 1rem;
    left: clamp(1rem, -2.65rem + 17.18vw, 8rem);
  }
  .business__cont.--business001 .eco_road--img div img.eco_road4 {
    top: 3.75rem;
    top: clamp(3.75rem, 3.359rem + 1.84vw, 4.5rem);
    left: 8.5rem;
    left: clamp(8.5rem, -2.712rem + 52.76vw, 30rem);
  }
  .business__cont.--business001 .eco_road--img div img.eco_road5 {
    top: 12.5rem;
    top: clamp(12.5rem, 8.328rem + 19.63vw, 20.5rem);
    left: 3.75rem;
    left: clamp(3.75rem, -1.465rem + 24.54vw, 13.75rem);
  }
}
.business__cont.--business002 .tit {
  display: grid;
  row-gap: 1.25rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.business__cont.--business002 .heading-img img {
  border-radius: 0.75rem;
}
.business__cont.--business002 .card__inner.--gridcol {
  display: grid;
  row-gap: var(--mp35);
  align-items: start;
}
.business__cont.--business002 .card__inner.--gridcol .col {
  display: grid;
  row-gap: 1rem;
  row-gap: clamp(1rem, 0.9rem + 0.5vw, 1.5rem);
}
.business__cont.--business002 .card__inner.--gridcol .col img {
  border-radius: 0.75rem;
}
.business__cont.--business002 .masonry__col {
  background-color: white;
}
.business__cont.--business002 .masonry__col__inner {
  display: grid;
  row-gap: 1rem;
  row-gap: clamp(1rem, 0.9rem + 0.5vw, 1.5rem);
}
@media screen and (min-width: 992px) {
  .business__cont.--business002 .business__cont__heading {
    grid-template-columns: 1fr 40%;
    column-gap: var(--mp35);
    align-items: start;
  }
  .business__cont.--business002 .card__inner.--gridcol {
    grid-template-columns: 1fr 1fr;
    column-gap: var(--mp35);
  }
  .business__cont.--business002 .masonry {
    column-count: 2;
    column-gap: var(--mp35);
  }
  .business__cont.--business002 .masonry__col {
    display: inline-block;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
    margin-top: calc((5rem + (1vw - 0.2rem) * 2) * 0.75);
    border-radius: 0.75rem;
  }
  .business__cont.--business002 .masonry__col:first-child {
    margin-top: 0;
  }
  .business__cont.--business002 .masonry__col:last-child {
    margin-bottom: calc((5rem + (1vw - 0.2rem) * 2) * 0.75);
  }
  .business__cont.--business002 .masonry__col img {
    border-radius: 0.75rem 0.75rem 0 0;
  }
  .business__cont.--business002 .masonry__col__inner {
    padding: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
}
@media screen and (max-width: 991.98px) {
  .business__cont.--business002 .heading-img {
    display: flex;
    justify-content: end;
    margin-top: -2.5rem;
    margin-top: calc((5rem + (1vw - 0.2rem) * 2) * -0.5);
  }
  .business__cont.--business002 .heading-img img {
    width: 80%;
  }
  .business__cont.--business002 .masonry {
    display: grid;
    row-gap: 5rem;
    row-gap: calc(5rem + (1vw - 0.2rem) * 2);
  }
  .business__cont.--business002 .masonry__col__inner {
    padding: var(--mp35) var(--mp15);
  }
}
.business__cont.--business003 .tit {
  display: grid;
  row-gap: 1.25rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.business__cont.--business003 .card__inner {
  display: grid;
  align-items: start;
  row-gap: var(--mp25);
}
.business__cont.--business003 .card__inner .desc {
  display: grid;
  row-gap: var(--mp15);
}
.business__cont.--business003 .card__inner--img {
  position: relative;
  overflow-x: clip;
}
.business__cont.--business003 .card__inner--img img {
  position: absolute;
}
@media screen and (min-width: 992px) {
  .business__cont.--business003 .--bgLeft .card__heading {
    margin-left: calc((5rem + (1vw - 0.2rem) * 2) * 2 - clamp(1rem, 0.57rem + 2.03vw, 3rem)) !important;
  }
  .business__cont.--business003 .--bgLeft .card__inner {
    grid-template-columns: 1fr 40%;
  }
  .business__cont.--business003 .--bgRight .card__inner {
    grid-template-columns: 40% 1fr;
  }
  .business__cont.--business003 .card__inner {
    column-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
  .business__cont.--business003 .card__inner--img.--sp__water_nalysis {
    margin-right: calc((5rem + (1vw - 0.2rem) * 2) * -2) !important;
  }
  .business__cont.--business003 .card__inner--img img.water_nalysis1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -2.5);
    right: 0;
    width: clamp(26rem, 11.066rem + 24.11vw, 40rem);
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business003 .card__inner--img img.water_nalysis2 {
    top: clamp(23rem, 8.866rem + 22.82vw, 36.25rem);
    left: 1rem;
    width: clamp(15rem, 4.333rem + 17.22vw, 25rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img img.water_nalysis3 {
    top: clamp(32.5rem, 14.365rem + 29.28vw, 49.5rem);
    left: clamp(10rem, 0.666rem + 15.07vw, 18.75rem);
    width: clamp(15rem, 4.333rem + 17.22vw, 25rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img img.bottom_sediment1 {
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img img.waste1 {
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img img.soil_pollution1 {
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img img.analysis_etc1 {
    border-radius: 0.75rem;
  }
}
@media screen and (max-width: 991.98px) {
  .business__cont.--business003 .card__inner--img {
    position: relative;
    margin-left: calc(var(--mp15) * -1);
    margin-right: calc(var(--mp15) * -1);
  }
  .business__cont.--business003 .card__inner--img.--sp__water_nalysis {
    height: 28rem;
    height: clamp(28rem, 20.439rem + 35.58vw, 42.5rem);
  }
  .business__cont.--business003 .card__inner--img.--sp__water_nalysis img.water_nalysis1 {
    top: 0;
    right: 0;
    width: 15rem;
    width: clamp(15rem, 8.221rem + 31.9vw, 28rem);
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business003 .card__inner--img.--sp__water_nalysis img.water_nalysis2 {
    top: 16rem;
    top: clamp(16rem, 14.566rem + 6.75vw, 18.75rem);
    left: 0.75rem;
    left: clamp(0.75rem, -2.77rem + 16.56vw, 7.5rem);
    width: 10rem;
    width: clamp(10rem, 5.437rem + 21.47vw, 18.75rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img.--sp__water_nalysis img.water_nalysis3 {
    top: 21.25rem;
    top: clamp(21.25rem, 16.296rem + 23.31vw, 30.75rem);
    left: 3rem;
    left: clamp(3rem, -4.822rem + 36.81vw, 18rem);
    width: 10rem;
    width: clamp(10rem, 5.437rem + 21.47vw, 18.75rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img.--sp__bottom_sediment {
    height: 9.5rem;
    height: calc(clamp(16rem, 7.135rem + 41.72vw, 33rem) * 0.75 - (5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
  .business__cont.--business003 .card__inner--img.--sp__bottom_sediment img.bottom_sediment1 {
    top: 0;
    width: 16rem;
    width: clamp(16rem, 7.135rem + 41.72vw, 33rem);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img.--sp__waste {
    height: 9.5rem;
    height: calc(clamp(16rem, 7.135rem + 41.72vw, 33rem) * 0.75 - (5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
  .business__cont.--business003 .card__inner--img.--sp__waste img.waste1 {
    top: 0;
    width: 16rem;
    width: clamp(16rem, 7.135rem + 41.72vw, 33rem);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img.--sp__soil_pollution {
    height: 9.5rem;
    height: calc(clamp(16rem, 7.135rem + 41.72vw, 33rem) * 0.75 - (5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
  .business__cont.--business003 .card__inner--img.--sp__soil_pollution img.soil_pollution1 {
    top: 0;
    width: 16rem;
    width: clamp(16rem, 7.135rem + 41.72vw, 33rem);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 0.75rem;
  }
  .business__cont.--business003 .card__inner--img.--sp__analysis_etc {
    height: 9.5rem;
    height: calc(clamp(16rem, 7.135rem + 41.72vw, 33rem) * 0.75 - (5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
  .business__cont.--business003 .card__inner--img.--sp__analysis_etc img.analysis_etc1 {
    top: 0;
    width: 16rem;
    width: clamp(16rem, 7.135rem + 41.72vw, 33rem);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 0.75rem;
  }
}
.business__cont.--business004 .tit {
  display: grid;
  row-gap: 1.25rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.business__cont.--business004 .card__inner {
  display: grid;
  align-items: start;
  row-gap: var(--mp25);
}
.business__cont.--business004 .card__inner .desc {
  display: grid;
  row-gap: var(--mp15);
}
.business__cont.--business004 .card__inner--img {
  position: relative;
  overflow-x: clip;
}
.business__cont.--business004 .card__inner--img img {
  position: absolute;
}
.business__cont.--business004 .business_plan {
  display: grid;
  row-gap: calc(5rem + (1vw - 0.2rem) * 2);
  padding-top: calc(5rem + (1vw - 0.2rem) * 2);
  padding-bottom: calc(5rem + (1vw - 0.2rem) * 2);
  background-color: #E3E3E3;
}
.business__cont.--business004 .business_plan .splide .splide__slide img {
  border-radius: 0.75rem;
}
.business__cont.--business004 .business_plan--img {
  position: relative;
  width: 100%;
  margin: -1.5rem auto 0;
  padding-left: var(--mp25);
  padding-right: var(--mp25);
}
.business__cont.--business004 .business_lineup {
  display: grid;
  row-gap: var(--mp25);
}
.business__cont.--business004 .business_lineup .col {
  padding: var(--mp15);
  background-color: white;
  border-radius: 0.75rem;
  box-shadow: 0 3px 10px 0 rgba(36, 36, 36, 0.25);
}
.business__cont.--business004 .business_lineup .col h3 {
  margin-bottom: 0.5rem;
  border-bottom: 1px solid #E3E3E3;
}
.business__cont.--business004 .relevant_laws {
  padding: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
  background-color: #30A038;
  border-radius: 0.75rem;
}
.business__cont.--business004 .relevant_laws .inner {
  display: grid;
  align-items: start;
}
.business__cont.--business004 .relevant_laws .inner .col {
  display: grid;
  row-gap: 1rem;
  align-items: start;
}
.business__cont.--business004 .relevant_laws .inner .col .tit {
  width: 80%;
  margin: 0 auto;
}
.business__cont.--business004 .relevant_laws .inner .col p {
  color: white;
}
@media screen and (min-width: 992px) {
  .business__cont.--business004 .card__inner {
    grid-template-columns: 1fr 40%;
    column-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
  .business__cont.--business004 .card__inner--img.--sp__env_assess {
    margin-right: calc((5rem + (1vw - 0.2rem) * 2) * -2) !important;
  }
  .business__cont.--business004 .card__inner--img img.env_assess1 {
    top: calc(clamp(10rem, 1.999rem + 12.92vw, 17.5rem) * -1);
    right: 0;
    width: 100%;
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business004 .card__inner--img img.env_assess2 {
    top: clamp(8.25rem, -0.284rem + 13.78vw, 16.25rem);
    left: clamp(5rem, -18.468rem + 37.89vw, 27rem);
    width: clamp(16.25rem, 6.916rem + 15.07vw, 25rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business004 .business_plan--img {
    max-width: 992px;
  }
  .business__cont.--business004 .business_lineup {
    grid-template-columns: repeat(3, 1fr);
    column-gap: var(--mp25);
  }
  .business__cont.--business004 .relevant_laws .inner {
    grid-template-columns: repeat(3, 1fr);
    column-gap: var(--mp15);
  }
  .business__cont.--business004 .relevant_laws .inner .col {
    padding-right: var(--mp15);
    border-right: 1px solid white;
  }
  .business__cont.--business004 .relevant_laws .inner .col:last-child {
    padding-right: 0;
    border-right: none;
  }
}
@media screen and (max-width: 991.98px) {
  .business__cont.--business004 .card__inner--img {
    position: relative;
    margin-left: calc(var(--mp15) * -1);
    margin-right: calc(var(--mp15) * -1);
  }
  .business__cont.--business004 .card__inner--img.--sp__env_assess {
    height: 12.5rem;
    height: clamp(12.5rem, 2.071rem + 49.08vw, 32.5rem);
  }
  .business__cont.--business004 .card__inner--img.--sp__env_assess img.env_assess1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    width: 75%;
    right: 0;
    border-radius: 0.75rem 0 0 0.75rem;
  }
  .business__cont.--business004 .card__inner--img.--sp__env_assess img.env_assess2 {
    top: 5rem;
    top: clamp(5rem, -1.518rem + 30.67vw, 17.5rem);
    left: var(--mp15);
    width: 40%;
    border-radius: 0.75rem;
  }
  .business__cont.--business004 .business_plan--img {
    max-width: 576px;
  }
  .business__cont.--business004 .relevant_laws {
    max-width: 576px;
    margin: 0 auto;
  }
  .business__cont.--business004 .relevant_laws .inner {
    row-gap: var(--mp15);
  }
  .business__cont.--business004 .relevant_laws .inner .col {
    padding-bottom: var(--mp15);
    border-bottom: 1px solid white;
  }
  .business__cont.--business004 .relevant_laws .inner .col:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }
}
.business__cont.--business005 .tit {
  display: grid;
  row-gap: 1.25rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.business__cont.--business005 .card__inner {
  display: grid;
  align-items: start;
  row-gap: var(--mp25);
}
.business__cont.--business005 .card__inner .desc {
  display: grid;
  row-gap: var(--mp15);
}
.business__cont.--business005 .card__inner--img {
  position: relative;
  overflow-x: clip;
}
.business__cont.--business005 .card__inner--img img {
  position: absolute;
}
.business__cont.--business005 .biostimulation {
  padding-top: 5rem;
  padding-top: calc(5rem + (1vw - 0.2rem) * 2);
  padding-bottom: 5rem;
  padding-bottom: calc(5rem + (1vw - 0.2rem) * 2);
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
}
.business__cont.--business005 .biostimulation--heading {
  text-align: center;
}
.business__cont.--business005 .biostimulation--heading h2 {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1.089rem + 0.76vw, 2rem);
}
.business__cont.--business005 .biostimulation--heading span {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  letter-spacing: 0.1rem;
}
.business__cont.--business005 .biostimulation--img {
  display: grid;
}
.business__cont.--business005 .biostimulation--img > div {
  display: grid;
  row-gap: 1rem;
  text-align: center;
}
.business__cont.--business005 .biostimulation--img > div h3 {
  font-size: 1rem;
  font-size: clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
}
.business__cont.--business005 .biostimulation--img > div p {
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.business__cont.--business005 .biostimulation--summary {
  padding: var(--mp25) var(--mp15);
  color: white;
  background-color: #30A038;
  border-radius: 5rem;
}
@media screen and (min-width: 992px) {
  .business__cont.--business005 .card__inner {
    grid-template-columns: 40% 1fr;
    column-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.5);
  }
  .business__cont.--business005 .card__inner--img.--sp__research_develop {
    margin-left: calc((5rem + (1vw - 0.2rem) * 2) * -2) !important;
  }
  .business__cont.--business005 .card__inner--img img.research_develop1 {
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1.5);
    left: 0;
    width: 44rem;
    border-radius: 0 0.75rem 0.75rem 0;
  }
  .business__cont.--business005 .card__inner--img img.research_develop2 {
    top: clamp(9.5rem, 0.966rem + 13.78vw, 17.5rem);
    right: clamp(1.25rem, 2.583rem - 2.15vw, 0rem);
    width: clamp(12.5rem, 9.833rem + 4.31vw, 15rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business005 .card__inner--img img.research_develop3 {
    top: clamp(17.5rem, 13.233rem + 6.89vw, 21.5rem);
    right: clamp(5rem, -1.667rem + 10.76vw, 11.25rem);
    width: clamp(16.25rem, 13.583rem + 4.31vw, 18.75rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business005 .biostimulation {
    padding-right: calc((5rem + (1vw - 0.2rem) * 2) * 2);
    padding-left: calc((5rem + (1vw - 0.2rem) * 2) * 4);
  }
  .business__cont.--business005 .biostimulation--img {
    grid-template-columns: 1fr 1fr 1.167fr;
    column-gap: var(--mp25);
  }
}
@media screen and (max-width: 991.98px) {
  .business__cont.--business005 .card__inner--img {
    position: relative;
    margin-left: calc(var(--mp15) * -1);
    margin-right: calc(var(--mp15) * -1);
  }
  .business__cont.--business005 .card__inner--img.--sp__research_develop {
    height: 17.5rem;
    height: clamp(17.5rem, 8.896rem + 40.49vw, 34rem);
  }
  .business__cont.--business005 .card__inner--img.--sp__research_develop img.research_develop1 {
    top: -5rem;
    top: calc((5rem + (1vw - 0.2rem) * 2) * -1);
    left: 0;
    width: 18.75rem;
    width: clamp(18.75rem, 7.669rem + 52.15vw, 40rem);
    border-radius: 0 0.75rem 0.75rem 0;
  }
  .business__cont.--business005 .card__inner--img.--sp__research_develop img.research_develop2 {
    top: 7.5rem;
    top: clamp(7.5rem, 4.371rem + 14.72vw, 13.5rem);
    left: 12.5rem;
    left: clamp(12.5rem, -0.537rem + 61.35vw, 37.5rem);
    width: 9rem;
    width: clamp(9rem, 5.871rem + 14.72vw, 15rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business005 .card__inner--img.--sp__research_develop img.research_develop3 {
    top: 10rem;
    top: clamp(10rem, 3.742rem + 29.45vw, 22rem);
    left: 4rem;
    left: clamp(4rem, -6.951rem + 51.53vw, 25rem);
    width: 10.5rem;
    width: clamp(10.5rem, 6.589rem + 18.4vw, 18rem);
    border-radius: 0.75rem;
  }
  .business__cont.--business005 .biostimulation {
    padding-right: var(--mp25);
    padding-left: var(--mp25);
  }
  .business__cont.--business005 .biostimulation--img {
    row-gap: var(--mp25);
    max-width: 575.98px;
    width: 100%;
    margin: 0 auto;
  }
}
.business__cont.--business006 .card__inner {
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.business__cont.--business006 .soil {
  display: grid;
  align-items: start;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.business__cont.--business006 .soil .desc {
  display: grid;
  row-gap: 2.5rem;
  row-gap: calc((5rem + (1vw - 0.2rem) * 2) * 0.25);
}
.business__cont.--business006 .soil--img {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
  column-gap: var(--mp25);
  grid-auto-flow: row;
  grid-template-areas: "soil1 soil1" "soil1 soil1" "soil2 soil3";
}
.business__cont.--business006 .soil--img img {
  border-radius: 0.75rem;
}
.business__cont.--business006 .soil .soil1 {
  grid-area: soil1;
}
.business__cont.--business006 .soil .soil2 {
  grid-area: soil2;
}
.business__cont.--business006 .soil .soil3 {
  grid-area: soil3;
}
.business__cont.--business006 .responsive_scroll table {
  width: 100%;
}
.business__cont.--business006 .responsive_scroll table tr {
  border-bottom: 1px solid #E3E3E3;
}
.business__cont.--business006 .responsive_scroll table tr:nth-child(even) {
  background-color: #EFEFEF;
}
.business__cont.--business006 .responsive_scroll table tr:last-child {
  border-bottom: none;
}
.business__cont.--business006 .responsive_scroll table th,
.business__cont.--business006 .responsive_scroll table td {
  padding: 0.4rem 0.8rem;
  padding: clamp(0.4rem, 0.314rem + 0.41vw, 0.8rem) clamp(0.8rem, 0.757rem + 0.2vw, 1rem);
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
}
.business__cont.--business006 .responsive_scroll table th {
  font-weight: normal;
}
.business__cont.--business006 .responsive_scroll table.table1 th {
  width: 15rem;
}
.business__cont.--business006 .responsive_scroll table.table2 td {
  text-align: center;
  border-left: 1px dotted #999999;
}
.business__cont.--business006 .responsive_scroll .--white {
  color: #242424 !important;
}
@media screen and (min-width: 992px) {
  .business__cont.--business006 .soil {
    grid-template-columns: 1fr 40%;
    column-gap: var(--mp35);
  }
}