@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
/*
  Josh's Custom CSS Reset
  https://www.joshwcomeau.com/css/custom-css-reset/
*/
/* 1. Use a more-intuitive box-sizing model */
*, *::before, *::after {
  box-sizing: border-box;
}

/* 2. Remove default margin */
*:not(dialog) {
  margin: 0;
}

/* 3. Enable keyword animations */
@media (prefers-reduced-motion: no-preference) {
  html {
    interpolate-size: allow-keywords;
  }
}
body {
  /* 4. Add accessible line-height */
  line-height: 1.5;
  /* 5. Improve text rendering */
  -webkit-font-smoothing: antialiased;
}

/* 6. Improve media defaults */
img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

/* 7. Inherit fonts for form controls */
input, button, textarea, select {
  font: inherit;
}

/* 8. Avoid text overflows */
p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

/* 9. Improve line wrapping */
p {
  text-wrap: pretty;
}

h1, h2, h3, h4, h5, h6 {
  text-wrap: balance;
}

/*
  10. Create a root stacking context
*/
#root, #__next {
  isolation: isolate;
}

/**
* @license
*
* Font Family: Chillax
* Designed by: Manushi Parikh
* URL: https://www.fontshare.com/fonts/chillax
* © 2026 Indian Type Foundry
*
* Chillax Regular 
* Chillax Medium 
* Chillax Semibold 

*
*/
@font-face {
  font-family: "Chillax-Regular";
  src: url("../fonts/chillax/Chillax-Regular.woff2") format("woff2"), url("../fonts/chillax/Chillax-Regular.woff") format("woff"), url("../fonts/chillax/Chillax-Regular.ttf") format("truetype");
  font-weight: 400;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Chillax-Medium";
  src: url("../fonts/chillax/Chillax-Medium.woff2") format("woff2"), url("../fonts/chillax/Chillax-Medium.woff") format("woff"), url("../fonts/chillax/Chillax-Medium.ttf") format("truetype");
  font-weight: 500;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Chillax-Semibold";
  src: url("../fonts/chillax/Chillax-Semibold.woff2") format("woff2"), url("../fonts/chillax/Chillax-Semibold.woff") format("woff"), url("../fonts/chillax/Chillax-Semibold.ttf") format("truetype");
  font-weight: 600;
  font-display: swap;
  font-style: normal;
}
/*------------------------------
BASE
-------------------------------*/
html {
  scroll-padding-top: 100px;
  scrollbar-gutter: stable;
}

html:has(:modal) {
  overflow: clip;
  scrollbar-gutter: auto;
}

@media screen and (min-width: 768px) and (max-width: 999px) {
  html {
    scroll-padding-top: 60px;
  }
  html:has(.header.is_open) {
    overflow: clip;
    scrollbar-gutter: auto;
  }
}
@media screen and (max-width: 767px) {
  html {
    scroll-padding-top: 60px;
    font-size: 87.5%;
  }
  html:has(.header.is_open) {
    overflow: clip;
    scrollbar-gutter: auto;
  }
}
body {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
  background: #fff url("../images/bg_5.webp") repeat-y;
  background-size: 100% auto;
  background-attachment: fixed;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", sans-serif;
  color: #4D4D4D;
  font-optical-sizing: auto;
  font-size: 100%;
  line-height: 1.7;
  font-weight: 400;
}

body:has(:modal) {
  overflow: auto;
  scrollbar-gutter: stable;
}

@media screen and (min-width: 768px) and (max-width: 999px) {
  body:has(.header.is_open) {
    overflow: auto;
    scrollbar-gutter: stable;
  }
}
@media screen and (max-width: 767px) {
  body {
    background-size: 140% auto;
  }
  body:has(.header.is_open) {
    overflow: auto;
    scrollbar-gutter: stable;
  }
}
/* */
h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  text-wrap: initial;
}

p {
  text-wrap: initial;
}

*:focus-visible {
  outline: 2px solid #008fcc;
  outline-offset: 0;
}

a {
  color: #30A338;
  backface-visibility: hidden;
}

figure {
  line-height: 0;
}

figcaption {
  line-height: 1.5;
}

img {
  height: auto;
}

/* display -------------*/
/* pc/sp */
.for-pc {
  display: inherit;
}

.for-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .for-pc {
    display: none;
  }
  .for-sp {
    display: inherit;
  }
}
/* margin -------------*/
.mt--100 {
  margin-top: -6.25rem !important;
}

.mb--100 {
  margin-bottom: -6.25rem !important;
}

.mt--90 {
  margin-top: -5.625rem !important;
}

.mb--90 {
  margin-bottom: -5.625rem !important;
}

.mt--80 {
  margin-top: -5rem !important;
}

.mb--80 {
  margin-bottom: -5rem !important;
}

.mt--70 {
  margin-top: -4.375rem !important;
}

.mb--70 {
  margin-bottom: -4.375rem !important;
}

.mt--60 {
  margin-top: -3.75rem !important;
}

.mb--60 {
  margin-bottom: -3.75rem !important;
}

.mt--50 {
  margin-top: -3.125rem !important;
}

.mb--50 {
  margin-bottom: -3.125rem !important;
}

.mt--40 {
  margin-top: -2.5rem !important;
}

.mb--40 {
  margin-bottom: -2.5rem !important;
}

.mt--30 {
  margin-top: -1.875rem !important;
}

.mb--30 {
  margin-bottom: -1.875rem !important;
}

.mt--20 {
  margin-top: -1.25rem !important;
}

.mb--20 {
  margin-bottom: -1.25rem !important;
}

.mt--10 {
  margin-top: -0.625rem !important;
}

.mb--10 {
  margin-bottom: -0.625rem !important;
}

.mt-0 {
  margin-top: 0rem !important;
}

.mb-0 {
  margin-bottom: 0rem !important;
}

.mt-10 {
  margin-top: 0.625rem !important;
}

.mb-10 {
  margin-bottom: 0.625rem !important;
}

.mt-20 {
  margin-top: 1.25rem !important;
}

.mb-20 {
  margin-bottom: 1.25rem !important;
}

.mt-30 {
  margin-top: 1.875rem !important;
}

.mb-30 {
  margin-bottom: 1.875rem !important;
}

.mt-40 {
  margin-top: 2.5rem !important;
}

.mb-40 {
  margin-bottom: 2.5rem !important;
}

.mt-50 {
  margin-top: 3.125rem !important;
}

.mb-50 {
  margin-bottom: 3.125rem !important;
}

.mt-60 {
  margin-top: 3.75rem !important;
}

.mb-60 {
  margin-bottom: 3.75rem !important;
}

.mt-70 {
  margin-top: 4.375rem !important;
}

.mb-70 {
  margin-bottom: 4.375rem !important;
}

.mt-80 {
  margin-top: 5rem !important;
}

.mb-80 {
  margin-bottom: 5rem !important;
}

.mt-90 {
  margin-top: 5.625rem !important;
}

.mb-90 {
  margin-bottom: 5.625rem !important;
}

.mt-100 {
  margin-top: 6.25rem !important;
}

.mb-100 {
  margin-bottom: 6.25rem !important;
}

.mt--10em {
  margin-top: -10em !important;
}

.mb--10em {
  margin-bottom: -10em !important;
}

.mt--9em {
  margin-top: -9em !important;
}

.mb--9em {
  margin-bottom: -9em !important;
}

.mt--8em {
  margin-top: -8em !important;
}

.mb--8em {
  margin-bottom: -8em !important;
}

.mt--7em {
  margin-top: -7em !important;
}

.mb--7em {
  margin-bottom: -7em !important;
}

.mt--6em {
  margin-top: -6em !important;
}

.mb--6em {
  margin-bottom: -6em !important;
}

.mt--5em {
  margin-top: -5em !important;
}

.mb--5em {
  margin-bottom: -5em !important;
}

.mt--4em {
  margin-top: -4em !important;
}

.mb--4em {
  margin-bottom: -4em !important;
}

.mt--3em {
  margin-top: -3em !important;
}

.mb--3em {
  margin-bottom: -3em !important;
}

.mt--2em {
  margin-top: -2em !important;
}

.mb--2em {
  margin-bottom: -2em !important;
}

.mt--1em {
  margin-top: -1em !important;
}

.mb--1em {
  margin-bottom: -1em !important;
}

.mt-0em {
  margin-top: 0em !important;
}

.mb-0em {
  margin-bottom: 0em !important;
}

.mt-1em {
  margin-top: 1em !important;
}

.mb-1em {
  margin-bottom: 1em !important;
}

.mt-2em {
  margin-top: 2em !important;
}

.mb-2em {
  margin-bottom: 2em !important;
}

.mt-3em {
  margin-top: 3em !important;
}

.mb-3em {
  margin-bottom: 3em !important;
}

.mt-4em {
  margin-top: 4em !important;
}

.mb-4em {
  margin-bottom: 4em !important;
}

.mt-5em {
  margin-top: 5em !important;
}

.mb-5em {
  margin-bottom: 5em !important;
}

.mt-6em {
  margin-top: 6em !important;
}

.mb-6em {
  margin-bottom: 6em !important;
}

.mt-7em {
  margin-top: 7em !important;
}

.mb-7em {
  margin-bottom: 7em !important;
}

.mt-8em {
  margin-top: 8em !important;
}

.mb-8em {
  margin-bottom: 8em !important;
}

.mt-9em {
  margin-top: 9em !important;
}

.mb-9em {
  margin-bottom: 9em !important;
}

.mt-10em {
  margin-top: 10em !important;
}

.mb-10em {
  margin-bottom: 10em !important;
}

/* padding -------------*/
.pt-0 {
  padding-top: 0rem !important;
}

.pb-0 {
  padding-bottom: 0rem !important;
}

.pt-10 {
  padding-top: 0.625rem !important;
}

.pb-10 {
  padding-bottom: 0.625rem !important;
}

.pt-20 {
  padding-top: 1.25rem !important;
}

.pb-20 {
  padding-bottom: 1.25rem !important;
}

.pt-30 {
  padding-top: 1.875rem !important;
}

.pb-30 {
  padding-bottom: 1.875rem !important;
}

.pt-40 {
  padding-top: 2.5rem !important;
}

.pb-40 {
  padding-bottom: 2.5rem !important;
}

.pt-50 {
  padding-top: 3.125rem !important;
}

.pb-50 {
  padding-bottom: 3.125rem !important;
}

.pt-60 {
  padding-top: 3.75rem !important;
}

.pb-60 {
  padding-bottom: 3.75rem !important;
}

.pt-70 {
  padding-top: 4.375rem !important;
}

.pb-70 {
  padding-bottom: 4.375rem !important;
}

.pt-80 {
  padding-top: 5rem !important;
}

.pb-80 {
  padding-bottom: 5rem !important;
}

.pt-90 {
  padding-top: 5.625rem !important;
}

.pb-90 {
  padding-bottom: 5.625rem !important;
}

.pt-100 {
  padding-top: 6.25rem !important;
}

.pb-100 {
  padding-bottom: 6.25rem !important;
}

.pt-1em {
  padding-top: 1em !important;
}

.pb-1em {
  padding-bottom: 1em !important;
}

.pt-2em {
  padding-top: 2em !important;
}

.pb-2em {
  padding-bottom: 2em !important;
}

.pt-3em {
  padding-top: 3em !important;
}

.pb-3em {
  padding-bottom: 3em !important;
}

.pt-4em {
  padding-top: 4em !important;
}

.pb-4em {
  padding-bottom: 4em !important;
}

.pt-5em {
  padding-top: 5em !important;
}

.pb-5em {
  padding-bottom: 5em !important;
}

.pt-6em {
  padding-top: 6em !important;
}

.pb-6em {
  padding-bottom: 6em !important;
}

.pt-7em {
  padding-top: 7em !important;
}

.pb-7em {
  padding-bottom: 7em !important;
}

.pt-8em {
  padding-top: 8em !important;
}

.pb-8em {
  padding-bottom: 8em !important;
}

.pt-9em {
  padding-top: 9em !important;
}

.pb-9em {
  padding-bottom: 9em !important;
}

.pt-10em {
  padding-top: 10em !important;
}

.pb-10em {
  padding-bottom: 10em !important;
}

/* text -------------*/
/* color */
.txt-blk {
  color: #4D4D4D !important;
}

.txt-grn {
  color: #30A338 !important;
}

.txt-wht {
  color: #fff !important;
}

/* font size */
.txt-en-400 {
  font-family: "Chillax-Regular", sans-serif;
}

.txt-en-500 {
  font-family: "Chillax-Medium", sans-serif;
}

.txt-en-600 {
  font-family: "Chillax-Semibold", sans-serif;
}

/* font size */
.txt-xsmall {
  font-size: 0.75rem;
}

.txt-small {
  font-size: 0.8125rem;
}

.txt-middle {
  font-size: 0.9375rem;
}

.txt-large {
  font-size: 1.125rem;
}

.txt-xlarge {
  font-size: 1.375rem;
}

/* align */
.txt-left {
  text-align: left;
}

.txt-right {
  text-align: right;
}

.txt-center {
  text-align: center;
}

.txt-center_forpc {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .txt-center_forpc {
    text-align: left;
  }
}

figure.center {
  text-align: center;
}
@media screen and (max-width: 767px) {
  figure.center figcaption {
    text-align: left;
  }
}

/* font weight */
.txt-fwL {
  font-weight: 300 !important;
}

.txt-fwR {
  font-weight: 400 !important;
}

.txt-fwM {
  font-weight: 500 !important;
}

.txt-fwB {
  font-weight: 600 !important;
}

/* line height */
.lh-thin {
  line-height: 1.4;
}

.lh-2 {
  line-height: 2;
}

/* letter space */
.ls-0 {
  letter-spacing: 0 !important;
}

.ls-1 {
  letter-spacing: 1em !important;
}

.ls-_1 {
  letter-spacing: 0.1em !important;
}

.ls-_5 {
  letter-spacing: 0.5em !important;
}

/* indent */
.indent-1 {
  margin-left: 1em;
  text-indent: -1em;
}

.indent-2 {
  margin-left: 2em;
  text-indent: -2em;
}

.indent-23 {
  margin-left: 2.3em;
  text-indent: -2.3em;
}

.indent-25 {
  margin-left: 2.5em;
  text-indent: -2.5em;
}

/**/
.txt-asterisk {
  display: block;
  position: relative;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.6 !important;
}

#header {
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  height: 100px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  z-index: 50;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  #header {
    height: 60px;
  }
}
@media screen and (max-width: 767px) {
  #header {
    height: 60px;
  }
}

#header.is_fixed {
  position: fixed;
}

.header-inner {
  position: relative;
  display: flex;
  gap: 0 60px;
  align-items: center;
  justify-content: space-between;
  padding: 20px 60px;
}
.header-inner .header-logo {
  flex: none;
  position: relative;
  color: #4D4D4D;
  line-height: 0;
  z-index: 1;
  display: flex;
  align-items: flex-end;
  gap: 0 20px;
}
.header-inner .header-logo a {
  display: flex;
  align-items: flex-end;
  gap: 0 20px;
  color: currentColor;
  text-decoration: none;
}
.header-inner .header-logo a:hover, .header-inner .header-logo a:focus {
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
  text-underline-offset: 2px;
}
.header-inner .header-logo img, .header-inner .header-logo svg {
  width: 160px;
  height: auto;
}
.header-inner .header-logo .site-title {
  flex: none;
  position: relative;
  top: 0.27em;
  color: currentColor;
  text-box-trim: trim-both;
  font-family: "Chillax-Regular", sans-serif;
  font-size: 1.125rem;
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
}
.header-inner .gNav {
  position: relative;
}
.header-inner .gNav > ul {
  position: relative;
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(5, auto);
  gap: 20px 40px;
  color: #000;
  font-size: 0.75rem;
  line-height: 1.5;
  font-weight: 500;
}
.header-inner .gNav > ul > li {
  position: relative;
}
.header-inner .gNav > ul > li a {
  position: relative;
  color: currentColor;
  text-decoration: none;
}
.header-inner .gNav > ul > li a:hover, .header-inner .gNav > ul > li a:focus {
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
  text-underline-offset: 2px;
}
.header-inner .gNav > ul > li a {
  z-index: 1;
}
.header-inner .gNav > ul > li a:hover, .header-inner .gNav > ul > li:focus, .header-inner .gNav > ul > li .is_current {
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
  text-underline-offset: 4px;
}
.header-inner .gNav > ul ul.sub-menu {
  position: absolute;
  top: 40px;
  right: 50%;
  list-style: none;
  width: 18em;
  padding: 20px;
  margin: 0;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.2);
  transform: translateX(50%);
  z-index: 0;
  font-size: 0.75rem;
  font-weight: 500;
  display: flex;
  flex-direction: column;
  gap: 15px;
  visibility: hidden;
}
.header-inner .gNav > ul ul.sub-menu:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-left: 7.5px solid transparent;
  border-right: 7.5px solid transparent;
  border-bottom: 15px solid #fff;
  transform: translateY(-100%);
  z-index: 1;
}
.header-inner .gNav > ul ul.sub-menu:after {
  content: "";
  display: block;
  position: absolute;
  top: -25px;
  left: 0;
  margin: auto;
  width: 100%;
  height: 30px;
  background: rgba(255, 255, 255, 0);
  z-index: 0;
}
.header-inner .gNav > ul ul.sub-menu li {
  position: relative;
  z-index: 1;
}
.header-inner .gNav > ul ul.sub-menu a:hover, .header-inner .gNav > ul ul.sub-menu:focus, .header-inner .gNav > ul ul.sub-menu .is_current {
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
  text-underline-offset: 4px;
}
.header-inner .gNav > ul > li:has(.sub-menu):hover ul.sub-menu, .header-inner .gNav > ul > li:has(.sub-menu):focus-within ul.sub-menu {
  visibility: visible;
}
@media screen and (min-width: 1000px) and (max-width: 1199px) {
  .header-inner {
    padding: 20px 30px;
  }
  .header-inner .header-logo img, .header-inner .header-logo svg {
    width: 140px;
  }
  .header-inner .header-logo .site-title {
    font-size: 100%;
  }
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .header-inner {
    padding: 20px 60px 20px 30px;
  }
  .header-inner .header-logo img, .header-inner .header-logo svg {
    width: 140px;
  }
  .header-inner .header-logo .site-title {
    font-size: 0.86rem;
  }
  .header-inner .gNav > ul {
    gap: 1.5em 0;
    grid-template-columns: 1fr;
    color: #fff;
    font-size: 100%;
    font-weight: 700;
  }
  .header-inner .gNav > ul ul.sub-menu {
    position: relative;
    top: 0;
    right: 0;
    width: auto;
    padding: 0;
    margin: 1em 0 0 0;
    background: none;
    border-radius: 0;
    box-shadow: none;
    transform: none;
    z-index: 0;
    visibility: visible;
  }
  .header-inner .gNav > ul ul.sub-menu:before, .header-inner .gNav > ul ul.sub-menu:after {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .header-inner {
    padding: 15px 60px 15px 15px;
  }
  .header-inner .header-logo img, .header-inner .header-logo svg {
    width: 110px;
  }
  .header-inner .header-logo .site-title {
    font-size: 0.86rem;
  }
  .header-inner .gNav > ul {
    gap: 1.5em 0;
    grid-template-columns: 1fr;
    color: #fff;
    font-size: 100%;
    font-weight: 700;
  }
  .header-inner .gNav > ul ul.sub-menu {
    position: relative;
    top: 0;
    right: 0;
    width: auto;
    padding: 0;
    margin: 1em 0 0 0;
    background: none;
    border-radius: 0;
    box-shadow: none;
    transform: none;
    z-index: 0;
    visibility: visible;
  }
  .header-inner .gNav > ul ul.sub-menu:before, .header-inner .gNav > ul ul.sub-menu:after {
    display: none;
  }
}

@media screen and (min-width: 768px) and (max-width: 999px) {
  #header.is_open .header-inner .header-logo {
    position: fixed;
    color: #fff;
  }
}
@media screen and (max-width: 767px) {
  #header.is_open .header-inner .header-logo {
    position: fixed;
    color: #fff;
  }
}

.header-toggle {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  width: 60px;
  height: 60px;
  line-height: 0;
  cursor: pointer;
  z-index: 51;
  margin: 0;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: 0;
  background: none;
}
.header-toggle .header-toggle-btn {
  position: relative;
  width: 30px;
  height: 30px;
}
.header-toggle .header-toggle-btn img {
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .header-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
@media screen and (max-width: 767px) {
  .header-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

.header-toggle[aria-expanded=false] .header-toggle-open {
  display: flex;
}
.header-toggle[aria-expanded=false] .header-toggle-close {
  display: none;
}

.header-toggle[aria-expanded=true] .header-toggle-open {
  display: none;
}
.header-toggle[aria-expanded=true] .header-toggle-close {
  display: block;
}

.header-menu {
  position: relative;
  z-index: 0;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .header-menu {
    position: fixed;
    top: 0;
    right: 0;
    overflow: hidden;
    pointer-events: auto;
    width: 100%;
    height: 100vh;
    padding: 70px 0 0;
    background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
    background-repeat: no-repeat, repeat;
    background-blend-mode: multiply;
  }
  .header-menu .header-menu-inner {
    position: relative;
    width: 100%;
    max-height: 100%;
    padding: 10px 50px 40px;
    display: flex;
    flex-direction: column;
    gap: 30px;
    overflow-y: auto;
  }
}
@media screen and (max-width: 767px) {
  .header-menu {
    position: fixed;
    top: 0;
    right: 0;
    overflow: hidden;
    pointer-events: auto;
    width: 100%;
    height: 100vh;
    padding: 70px 0 0;
    background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
    background-repeat: no-repeat, repeat;
    background-blend-mode: multiply;
  }
  .header-menu .header-menu-inner {
    position: relative;
    width: 100%;
    max-height: 100%;
    padding: 10px 50px 40px;
    display: flex;
    flex-direction: column;
    gap: 30px;
    overflow-y: auto;
  }
}

.header-menu[aria-hidden=true] {
  display: none;
}

.header-menu[aria-hidden=false] {
  display: flex;
}

.skiplink {
  position: absolute;
  width: 0;
  height: 0;
  margin: 0;
  overflow: hidden;
  font-size: 0;
}

footer {
  position: relative;
  margin: 0;
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border-radius: 50px 50px 0 0;
  color: #fff;
}
footer a {
  color: #fff;
  text-decoration: none;
}
footer a:hover, footer a:focus {
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
  text-underline-offset: 2px;
}
@media screen and (max-width: 767px) {
  footer {
    border-radius: 30px 30px 0 0;
  }
}

.footer-inner {
  position: relative;
  width: 90%;
  max-width: 1240px;
  margin: auto;
  padding: 50px 0;
  display: grid;
  grid-template-columns: 170px 1fr 1fr;
  gap: 100px 60px;
}
.footer-inner .footer-block-1 {
  grid-area: 1/2/2/4;
}
.footer-inner .footer-block-2 {
  grid-area: 1/1/2/2;
}
.footer-inner .footer-block-3 {
  grid-area: 2/1/3/3;
}
.footer-inner .footer-block-4 {
  grid-area: 2/3/3/4;
  justify-self: end;
}
.footer-inner .footer-logo a {
  display: inline-flex;
  gap: 15px;
  flex-direction: column;
}
.footer-inner .footer-logo .site-title {
  position: relative;
  top: 0.27em;
  line-height: 1.5;
}
.footer-inner .footer-nav {
  position: relative;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
.footer-inner .footer-nav > ul {
  position: relative;
  list-style: none;
  max-width: 890px;
  padding: 0;
  margin: 0 0 0 auto;
  display: flex;
  gap: 40px;
  display: grid;
  grid-template-columns: repeat(5, auto);
  line-height: 1.5;
  font-weight: 600;
}
.footer-inner .footer-nav > ul > li {
  min-width: 4em;
}
.footer-inner .footer-nav > ul ul {
  position: relative;
  list-style: none;
  margin: 1em 0 0 0;
  padding: 0;
  font-size: 0.75rem;
  font-weight: 500;
  display: flex;
  flex-direction: column;
  gap: 15px;
}
.footer-inner .footer-nav > ul a[target=_blank]:after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-left: 0.25em;
  background: url("../images/blank_wht.svg") no-repeat;
  background-size: 100% auto;
  vertical-align: middle;
}
.footer-inner .footer-nav-2 {
  position: relative;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
.footer-inner .footer-nav-2 > ul {
  position: relative;
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 40px;
}
.footer-inner .footer-nav-2 a[target=_blank]:after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-left: 0.25em;
  background: url("../images/blank_wht.svg") no-repeat;
  background-size: 100% auto;
  vertical-align: middle;
}
.footer-inner .copyright {
  margin: 0;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .footer-inner .footer-block-1 {
    grid-area: 1/1/2/2;
  }
  .footer-inner .footer-block-2 {
    grid-area: 3/1/4/2;
  }
  .footer-inner .footer-block-3 {
    grid-area: 2/1/3/2;
    padding-bottom: 30px;
  }
  .footer-inner .footer-block-4 {
    grid-area: 4/1/5/2;
    justify-self: start;
  }
  .footer-inner .footer-logo a {
    display: flex;
    gap: 15px;
    flex-direction: row;
    align-items: flex-end;
  }
  .footer-inner .footer-nav > ul {
    max-width: 100%;
    grid-template-columns: repeat(1, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .footer-inner .footer-block-1 {
    grid-area: 1/1/2/2;
  }
  .footer-inner .footer-block-2 {
    grid-area: 3/1/4/2;
  }
  .footer-inner .footer-block-3 {
    grid-area: 2/1/3/2;
    padding-bottom: 30px;
  }
  .footer-inner .footer-block-4 {
    grid-area: 4/1/5/2;
    justify-self: start;
  }
  .footer-inner .footer-logo a {
    display: inline-flex;
    gap: 15px;
    flex-direction: row;
    align-items: flex-end;
  }
  .footer-inner .footer-logo img {
    width: 110px;
  }
  .footer-inner .footer-logo .site-title {
    font-size: 0.86rem;
  }
  .footer-inner .footer-nav > ul {
    max-width: 100%;
    grid-template-columns: repeat(1, 1fr);
    font-size: 1.125rem;
  }
}

/* btn -------------*/
.btn {
  position: relative;
  display: flex;
  gap: 5px;
  align-items: center;
  justify-content: center;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 8em;
  max-width: 100%;
  min-height: 3em;
  padding: 10px 45px 10px 45px;
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border-radius: 100px;
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.04em;
  overflow: hidden;
}
.btn:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: 100%;
}
.btn:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 10px solid #fff;
}

.btn:hover:before, .btn:focus-visible:before {
  background: rgba(255, 255, 255, 0.2);
}

.btn.wht {
  background: #fff;
  color: #30A338;
}
.btn.wht:before {
  display: none;
}
.btn.wht:after {
  border-left: 10px solid #30A338;
}

.btn.wht:hover, .btn.wht:focus-visible {
  box-shadow: inset 0 0 0px 2px #30A338;
}

/* btn-container -------------*/
.btn-container {
  display: flex;
  gap: 30px;
}

.btn-container.center {
  align-items: center;
  justify-content: center;
}

/* btn-card -------------*/
ul.btn-card-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 15px 30px;
  grid-template-columns: repeat(3, 1fr);
}
ul.btn-card-list li {
  margin: 0;
  padding: 0;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  ul.btn-card-list {
    grid-template-columns: 1fr;
    gap: 15px 20px;
  }
}
@media screen and (max-width: 767px) {
  ul.btn-card-list {
    grid-template-columns: 1fr;
  }
}

.btn-card {
  position: relative;
  display: flex;
  gap: 15px;
  align-items: center;
  justify-content: space-between;
  min-height: 160px;
  padding: 10px 15px;
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border-radius: 20px;
  color: #fff;
  text-decoration: none;
}
.btn-card:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: 100%;
}
.btn-card .icon {
  flex: none;
  display: block;
  width: 82px;
  border-radius: 100px;
  background: #F5F5F5;
  line-height: 0;
}
.btn-card .icon img {
  width: 100%;
  height: auto;
}
.btn-card .label {
  flex: 1;
  display: flex;
  gap: 2px;
  flex-direction: column;
  font-size: 1.25rem;
  font-size: clamp(16px, 1.6vw, 20px);
  text-wrap: balance;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
.btn-card .label .txt-en-400 {
  font-family: "Chillax-Regular", sans-serif;
  font-size: 75%;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1.5;
}
.btn-card:hover:before {
  background: rgba(255, 255, 255, 0.2);
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .btn-card {
    min-height: 90px;
  }
  .btn-card .icon {
    width: 60px;
  }
}
@media screen and (max-width: 767px) {
  .btn-card {
    min-height: 90px;
  }
  .btn-card .icon {
    width: 50px;
  }
}

/* page navigation -------------*/
.page-navigation {
  position: relative;
}
.page-navigation ul {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  list-style: none;
  margin: 0;
  padding: 0;
  font-weight: 500;
  line-height: 1.4;
  display: grid;
}
.page-navigation li {
  display: grid;
  grid-template-rows: subgrid;
}
.page-navigation a {
  position: relative;
  display: flex;
  gap: 15px;
  align-items: center;
  justify-content: space-between;
  min-height: 54px;
  padding: 10px 15px;
  background: #fff;
  border-radius: 10px;
  color: #30A338;
  text-decoration: none;
}
.page-navigation a:after {
  flex: none;
  content: "";
  display: block;
  position: relative;
  width: 25px;
  height: 25px;
  background: url("../images/arrow_circle_down.svg") no-repeat;
  background-size: 100% auto;
}
.page-navigation a .icon {
  flex: none;
  display: block;
  width: 50px;
  border-radius: 100px;
  background: #F5F5F5;
  line-height: 0;
}
.page-navigation a .icon img {
  width: 100%;
  height: auto;
}
.page-navigation a .label {
  flex: 1;
  display: flex;
  gap: 2px;
  flex-direction: column;
  text-wrap: balance;
}
.page-navigation a .label .txt-en-400 {
  font-size: 75%;
}
.page-navigation a:hover {
  box-shadow: inset 0 0 0px 2px #30A338;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .page-navigation ul {
    gap: 20px;
  }
}
@media screen and (max-width: 767px) {
  .page-navigation ul {
    gap: 10px;
  }
  .page-navigation a {
    min-height: 40px;
  }
  .page-navigation a:after {
    width: 20px;
    height: 20px;
  }
}

.page-navigation.div2 ul {
  width: 80%;
  margin: 0 auto;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .page-navigation.div2 ul {
    width: auto;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .page-navigation.div2 ul {
    width: auto;
    grid-template-columns: repeat(1, 1fr);
  }
}

.page-navigation.div3 ul {
  grid-template-columns: repeat(3, 1fr);
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .page-navigation.div3 ul {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .page-navigation.div3 ul {
    grid-template-columns: repeat(1, 1fr);
  }
}

.page-navigation.div4 ul {
  grid-template-columns: repeat(4, 1fr);
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .page-navigation.div4 ul {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .page-navigation.div4 ul {
    grid-template-columns: repeat(1, 1fr);
  }
}

.page-navigation.grn a {
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  color: #fff;
}
.page-navigation.grn a:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: 100%;
}
.page-navigation.grn a:hover {
  box-shadow: none;
}
.page-navigation.grn a:hover:before {
  background: rgba(255, 255, 255, 0.2);
}

/* heading -------------*/
.h-lv2 .title {
  position: relative;
  margin: 0;
  color: #30A338;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
}

.h-lv2-en {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.h-lv2-en .title-en {
  position: relative;
  font-family: "Chillax-Medium", sans-serif;
  color: #30A338;
  font-size: clamp(40px, 5.4vw, 4rem);
  font-weight: 500;
  line-height: 1.1;
  text-wrap: balance;
}
.h-lv2-en .title {
  position: relative;
  margin: 0;
  color: #30A338;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .h-lv2-en {
    gap: 10px;
  }
  .h-lv2-en .title-en {
    font-size: clamp(24px, 8.5vw, 2.6rem);
  }
}

/* common -------------*/
.main {
  position: relative;
  z-index: 0;
}

.page-body {
  position: relative;
}

.section {
  position: relative;
}

/* breadcrumb -------------*/
.breadcrumb {
  position: relative;
  width: 90%;
  margin: 50px auto;
  max-width: 1200px;
  font-size: 0.75rem;
  line-height: 1.5;
}
.breadcrumb ol {
  position: relative;
  list-style: none;
  padding: 0;
  margin: 0;
}
.breadcrumb li {
  position: relative;
  display: inline;
  margin-right: 10px;
}
.breadcrumb li:after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  margin-left: 15px;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 10px solid #30A338;
}
.breadcrumb li a {
  color: currentColor;
  text-underline-offset: 0.2em;
}
.breadcrumb li a:hover {
  color: #30A338;
}
.breadcrumb li:last-child {
  margin-right: 0;
}
.breadcrumb li:last-child:after {
  display: none;
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    font-size: 1rem;
  }
}

/* container -------------*/
.w-1200 {
  max-width: 1200px;
}

.mx {
  width: 90%;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .mx {
    width: calc(100% - 40px);
  }
}

.mt-middle {
  margin-top: 100px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .mt-middle {
    margin-top: 80px;
  }
}
@media screen and (max-width: 767px) {
  .mt-middle {
    margin-top: 80px;
  }
}

.mb-middle {
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .mb-middle {
    margin-bottom: 80px;
  }
}
@media screen and (max-width: 767px) {
  .mb-middle {
    margin-bottom: 80px;
  }
}

.pt-middle {
  padding-top: 100px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .pt-middle {
    padding-top: 80px;
  }
}
@media screen and (max-width: 767px) {
  .pt-middle {
    padding-top: 80px;
  }
}

.pb-middle {
  padding-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .pb-middle {
    padding-bottom: 80px;
  }
}
@media screen and (max-width: 767px) {
  .pb-middle {
    padding-bottom: 80px;
  }
}

/* scroll in -------------*/
.scrollIn.fade {
  visibility: hidden;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1.2s ease-out, transform 1.5s ease-out;
}

.scrollIn.fade.is_show {
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
}

/* page-header -------------*/
.page-header {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 15px;
  width: 90%;
  margin: 70px auto 40px;
}
.page-header .page-title-en {
  position: relative;
  font-family: "Chillax-Medium", sans-serif;
  color: #30A338;
  font-size: clamp(50px, 7.8vw, 5.625rem);
  font-weight: 500;
  line-height: 1;
  text-wrap: balance;
}
.page-header .h-page-title {
  position: relative;
  margin: 0;
  color: #30A338;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .page-header {
    gap: 10px;
    margin: 30px auto 30px;
  }
  .page-header .page-title-en {
    font-size: clamp(28px, 12vw, 3.6rem);
  }
}

/* page-wide-image -------------*/
.page-wide-image {
  position: relative;
  margin: 60px 60px 100px 0;
}
.page-wide-image img {
  width: 100%;
  aspect-ratio: 1380/400;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  border-radius: 0 20vw 20vw 0;
}
@media screen and (max-width: 767px) {
  .page-wide-image {
    margin: 30px 15px 60px 0;
  }
  .page-wide-image img {
    aspect-ratio: 360/228;
    border-radius: 0 60vw 60vw 0;
  }
}

/* box-wht -------------*/
.box-wht {
  background: #fff;
  border-radius: 30px;
  padding: 50px 50px;
}
@media screen and (max-width: 767px) {
  .box-wht {
    padding: 50px 30px;
  }
}

/*-----------------
Philosophy
------------------*/
.philosophy-mission-container {
  position: relative;
  padding: clamp(60px, 9vw, 120px) 0;
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise_grn_3.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border-radius: 50px;
}
.philosophy-mission-container .mission-img {
  position: relative;
  margin-bottom: -6vw;
  line-height: 0;
}
.philosophy-mission-container .mission-img img {
  aspect-ratio: 1440/710;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.philosophy-mission-container .mission-text {
  position: relative;
  width: 90%;
  margin: 0 auto;
  color: #fff;
  text-align: center;
}
.philosophy-mission-container .mission-text h3 {
  margin: 0 auto 1.5em;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.04em;
  text-decoration: underline;
  text-underline-offset: 0.3em;
}
.philosophy-mission-container .mission-text p {
  margin: 0;
  font-size: 1.25rem;
  line-height: 2.4;
  font-weight: 700;
}
.philosophy-mission-container .mission-img2 {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .philosophy-mission-container .mission-img {
    margin-bottom: -3vw;
  }
  .philosophy-mission-container .mission-img img {
    aspect-ratio: 1440/770;
  }
}
@media screen and (max-width: 767px) {
  .philosophy-mission-container .mission-img {
    width: 90%;
    max-width: 450px;
    margin: 30px auto;
  }
  .philosophy-mission-container .mission-img img {
    aspect-ratio: auto;
  }
  .philosophy-mission-container .mission-text h3 {
    font-size: clamp(16px, 5.5vw, 24px);
  }
  .philosophy-mission-container .mission-text p {
    display: table;
    margin: 0 auto;
    font-size: 1.125rem;
    line-height: 2;
  }
  .philosophy-mission-container .mission-img2 {
    display: block;
    position: relative;
    width: 90%;
    max-width: 500px;
    margin: 40px auto 0;
    text-align: center;
    line-height: 0;
  }
  .philosophy-mission-container .mission-img2 img {
    margin: 0 auto;
  }
}

.philosophy-container {
  position: relative;
  padding: clamp(60px, 9vw, 120px) 0;
}
.philosophy-container .philosophy-inner {
  position: relative;
  display: flex;
  gap: 60px;
  justify-content: space-between;
  width: 90%;
  max-width: 1200px;
  margin: auto;
}
.philosophy-container .philosophy-header {
  position: relative;
  width: 40%;
}
.philosophy-container .philosophy-body {
  position: relative;
  flex: 1;
  max-width: 700px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .philosophy-container .philosophy-inner {
    display: block;
  }
  .philosophy-container .philosophy-header {
    width: 100%;
    max-width: 700px;
    margin: 0 auto 30px;
  }
  .philosophy-container .philosophy-body {
    width: 100%;
    margin: auto;
  }
}
@media screen and (max-width: 767px) {
  .philosophy-container {
    padding: 60px 0;
    border-radius: 30px;
  }
  .philosophy-container .philosophy-inner {
    display: block;
  }
  .philosophy-container .philosophy-header {
    width: 100%;
    max-width: 700px;
    margin: 0 auto 30px;
  }
  .philosophy-container .philosophy-body {
    width: 100%;
    margin: auto;
  }
}

.h-philosophy {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: #30A338;
}
.h-philosophy .title-en {
  position: relative;
  font-family: "Chillax-Medium", sans-serif;
  font-size: clamp(40px, 5.4vw, 4rem);
  font-weight: 500;
  line-height: 1.1;
  text-wrap: balance;
}
.h-philosophy .title {
  position: relative;
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}
.h-philosophy .label {
  position: relative;
  margin: 0;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  display: flex;
  gap: 0.625em;
}
.h-philosophy .label:before {
  flex: none;
  content: "";
  display: inline-block;
  position: relative;
  top: 0.437em;
  width: 0.625em;
  height: 0.625em;
  background: currentColor;
  border-radius: 100px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .h-philosophy .title-en {
    font-size: clamp(40px, 5.4vw, 4rem);
  }
}
@media screen and (max-width: 767px) {
  .h-philosophy .title-en {
    font-size: clamp(24px, 8.5vw, 2.6rem);
  }
  .h-philosophy .label {
    font-size: 1.25rem;
  }
}

.philosophy-wideimg {
  position: relative;
  line-height: 0;
}
.philosophy-wideimg img {
  width: 100%;
  height: auto;
}

.philosophy-action-container {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.philosophy-action-container .philosophy-action-item {
  position: relative;
  padding: 40px;
  border-radius: 30px;
  background: #fff;
  display: flex;
  gap: 20px;
}
.philosophy-action-container .item-num {
  flex: none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: 100px;
  font-family: "Chillax-Medium", sans-serif;
  font-size: 1.5rem;
  color: #fff;
  text-align: center;
  line-height: 1;
  font-weight: 500;
  background-image: linear-gradient(90deg, rgb(100, 160, 140) 0%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
}
.philosophy-action-container .item-text {
  position: relative;
  flex: 1;
}
.philosophy-action-container .item-text h3 {
  margin: 0 0 0.8em;
  color: #30A338;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
}
.philosophy-action-container .item-text .text {
  position: relative;
}
.philosophy-action-container .item-text .text p {
  margin: 0;
  letter-spacing: 0.05em;
  line-height: 2;
  font-weight: 500;
}
.philosophy-action-container .item-text .text p span {
  color: #30A338;
}
@media screen and (max-width: 767px) {
  .philosophy-action-container .philosophy-action-item {
    gap: 15px;
    padding: 30px 20px;
  }
  .philosophy-action-container .item-num {
    width: 40px;
    height: 40px;
    font-size: 1.25rem;
  }
}

.philosophy-ideal-container {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 70px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .philosophy-ideal-container {
    gap: 60px;
  }
}
@media screen and (max-width: 767px) {
  .philosophy-ideal-container {
    gap: 50px;
  }
}

.block-philosophy-ideal {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.block-philosophy-ideal .philosophy-ideal-img {
  position: relative;
  line-height: 0;
}
.block-philosophy-ideal .philosophy-ideal-img img {
  width: 100%;
  height: auto;
  border-radius: 30px;
}
.block-philosophy-ideal .philosophy-ideal-text {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.block-philosophy-ideal .philosophy-ideal-text h3 {
  position: relative;
  color: #30A338;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  display: flex;
  gap: 0.5em;
}
.block-philosophy-ideal .philosophy-ideal-text h3:before {
  flex: none;
  content: "●";
  display: inline-block;
  position: relative;
  top: 0.15em;
  color: #30A338;
  font-size: 0.9em;
}
.block-philosophy-ideal .philosophy-ideal-text p {
  margin: 0;
  line-height: 2;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .block-philosophy-ideal {
    gap: 20px;
  }
  .block-philosophy-ideal .philosophy-ideal-img img {
    border-radius: 20px;
  }
}

.philosophy-message-container {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 60px;
  margin-bottom: 7vw;
}
.philosophy-message-container .philosophy-message-img {
  position: relative;
  padding: 14px;
  border-radius: 65px;
  background-image: linear-gradient(90deg, rgb(100, 160, 140) 0%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  line-height: 0;
  overflow: hidden;
}
.philosophy-message-container .philosophy-message-img img {
  width: 100%;
  border-radius: 50px;
}
.philosophy-message-container h3 {
  margin: 0;
  color: #30A338;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.04em;
  text-decoration: underline;
  text-underline-offset: 0.3em;
}
.philosophy-message-container p.text {
  margin: 0;
  font-size: 1.25rem;
  line-height: 2.4;
  font-weight: 700;
}
.philosophy-message-container p.name {
  margin: 0;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .philosophy-message-container {
    gap: 50px;
    margin-bottom: 3vw;
  }
  .philosophy-message-container .philosophy-message-img {
    border-radius: 50px;
  }
  .philosophy-message-container .philosophy-message-img img {
    border-radius: 45px;
  }
}
@media screen and (max-width: 767px) {
  .philosophy-message-container {
    gap: 30px;
    margin-bottom: 0;
  }
  .philosophy-message-container .philosophy-message-img {
    padding: 8px;
    border-radius: 50px;
  }
  .philosophy-message-container .philosophy-message-img img {
    border-radius: 45px;
  }
  .philosophy-message-container h3 {
    font-size: clamp(16px, 5.5vw, 24px);
  }
  .philosophy-message-container p.text {
    margin: 0 auto;
    font-size: 1.125rem;
    line-height: 2;
    text-align: left;
  }
}

.philosophy-bottom-img {
  position: absolute;
  bottom: -50px;
  left: 0;
  line-height: 0;
  opacity: 0.5;
  pointer-events: none;
}
.philosophy-bottom-img img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center bottom;
     object-position: center bottom;
}
@media screen and (max-width: 767px) {
  .philosophy-bottom-img {
    bottom: -30px;
  }
  .philosophy-bottom-img img {
    aspect-ratio: 5/3;
  }
}

/*-----------------
People
------------------*/
.people-container {
  position: relative;
}
.people-container .people-header {
  position: relative;
}
.people-container .people-header .people-header-img {
  position: relative;
  padding: 14px;
  border-radius: 65px;
  background-image: linear-gradient(90deg, rgb(100, 160, 140) 0%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  line-height: 0;
  overflow: hidden;
}
.people-container .people-header .people-header-img img {
  width: 100%;
  aspect-ratio: 1172/472;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 50px;
}
.people-container .people-header .people-header-txt {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 6%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #fff;
}
.people-container .people-header .people-header-txt .h-people-title {
  position: relative;
  margin: 0 0 20px;
  font-size: clamp(20px, 2.8vw, 2.125rem);
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.04em;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.people-container .people-header .people-header-txt .h-people-title span {
  display: inline-block;
  margin: 0 auto 0 0;
  padding: 0 10px;
  border-radius: 5px;
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
}
.people-container .people-header .people-header-txt .profile-txt {
  color: #fff;
}
.people-container .people-header .people-header-txt .txt_1 {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
}
.people-container .people-header .people-header-txt .txt_2 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
}
.people-container .people-header .people-header-txt .txt_3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 500;
}
.people-container .people-body {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 140px;
  margin: 140px auto;
}
.people-container .block-people-imgs {
  position: relative;
  display: flex;
  border-radius: 30px;
  line-height: 0;
  overflow: hidden;
}
.people-container .block-people-imgs .img {
  flex: 1;
  line-height: 0;
}
.people-container .block-people-imgs .img img {
  width: 100%;
  height: auto;
}
.people-container .block-people-imgs.for-sp {
  display: none;
}
.people-container .block-people-textimg {
  position: relative;
  display: flex;
  gap: 60px;
}
.people-container .block-people-textimg .text {
  position: relative;
  flex: 1;
}
.people-container .block-people-textimg .img {
  width: 40%;
  line-height: 0;
}
.people-container .block-people-textimg .img img {
  width: 100%;
  height: auto;
  border-radius: 30px;
}
.people-container .block-people-textimg h3 {
  position: relative;
  margin: 50px 0 20px;
  font-family: 1.125rem;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.04em;
}
.people-container .block-people-textimg h3:before {
  content: "";
  display: inline-block;
  position: relative;
  width: 0;
  height: 0;
  margin-right: 0.5em;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 12px solid #30A338;
  vertical-align: middle;
}
.people-container .block-people-textimg h4 {
  position: relative;
  margin: 20px 0;
  color: #30A338;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.04em;
}
.people-container .block-people-textimg p {
  position: relative;
  margin: 20px 0;
  line-height: 2;
  font-weight: 500;
}
.people-container .block-people-textimg h3:first-child, .people-container .block-people-textimg h4:first-child, .people-container .block-people-textimg p:first-child {
  margin-top: 0;
}
.people-container .block-people-textimg h3:last-child, .people-container .block-people-textimg h4:last-child, .people-container .block-people-textimg p:last-child {
  margin-bottom: 0;
}
.people-container .block-people-textimg.reverse {
  flex-direction: row-reverse;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .people-container .people-header .people-header-img {
    border-radius: 50px;
  }
  .people-container .people-header .people-header-img img {
    aspect-ratio: 1172/550;
    border-radius: 45px;
  }
  .people-container .people-header .people-header-txt .h-people-title {
    margin: 0 0 10px;
  }
  .people-container .people-body {
    gap: 100px;
    margin: 100px auto;
  }
}
@media screen and (max-width: 767px) {
  .people-container .people-header .people-header-img {
    padding: 8px;
    border-radius: 50px;
  }
  .people-container .people-header .people-header-img img {
    aspect-ratio: 328/210;
    border-radius: 45px;
  }
  .people-container .people-header .people-header-txt {
    position: relative;
    left: 0;
    margin: 20px auto 0;
  }
  .people-container .people-header .people-header-txt .h-people-title {
    margin: 0 0 20px;
    font-size: 1.5rem;
    font-size: clamp(18px, 6.5vw, 1.5rem);
    font-size: clamp(20px, 5.5vw, 30px);
    font-weight: 700;
    line-height: 1.7;
    letter-spacing: 0.04em;
  }
  .people-container .people-header .people-header-txt .profile-txt {
    color: #4D4D4D;
  }
  .people-container .people-body {
    gap: 50px;
    margin: 50px auto;
  }
  .people-container .block-people-imgs {
    flex-direction: column;
    border-radius: 20px;
  }
  .people-container .block-people-imgs.for-pc {
    display: none;
  }
  .people-container .block-people-imgs.for-sp {
    display: flex;
  }
  .people-container .block-people-imgs.for-sp img {
    border-radius: 0 !important;
  }
  .people-container .block-people-textimg,
  .people-container .block-people-textimg.reverse {
    flex-direction: column;
    gap: 50px;
  }
  .people-container .block-people-textimg .img,
  .people-container .block-people-textimg.reverse .img {
    width: 100%;
  }
  .people-container .block-people-textimg .img img,
  .people-container .block-people-textimg.reverse .img img {
    border-radius: 20px;
  }
}

.people-schedule-container {
  position: relative;
  padding: clamp(60px, 9vw, 120px) 0;
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise_grn_3.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border-radius: 50px;
}
.people-schedule-container .people-schedule-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 60px;
  width: 90%;
  max-width: 1200px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .people-schedule-container {
    border-radius: 30px;
  }
  .people-schedule-container .people-schedule-inner {
    gap: 40px;
  }
}

.people-schedule-body {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.people-schedule-body .schedule-item {
  position: relative;
  display: grid;
  grid-template-columns: 300px auto;
  align-items: center;
  min-height: 105px;
  padding: 15px 30px;
  gap: 10px 60px;
  align-self: stretch;
  border-radius: 30px;
  background: #fff;
}
.people-schedule-body .schedule-item-time {
  position: relative;
  display: flex;
  gap: 0 20px;
  align-items: center;
  color: #30A338;
}
.people-schedule-body .schedule-item-time .icon {
  width: 30px;
  height: 30px;
  border-radius: 100px;
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise_grn_3.png");
}
.people-schedule-body .schedule-item-time .time {
  position: relative;
  display: flex;
  padding-right: 20px;
  font-family: "Chillax-Medium", sans-serif;
  font-size: 1.375rem;
  font-weight: 500;
  line-height: 1;
}
.people-schedule-body .schedule-item-time .time:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 100%;
  background: #30A338;
  border-radius: 2px;
}
.people-schedule-body .schedule-item-time .title {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5;
}
.people-schedule-body .schedule-item-content {
  position: relative;
  line-height: 2;
  font-weight: 500;
}
.people-schedule-body .schedule-item-content p {
  margin: 0;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .people-schedule-body .schedule-item {
    gap: 10px 40px;
    grid-template-columns: 260px auto;
  }
  .people-schedule-body .schedule-item-time {
    gap: 0 15px;
  }
  .people-schedule-body .schedule-item-time .time {
    padding-right: 15px;
    font-size: 1.25rem;
  }
  .people-schedule-body .schedule-item-time .title {
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 767px) {
  .people-schedule-body .schedule-item {
    grid-template-columns: 1fr;
    border-radius: 20px;
  }
}

.block-people-message {
  position: relative;
  display: flex;
  align-items: center;
  gap: 40px;
  padding: 60px;
  border-radius: 65px;
  background: #fff;
}
.block-people-message .message-img {
  flex: none;
  position: relative;
  width: 25%;
  min-width: 180px;
  line-height: 0;
}
.block-people-message .message-img img {
  border-radius: 100%;
}
.block-people-message .message-text {
  position: relative;
  flex: 1;
  line-height: 2;
  font-weight: 500;
}
.block-people-message .message-text p {
  margin: 0;
}
@media screen and (max-width: 767px) {
  .block-people-message {
    flex-direction: column;
    gap: 20px;
    border-radius: 30px;
    padding: 30px;
  }
  .block-people-message .message-img {
    width: 30%;
    min-width: 120px;
  }
}

.block-other-interview {
  position: relative;
  display: grid;
  gap: 30px 60px;
  grid-template-columns: 0.6fr 1fr;
  max-width: 1000px;
  margin: auto;
}
.block-other-interview .other-interview-header {
  position: relative;
  color: #30A338;
}
.block-other-interview .other-interview-header h3, .block-other-interview .other-interview-header h4 {
  position: relative;
  font-family: "Chillax-Medium", sans-serif;
  color: #30A338;
  font-size: clamp(40px, 5.4vw, 4rem);
  font-weight: 500;
  line-height: 1.1;
  text-wrap: balance;
}
@media screen and (max-width: 767px) {
  .block-other-interview {
    grid-template-columns: 1fr;
  }
  .block-other-interview .other-interview-header {
    text-align: center;
  }
  .block-other-interview .other-interview-header h3, .block-other-interview .other-interview-header h4 {
    font-size: clamp(24px, 8.5vw, 2.6rem);
  }
}

/* Interview ------------------*/
.block-relate-interview {
  position: relative;
  display: grid;
  gap: 10px clamp(20px, 9vw, 90px);
  grid-template-columns: clamp(50px, 9vw, 90px) 1fr;
}
.block-relate-interview .relate-interview-header {
  position: relative;
  color: #30A338;
}
.block-relate-interview .relate-interview-header h3, .block-relate-interview .relate-interview-header h4 {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  font-family: "Chillax-Medium", sans-serif;
  font-size: clamp(50px, 9vw, 90px);
  font-weight: 500;
  line-height: 1;
  text-wrap: balance;
  transform: translateY(-100%) rotate(90deg);
  transform-origin: left bottom;
}

.block-relate-interview.wht .relate-interview-header {
  color: #fff;
}
.block-relate-interview.wht .interview-item .interview-item-img {
  background: #fff;
}
.block-relate-interview.wht .interview-item .interview-item-data:before {
  background: #fff;
}

.interview-item {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.interview-item .interview-item-img {
  position: relative;
  overflow: hidden;
  padding: 14px;
  background-image: linear-gradient(90deg, rgb(100, 160, 140) 0%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border-radius: 65px;
  line-height: 0;
}
.interview-item .interview-item-img img {
  width: 100%;
  border-radius: 50px;
}
.interview-item .interview-item-body {
  position: relative;
  display: grid;
  gap: 25px 25px;
  grid-template-columns: 1fr auto;
}
.interview-item .interview-item-data {
  align-self: center;
  position: relative;
  display: flex;
  flex-direction: column;
  padding-left: 25px;
  flex: 1;
}
.interview-item .interview-item-data:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 6px;
  height: 100%;
  background: #30A338;
  border-radius: 6px;
}
.interview-item .interview-item-data .txt_1 {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
}
.interview-item .interview-item-data .txt_2 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
}
.interview-item .interview-item-data .txt_3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 500;
}
.interview-item .btn-container {
  align-self: end;
}
@media screen and (max-width: 767px) {
  .interview-item .interview-item-img {
    padding: 8px;
    border-radius: 50px;
  }
  .interview-item .interview-item-img img {
    border-radius: 45px;
  }
  .interview-item .interview-item-body {
    grid-template-columns: 1fr;
  }
}

/*-----------------
Business
------------------*/
.business-container {
  position: relative;
  padding: clamp(60px, 9vw, 120px) 0;
  background-image: linear-gradient(45deg, rgb(100, 160, 140) 0%, rgb(102, 162, 137) 25.26%, rgb(107, 167, 126) 47.09%, rgb(117, 176, 108) 67.65%, rgb(129, 188, 83) 87.32%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border-radius: 50px;
}
.business-container .business-inner {
  position: relative;
  display: flex;
  gap: 60px;
  justify-content: space-between;
  width: 90%;
  max-width: 1200px;
  margin: auto;
}
.business-container .business-header {
  position: relative;
  width: 40%;
}
.business-container .business-body {
  position: relative;
  flex: 1;
  max-width: 700px;
  display: flex;
  flex-direction: column;
  gap: 50px 0;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .business-container .business-inner {
    display: block;
  }
  .business-container .business-header {
    width: 100%;
    max-width: 700px;
    margin: auto;
  }
  .business-container .business-body {
    width: 100%;
    margin: auto;
  }
}
@media screen and (max-width: 767px) {
  .business-container {
    padding: 60px 0;
    border-radius: 30px;
  }
  .business-container .business-inner {
    display: block;
  }
  .business-container .business-header {
    width: 100%;
    max-width: 700px;
    margin: 0 auto 30px;
  }
  .business-container .business-body {
    width: 100%;
    margin: auto;
  }
}

.h-business {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: #30A338;
}
.h-business .title-en {
  position: relative;
  font-family: "Chillax-Medium", sans-serif;
  font-size: clamp(40px, 5.4vw, 4rem);
  font-weight: 500;
  line-height: 1.1;
  text-wrap: balance;
}
.h-business .title {
  position: relative;
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}
.h-business .label {
  position: relative;
  margin: 0;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  display: flex;
  gap: 0.625em;
}
.h-business .label:before {
  flex: none;
  content: "";
  display: inline-block;
  position: relative;
  top: 0.437em;
  width: 0.625em;
  height: 0.625em;
  background: currentColor;
  border-radius: 100px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .h-business .title-en {
    font-size: clamp(40px, 5.4vw, 4rem);
  }
}
@media screen and (max-width: 767px) {
  .h-business .title-en {
    font-size: clamp(24px, 8.5vw, 2.6rem);
  }
  .h-business .label {
    font-size: 1.25rem;
  }
}

.business-container.grn_1 {
  background-image: linear-gradient(45deg, rgb(191, 218, 154) 0%, rgb(222, 236, 203) 100%), url("../images/bg_noise_grn_1.png");
}

.business-container.grn_2 {
  background-image: linear-gradient(45deg, rgb(116, 180, 94) 0%, rgb(179, 214, 167) 99.98%), url("../images/bg_noise_grn_2.png");
}
.business-container.grn_2 .h-business {
  color: #fff;
}
.business-container.grn_2 .business-body {
  color: #fff;
}
.business-container.grn_2 .block-business-service .business-service-item-title {
  color: currentColor;
}

.business-container.grn_3 {
  background-image: linear-gradient(45deg, rgb(46, 162, 57) 0%, rgb(149, 208, 155) 100%), url("../images/bg_noise_grn_3.png");
}
.business-container.grn_3 .h-business {
  color: #fff;
}
.business-container.grn_3 .business-body {
  color: #fff;
}
.business-container.grn_3 .block-business-service .business-service-item-title {
  color: currentColor;
}

.block-business-service {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.block-business-service .business-service-img {
  position: relative;
  line-height: 0;
}
.block-business-service .business-service-img img {
  width: 100%;
  height: auto;
  border-radius: 30px;
}
.block-business-service .business-service-text {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.block-business-service .business-service-text .business-service-item-title {
  position: relative;
  margin: 0;
  color: #30A338;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  display: flex;
  align-items: flex-start;
}
.block-business-service .business-service-text .business-service-item-title .sub-title {
  flex: none;
  position: relative;
  top: 0.5rem;
  display: flex;
  gap: 0.5em;
  align-items: center;
  padding: 0 1em 0 0.5em;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.3;
  vertical-align: middle;
  border-left: 1px solid currentColor;
}
.block-business-service .business-service-text .business-service-item-title .sub-title .sub-title-divider {
  position: relative;
}
.block-business-service .business-service-text p {
  margin: 0;
}
@media screen and (max-width: 767px) {
  .block-business-service {
    gap: 20px;
  }
  .block-business-service .business-service-img img {
    border-radius: 20px;
  }
}

/*-----------------
Environment
------------------*/
.data-card-list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  max-width: 960px;
  margin: 60px auto;
}
.data-card-list .data-card-item {
  position: relative;
  line-height: 0;
}
.data-card-list .data-card-item img {
  width: 100%;
  height: auto;
  box-shadow: 10px 10px 10px 0 rgba(0, 0, 0, 0.1);
  border-radius: min(28px, 2.6vw);
}
.data-card-list .data-card-item svg {
  width: 100%;
  height: auto;
}
.data-card-list .data-card-item:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../images/bg_noise.png") repeat;
  mix-blend-mode: multiply;
  pointer-events: none;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .data-card-list {
    gap: 20px;
  }
  .data-card-list .data-card-item img {
    box-shadow: 5px 5px 5px 0 rgba(0, 0, 0, 0.1);
  }
}
@media screen and (max-width: 767px) {
  .data-card-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin: 40px auto;
  }
  .data-card-list .data-card-item img {
    box-shadow: 5px 5px 5px 0 rgba(0, 0, 0, 0.1);
    border-radius: min(35px, 4vw);
  }
}

.fukuri-container {
  position: relative;
  max-width: 770px;
  margin: 60px auto;
  text-align: center;
}
.fukuri-container .fukuri-list {
  position: relative;
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
  margin: 40px auto 60px;
}
.fukuri-container .fukuri-list .list-item {
  position: relative;
}
.fukuri-container .fukuri-list .icon {
  position: relative;
  max-width: 160px;
  margin: 0 auto;
  text-align: center;
  line-height: 0;
}
.fukuri-container .fukuri-list .icon img {
  width: 100%;
  height: auto;
}
.fukuri-container .fukuri-list .label {
  position: relative;
  margin: 1em 0 0;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}
.fukuri-container .fukuri-list .caption {
  margin: 1.125rem auto 0;
  text-align: left;
}
.fukuri-container .fukuri-list.div4 .list-item {
  width: calc((100% - 120px) / 4);
}
.fukuri-container .fukuri-list.div2 .list-item {
  width: calc((100% - 40px) / 2);
  max-width: 240px;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .fukuri-container .fukuri-list {
    gap: 30px;
  }
  .fukuri-container .fukuri-list.div4 .list-item {
    width: calc((100% - 60px) / 3);
    max-width: 240px;
  }
  .fukuri-container .fukuri-list.div2 .list-item {
    width: calc((100% - 60px) / 3);
    max-width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .fukuri-container {
    margin: 40px auto;
  }
  .fukuri-container .fukuri-list {
    gap: 30px;
    margin: 20px auto 60px;
  }
  .fukuri-container .fukuri-list .icon {
    max-width: 130px;
  }
  .fukuri-container .fukuri-list .label {
    margin: 10px 0 0;
    font-size: 1rem;
  }
  .fukuri-container .fukuri-list .caption {
    margin: 10px auto 0;
  }
  .fukuri-container .fukuri-list.div4 .list-item {
    width: calc((100% - 30px) / 2);
    max-width: 240px;
  }
  .fukuri-container .fukuri-list.div2 .list-item {
    width: calc((100% - 30px) / 2);
  }
}

/*-----------------
Information
------------------*/
.info-container {
  position: relative;
  margin: 100px auto;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .info-container {
    margin: 80px auto;
  }
}
@media screen and (max-width: 767px) {
  .info-container {
    margin: 50px auto;
  }
}

.info-table {
  position: relative;
  display: grid;
  grid-template-columns: 8em 1fr;
  gap: 0;
}
.info-table .table-item {
  position: relative;
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 2;
  gap: 10px 20px;
  padding: 40px 0;
  border-bottom: 1px solid #30A338;
}
.info-table .table-item:first-child {
  padding-top: 0;
}
.info-table .th {
  position: relative;
  margin: 0;
  color: #30A338;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}
.info-table .td {
  position: relative;
  margin: 0;
  line-height: 1.9;
}
.info-table .td p {
  margin: 0 0 1em;
}
.info-table .td p:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .info-table {
    grid-template-columns: 1fr;
  }
  .info-table .table-item {
    grid-column: span 1;
    padding: 25px 0;
  }
  .info-table .table-item:first-child {
    padding-top: 0;
  }
}

.info-step {
  position: relative;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 30px 20px;
  margin: 30px;
}
.info-step .step-item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
}
.info-step .step-item-icon {
  position: relative;
  width: 160px;
  background: #F5F5F5;
  border-radius: 100%;
  line-height: 0;
  overflow: hidden;
}
.info-step .step-item-icon img {
  width: 100%;
  height: auto;
}
.info-step .step-item-label {
  position: relative;
  line-height: 1.5;
  font-weight: 700;
}
.info-step .step-item-label p {
  margin: 0;
}
.info-step .arrow {
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 1000px) and (max-width: 1199px) {
  .info-step .step-item-icon {
    width: 130px;
  }
  .info-step .arrow {
    height: 130px;
  }
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .info-step .step-item-icon {
    width: 100px;
  }
  .info-step .arrow {
    height: 100px;
  }
}
@media screen and (max-width: 767px) {
  .info-step {
    flex-direction: column;
    gap: 15px;
  }
  .info-step .step-item {
    flex-direction: row;
  }
  .info-step .step-item-icon {
    width: 100px;
  }
  .info-step .arrow {
    width: 100px;
    height: auto;
  }
  .info-step .arrow img {
    transform: rotate(90deg);
  }
}

/* toppage heading -------------*/
.toppage-h-lv2-en {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.toppage-h-lv2-en .title-en {
  position: relative;
  font-family: "Chillax-Medium", sans-serif;
  color: #30A338;
  font-size: clamp(50px, 7.5vw, 5.625rem);
  font-weight: 500;
  line-height: 1.1;
  text-wrap: balance;
}
.toppage-h-lv2-en .title {
  position: relative;
  margin: 0;
  color: #30A338;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .toppage-h-lv2-en {
    gap: 10px;
  }
  .toppage-h-lv2-en .title-en {
    font-size: clamp(24px, 13vw, 50px);
  }
}

/*-------------------
 toppage KV 
 -------------------*/
.toppage-kv-imgs {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100dvh;
  overflow-x: clip;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 0 0 0 55%;
}
.toppage-kv-imgs .kv-circle {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 55%;
  margin: auto;
  width: calc(36vw + 28px);
  height: calc(36vw + 28px);
  max-width: calc(80dvh + 28px);
  max-height: calc(80dvh + 28px);
  background-image: linear-gradient(90deg, rgb(100, 160, 140) 0%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border-radius: 100%;
  transform: translateX(-14px);
}
.toppage-kv-imgs .toppage-kv-imgs-inner {
  aspect-ratio: 50/50;
  width: 36vw;
  max-width: 80dvh;
  clip-path: circle(50% at 50% 50%);
}
.toppage-kv-imgs .kv-imgs-container {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 200vw;
  transform: translate(-50%, -50%) rotate(-10deg);
  background: #fff;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.45s ease, visibility 0s linear 0.45s;
}
.toppage-kv-imgs.is_kv_ready .kv-imgs-container {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.45s ease, visibility 0s linear 0s;
}
.toppage-kv-imgs .kv-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #555;
  mix-blend-mode: multiply;
  opacity: 0;
}
.toppage-kv-imgs .kv-imgs {
  position: relative;
}
.toppage-kv-imgs .kv-imgs .kv-img-list {
  display: flex;
}
.toppage-kv-imgs .kv-imgs .kv-img-item {
  flex: 1;
  line-height: 0;
}
.toppage-kv-imgs .kv-imgs .kv-img-item img {
  width: 100%;
  border: 1px solid #fff;
  border-radius: 10%/15%;
}
@media screen and (max-width: 767px) {
  .toppage-kv-imgs .kv-circle {
    width: calc(36vw + 16px);
    height: calc(36vw + 16px);
    max-width: calc(80dvh + 16px);
    max-height: calc(80dvh + 16px);
    transform: translateX(-8px);
  }
}
@media screen and (min-aspect-ratio: 8/5) {
  .toppage-kv-imgs .kv-imgs-container {
    width: 220vw;
  }
}
@media screen and (max-aspect-ratio: 4/5) {
  .toppage-kv-imgs .kv-imgs-container {
    width: 220dvh;
  }
}
@media screen and (max-width: 1000px) and (max-aspect-ratio: 7/9) {
  .toppage-kv-imgs {
    padding: 0;
    align-items: flex-start;
  }
  .toppage-kv-imgs .kv-circle {
    top: calc(52dvh - 8px);
    bottom: auto;
    left: 0;
    right: 0;
    width: calc(70vw + 16px);
    height: calc(70vw + 16px);
    max-width: calc(43dvh + 16px);
    max-height: calc(43dvh + 16px);
    transform: none;
  }
  .toppage-kv-imgs .toppage-kv-imgs-inner {
    margin: 52dvh auto 0;
    width: 70vw;
    max-width: 43dvh;
  }
  .toppage-kv-imgs .kv-imgs-container {
    width: 220dvh;
  }
}

.topage-kv-container {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  width: 100%;
  height: 100dvh;
  padding: 100px 0 0;
}
.topage-kv-container .kv-text {
  flex: 1;
  width: 33vw;
  max-width: 80dvh;
  margin: 0 55% 0 0;
  display: flex;
  align-items: center;
  line-height: 0;
}
.topage-kv-container .kv-text img, .topage-kv-container .kv-text svg {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: auto;
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .topage-kv-container {
    padding: 60px 0 0;
  }
  .topage-kv-container .kv-text {
    width: 38vw;
  }
}
@media screen and (max-width: 1000px) and (max-aspect-ratio: 7/9) {
  .topage-kv-container {
    padding: 70px 0 0;
  }
  .topage-kv-container .kv-text {
    width: calc((100vw - 70px) * 0.9);
    max-width: 50dvh;
    margin: auto;
    align-items: flex-start;
  }
  .topage-kv-container .kv-text img, .topage-kv-container .kv-text svg {
    position: absolute;
    top: auto;
    bottom: 50dvh;
    left: 0;
    margin: 0;
    width: 100%;
    height: auto;
    opacity: 0;
  }
}

.text_ttbl {
  position: relative;
}
@media screen and (max-width: 767px) {
  .text_ttbl {
    width: 150vw;
  }
}

/*-------------------
 toppage Philosophy 
 -------------------*/
.toppage-philosophy-container {
  position: relative;
  margin: 50px 0 0;
  padding: 100px 0;
}
.toppage-philosophy-container .toppage-philosophy-inner {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  grid-column-gap: 50px;
  grid-row-gap: 40px;
  width: 90%;
  max-width: 1200px;
  margin: auto;
}
.toppage-philosophy-container .toppage-h-lv2-en {
  align-self: end;
}
.toppage-philosophy-container .toppage-philosophy-text {
  grid-row: span 2;
  align-self: center;
  color: #fff;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 2.4;
}
.toppage-philosophy-container .toppage-philosophy-text p {
  margin: 0;
}
.toppage-philosophy-container .btn-container {
  align-self: start;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .toppage-philosophy-container .toppage-philosophy-inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }
  .toppage-philosophy-container .toppage-h-lv2-en {
    text-align: center;
  }
  .toppage-philosophy-container .toppage-philosophy-text {
    grid-row: span 1;
    text-align: center;
  }
  .toppage-philosophy-container .btn-container {
    justify-self: center;
  }
}
@media screen and (max-width: 767px) {
  .toppage-philosophy-container .toppage-philosophy-inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }
  .toppage-philosophy-container .toppage-h-lv2-en {
    text-align: center;
  }
  .toppage-philosophy-container .toppage-philosophy-text {
    grid-row: span 1;
    text-align: center;
    font-size: 1rem;
  }
  .toppage-philosophy-container .btn-container {
    justify-self: center;
  }
}

.toppage-body {
  position: relative;
}
.toppage-body:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100% + 80px);
  background: #fff url("../images/bg_5.webp") repeat-y;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .toppage-body:before {
    background-size: 140% auto;
  }
}

/*-------------------
 toppage Business 
 -------------------*/
.toppage-business-container {
  position: relative;
  overflow: clip;
}
.toppage-business-container .toppage-business-header {
  position: relative;
  display: grid;
  gap: 40px 50px;
  align-items: end;
  grid-template-columns: auto 1fr;
}
.toppage-business-container .toppage-business-header .toppage-h-lv2-en {
  grid-area: 1/1/2/2;
}
.toppage-business-container .toppage-business-header .business-lead {
  grid-area: 1/2/3/3;
}
.toppage-business-container .toppage-business-header .btn-container {
  grid-area: 2/1/3/2;
}
.toppage-business-container .toppage-business-header {
  padding: 100px 0;
}
.toppage-business-container .business-lead {
  position: relative;
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767px) {
  .toppage-business-container .toppage-business-header {
    grid-template-columns: 1fr;
    gap: 30px;
    padding: 50px 0;
  }
  .toppage-business-container .toppage-business-header .toppage-h-lv2-en, .toppage-business-container .toppage-business-header .business-lead, .toppage-business-container .toppage-business-header .btn-container {
    grid-area: auto/auto/auto/auto;
  }
}

.toppage-business-bg {
  position: absolute;
  top: 0;
  left: 50%;
  aspect-ratio: 1440/1440;
  background: #fff url("../images/bg_5.webp") repeat-y;
  background-size: 100% auto;
  transform: translateX(-50%);
  width: 130vw;
  border-radius: 100%/30% 30% 0 0;
}

.toppage-business-body {
  position: relative;
}
.toppage-business-body .toppage-business-card {
  position: sticky;
  padding: 30px 50px 60px;
  border-radius: 50px 50px 0 0;
  min-height: 100dvh;
}
.toppage-business-body .toppage-business-card-inner {
  position: relative;
  margin: auto;
  display: flex;
  gap: 60px;
  justify-content: space-between;
}
.toppage-business-body .business-card-header {
  position: relative;
  width: 25vw;
  max-width: 35rem;
  color: #30A338;
}
.toppage-business-body .business-card-header .business-num {
  display: flex;
  gap: 15px;
  align-items: center;
  font-family: "Chillax-Medium", sans-serif;
  font-weight: 500;
  line-height: 1.5;
}
.toppage-business-body .business-card-header .label {
  font-size: 1.125rem;
}
.toppage-business-body .business-card-header .num {
  font-size: 2.5rem;
}
.toppage-business-body .business-card-header .business-card-title-en {
  margin: 0;
  font-family: "Chillax-Medium", sans-serif;
  font-size: clamp(40px, 5.4vw, 4rem);
  font-size: clamp(30px, 3.6vw, 4rem);
  font-weight: 500;
  line-height: 1.1;
  text-wrap: balance;
}
.toppage-business-body .business-card-body {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: row-reverse;
  gap: 60px;
}
.toppage-business-body .business-card-img {
  position: relative;
  flex: none;
  width: 50%;
  max-width: 600px;
  line-height: 0;
}
.toppage-business-body .business-card-img img {
  width: 100%;
  border-radius: 30px;
}
.toppage-business-body .business-card-text {
  flex: 1;
  position: relative;
  color: #30A338;
}
.toppage-business-body .business-card-text .title {
  position: relative;
  margin: 0 0 10px;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}
.toppage-business-body .business-card-text .label {
  position: relative;
  margin: 0 0 20px;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  display: flex;
  gap: 0.625em;
}
.toppage-business-body .business-card-text .label:before {
  flex: none;
  content: "";
  display: inline-block;
  position: relative;
  top: 0.437em;
  width: 0.625em;
  height: 0.625em;
  background: currentColor;
  border-radius: 100px;
}
.toppage-business-body .business-card-text .text {
  position: relative;
  margin: 0 0 20px;
  font-weight: 500;
  line-height: 2;
}
.toppage-business-body .toppage-business-card.grn_1 {
  background-image: linear-gradient(45deg, rgb(191, 218, 154) 0%, rgb(222, 236, 203) 100%), url("../images/bg_noise_grn_1.png");
}
.toppage-business-body .toppage-business-card.grn_2 {
  background-image: linear-gradient(45deg, rgb(116, 180, 94) 0%, rgb(179, 214, 167) 99.98%), url("../images/bg_noise_grn_2.png");
}
.toppage-business-body .toppage-business-card.grn_2 .business-card-header {
  color: #fff;
}
.toppage-business-body .toppage-business-card.grn_2 .business-card-text {
  color: #fff;
}
.toppage-business-body .toppage-business-card.grn_3 {
  background-image: linear-gradient(45deg, rgb(46, 162, 57) 0%, rgb(149, 208, 155) 100%), url("../images/bg_noise_grn_3.png");
}
.toppage-business-body .toppage-business-card.grn_3 .business-card-header {
  color: #fff;
}
.toppage-business-body .toppage-business-card.grn_3 .business-card-text {
  color: #fff;
}
.toppage-business-body .toppage-business-card:nth-of-type(1) {
  top: 100px;
  min-height: calc(100dvh - 100px);
}
.toppage-business-body .toppage-business-card:nth-of-type(2) {
  top: 200px;
  min-height: calc(100dvh - 200px);
}
.toppage-business-body .toppage-business-card:nth-of-type(3) {
  top: 300px;
  min-height: calc(100dvh - 300px);
}
.toppage-business-body .toppage-business-card:nth-of-type(4) {
  top: 400px;
  min-height: calc(100dvh - 400px);
}
@media screen and (min-width: 1000px) and (max-width: 1199px) {
  .toppage-business-body .business-card-body {
    gap: 30px;
  }
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .toppage-business-body:before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(100% - 60px);
    background: #fff url("../images/bg_5.webp") repeat-y;
    background-size: 100% auto;
    background-position: center bottom;
    pointer-events: none;
  }
  .toppage-business-body .toppage-business-card {
    min-height: 0;
    border-radius: 40px;
  }
  .toppage-business-body .business-card-body {
    gap: 30px;
  }
  .toppage-business-body .business-card-text .title {
    font-size: 1rem;
  }
  .toppage-business-body .business-card-text .label {
    font-size: 1.125rem;
  }
  .toppage-business-body .business-card-text .text {
    font-size: 0.875rem;
    line-height: 1.7;
  }
  .toppage-business-body .toppage-business-card:nth-of-type(1) {
    position: relative;
    top: 0;
    min-height: 0;
  }
  .toppage-business-body .toppage-business-card:nth-of-type(2) {
    position: relative;
    top: 0;
    min-height: 0;
  }
  .toppage-business-body .toppage-business-card:nth-of-type(3) {
    position: relative;
    top: 0;
    min-height: 0;
  }
  .toppage-business-body .toppage-business-card:nth-of-type(4) {
    position: relative;
    top: 0;
    min-height: 0;
  }
}
@media screen and (max-width: 767px) {
  .toppage-business-body:before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(100% - 60px);
    background: #fff url("../images/bg_5.webp") repeat-y;
    background-size: 140% auto;
    background-position: center bottom;
    pointer-events: none;
  }
  .toppage-business-body .toppage-business-card {
    padding: 40px 0;
    border-radius: 30px;
    min-height: 0;
  }
  .toppage-business-body .toppage-business-card-inner {
    flex-direction: column;
    gap: 30px;
    width: 90%;
  }
  .toppage-business-body .business-card-header {
    width: 100%;
    max-width: 100%;
  }
  .toppage-business-body .business-card-header .business-card-title-en {
    font-size: clamp(24px, 8.5vw, 2.6rem);
  }
  .toppage-business-body .business-card-body {
    flex-direction: column;
    gap: 30px;
    width: 100%;
    max-width: 100%;
  }
  .toppage-business-body .business-card-img {
    width: 100%;
    max-width: 100%;
  }
  .toppage-business-body .business-card-img img {
    border-radius: 20px;
  }
  .toppage-business-body .business-card-text .label {
    font-size: 1.25rem;
  }
  .toppage-business-body .toppage-business-card:nth-of-type(1) {
    position: relative;
    top: 0;
    min-height: 0;
  }
  .toppage-business-body .toppage-business-card:nth-of-type(2) {
    position: relative;
    top: 0;
    min-height: 0;
  }
  .toppage-business-body .toppage-business-card:nth-of-type(3) {
    position: relative;
    top: 0;
    min-height: 0;
  }
  .toppage-business-body .toppage-business-card:nth-of-type(4) {
    position: relative;
    top: 0;
    min-height: 0;
  }
}

/*-------------------
 toppage People 
 -------------------*/
.toppage-people-container {
  position: relative;
  display: grid;
  gap: 40px 80px;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(3, auto) 1fr;
  align-items: start;
}
.toppage-people-container .toppage-h-lv2-en {
  grid-area: 1/1/2/2;
}
.toppage-people-container .people-lead {
  grid-area: 2/1/3/2;
}
.toppage-people-container .toppage-h-lv2-en {
  grid-area: 1/1/2/2;
}
.toppage-people-container .people-lead {
  grid-area: 2/1/3/2;
}
.toppage-people-container #people_1.interview-item {
  grid-area: 3/1/4/2;
}
.toppage-people-container #people_2.interview-item {
  grid-area: 1/2/4/3;
}
.toppage-people-container .people-lead {
  position: relative;
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .toppage-people-container {
    display: block;
  }
  .toppage-people-container .toppage-h-lv2-en {
    margin-bottom: 30px;
  }
  .toppage-people-container .people-lead {
    margin-bottom: 60px;
  }
  .toppage-people-container #people_1.interview-item {
    margin-bottom: 60px;
  }
  .toppage-people-container .interview-item {
    max-width: 500px;
    margin-inline: auto;
  }
}
@media screen and (max-width: 767px) {
  .toppage-people-container {
    display: block;
  }
  .toppage-people-container .toppage-h-lv2-en {
    margin-bottom: 30px;
  }
  .toppage-people-container .people-lead {
    margin-bottom: 60px;
  }
  .toppage-people-container #people_1.interview-item {
    margin-bottom: 60px;
  }
}

/*-------------------
 toppage Environment 
 -------------------*/
.toppage-environment-container {
  position: relative;
  display: grid;
  gap: 40px 80px;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(3, auto) 1fr;
  align-items: start;
}
.toppage-environment-container .toppage-h-lv2-en {
  grid-area: 1/1/2/2;
}
.toppage-environment-container .environment-lead {
  grid-area: 2/1/3/2;
}
.toppage-environment-container .toppage-environment-slide {
  grid-area: 1/2/5/3;
}
.toppage-environment-container .toppage-environment-menu {
  grid-area: 3/1/4/2;
}
.toppage-environment-container .btn-container {
  grid-area: 4/1/5/2;
}
.toppage-environment-container .environment-lead {
  position: relative;
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.toppage-environment-container .toppage-environment-menu {
  position: relative;
}
.toppage-environment-container .toppage-environment-menu ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.toppage-environment-container .toppage-environment-menu a {
  display: flex;
  gap: 0 20px;
  align-items: center;
  color: #30A338;
  text-decoration: none;
}
.toppage-environment-container .toppage-environment-menu a:hover, .toppage-environment-container .toppage-environment-menu a:focus-visible, .toppage-environment-container .toppage-environment-menu a.is_current {
  color: #30A338;
}
.toppage-environment-container .toppage-environment-menu a:hover .num, .toppage-environment-container .toppage-environment-menu a:focus-visible .num, .toppage-environment-container .toppage-environment-menu a.is_current .num {
  border-radius: 100px;
  font-family: "Chillax-Medium", sans-serif;
  color: #fff;
  text-decoration: none;
  background-image: linear-gradient(90deg, rgb(100, 160, 140) 0%, rgb(140, 198, 63) 100%), url("../images/bg_noise.png");
  background-repeat: no-repeat, repeat;
  background-blend-mode: multiply;
  border: 0;
  transform: scale(1);
  transition: transform 0.3s ease-in-out;
}
.toppage-environment-container .toppage-environment-menu a:hover .label, .toppage-environment-container .toppage-environment-menu a:focus-visible .label, .toppage-environment-container .toppage-environment-menu a.is_current .label {
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
  text-underline-offset: 4px;
}
.toppage-environment-container .toppage-environment-menu .num-container {
  flex: none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
}
.toppage-environment-container .toppage-environment-menu .num {
  flex: none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  border-radius: 100px;
  font-family: "Chillax-Medium", sans-serif;
  font-size: 46px;
  color: #30A338;
  text-align: center;
  line-height: 1;
  font-weight: 500;
  text-decoration: none;
  background: #fff;
  border: 2px solid #30A338;
  transform: scale(0.6);
}
.toppage-environment-container .toppage-environment-menu .label {
  flex: 1;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .toppage-environment-container {
    display: block;
  }
  .toppage-environment-container .toppage-h-lv2-en {
    margin-bottom: 30px;
  }
  .toppage-environment-container .environment-lead {
    margin-bottom: 30px;
  }
  .toppage-environment-container .toppage-environment-menu {
    margin-bottom: 30px;
  }
  .toppage-environment-container .toppage-environment-menu a:hover .num, .toppage-environment-container .toppage-environment-menu a:focus-visible .num, .toppage-environment-container .toppage-environment-menu a.is_current .num {
    border: 0;
  }
  .toppage-environment-container .toppage-environment-menu .num-container {
    width: 60px;
  }
  .toppage-environment-container .toppage-environment-menu .num {
    width: 60px;
    height: 60px;
    border: 1px solid #30A338;
    font-size: 24px;
    transform: scale(1);
  }
}

/* 重なりカード */
.toppage-environment-slide {
  position: relative;
  width: 76%;
  margin: auto;
  aspect-ratio: 363/545;
  isolation: isolate;
}
.toppage-environment-slide .toppage-environment-slide-item {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.75s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.75s cubic-bezier(0.33, 1, 0.68, 1), filter 0.75s cubic-bezier(0.33, 1, 0.68, 1);
  transform-origin: center bottom;
  will-change: transform;
}
.toppage-environment-slide .toppage-environment-slide-item .img {
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 20px;
  box-shadow: 10px 10px 10px 0 rgba(0, 0, 0, 0.1);
}
.toppage-environment-slide .toppage-environment-slide-item .img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.toppage-environment-slide .toppage-environment-slide-item.is-front {
  z-index: 2;
  transform: translate(0, 0) rotate(-5deg) scale(1);
  opacity: 1;
  filter: none;
  pointer-events: auto;
}
.toppage-environment-slide .toppage-environment-slide-item.is-back {
  z-index: 1;
  transform: translate(6%, 0) rotate(5deg) scale(0.98);
  opacity: 0.88;
  filter: brightness(0.97);
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .toppage-environment-slide {
    width: 70%;
    max-width: 300px;
    margin-bottom: 60px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .toppage-environment-slide .toppage-environment-slide-item {
    transition-duration: 0.01ms;
  }
}
/*# sourceMappingURL=map/style.css.map */
