@charset "UTF-8";
/* animation
----------------------------------------- */
.smoothText {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: center;
  overflow: hidden;
}
.smoothText .text {
  -webkit-transform: translateY(110%);
  display: inline-block;
          transform: translateY(110%);
  white-space: pre-wrap;
}
.smoothText span {
  display: block;
}
.smoothText.is-anim .text {
  -webkit-animation: showText 0.7s cubic-bezier(0.19, 1, 0.22, 1.1) forwards;
          animation: showText 0.7s cubic-bezier(0.19, 1, 0.22, 1.1) forwards;
}
.smoothText.is-anim .text:nth-child(1) {
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}
.smoothText.is-anim .text:nth-child(2) {
  -webkit-animation-delay: 0.02s;
          animation-delay: 0.02s;
}
.smoothText.is-anim .text:nth-child(3) {
  -webkit-animation-delay: 0.04s;
          animation-delay: 0.04s;
}
.smoothText.is-anim .text:nth-child(4) {
  -webkit-animation-delay: 0.06s;
          animation-delay: 0.06s;
}
.smoothText.is-anim .text:nth-child(5) {
  -webkit-animation-delay: 0.08s;
          animation-delay: 0.08s;
}
.smoothText.is-anim .text:nth-child(6) {
  -webkit-animation-delay: 0.1s;
          animation-delay: 0.1s;
}
.smoothText.is-anim .text:nth-child(7) {
  -webkit-animation-delay: 0.12s;
          animation-delay: 0.12s;
}
.smoothText.is-anim .text:nth-child(8) {
  -webkit-animation-delay: 0.14s;
          animation-delay: 0.14s;
}
.smoothText.is-anim .text:nth-child(9) {
  -webkit-animation-delay: 0.16s;
          animation-delay: 0.16s;
}
.smoothText.is-anim .text:nth-child(10) {
  -webkit-animation-delay: 0.18s;
          animation-delay: 0.18s;
}
.smoothText.is-anim .text:nth-child(11) {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
.smoothText.is-anim .text:nth-child(12) {
  -webkit-animation-delay: 0.22s;
          animation-delay: 0.22s;
}
.smoothText.is-anim .text:nth-child(13) {
  -webkit-animation-delay: 0.24s;
          animation-delay: 0.24s;
}
.smoothText.is-anim .text:nth-child(14) {
  -webkit-animation-delay: 0.26s;
          animation-delay: 0.26s;
}
.smoothText.is-anim .text:nth-child(15) {
  -webkit-animation-delay: 0.28s;
          animation-delay: 0.28s;
}
.smoothText.is-anim .text:nth-child(16) {
  -webkit-animation-delay: 0.3s;
          animation-delay: 0.3s;
}
.smoothText.is-anim .text:nth-child(17) {
  -webkit-animation-delay: 0.32s;
          animation-delay: 0.32s;
}
.smoothText.is-anim .text:nth-child(18) {
  -webkit-animation-delay: 0.34s;
          animation-delay: 0.34s;
}
.smoothText.is-anim .text:nth-child(19) {
  -webkit-animation-delay: 0.36s;
          animation-delay: 0.36s;
}
.smoothText.is-anim .text:nth-child(20) {
  -webkit-animation-delay: 0.38s;
          animation-delay: 0.38s;
}
.smoothText.is-anim .text:nth-child(21) {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}
.smoothText.is-anim .text:nth-child(22) {
  -webkit-animation-delay: 0.42s;
          animation-delay: 0.42s;
}
.smoothText.is-anim .text:nth-child(23) {
  -webkit-animation-delay: 0.44s;
          animation-delay: 0.44s;
}
.smoothText.is-anim .text:nth-child(24) {
  -webkit-animation-delay: 0.46s;
          animation-delay: 0.46s;
}
.smoothText.is-anim .text:nth-child(25) {
  -webkit-animation-delay: 0.48s;
          animation-delay: 0.48s;
}

@-webkit-keyframes showText {
  0% {
    -webkit-transform: translateY(110%);
            transform: translateY(110%);
  }
  100% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
}

@keyframes showText {
  0% {
    -webkit-transform: translateY(110%);
            transform: translateY(110%);
  }
  100% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
}
.textUp {
  -webkit-transition: all 0.35s cubic-bezier(0.17, 0.67, 0.32, 1);
  -webkit-transform: translateY(2rem);
          transform: translateY(2rem);
  opacity: 0;
  transition: all 0.35s cubic-bezier(0.17, 0.67, 0.32, 1);
}
.textUp.is-anim {
  -webkit-transition-delay: 0.2s;
  -webkit-transform: translate(0);
          transform: translate(0);
  opacity: 1;
          transition-delay: 0.2s;
}

.popShow {
  -webkit-transition: all 0.3s cubic-bezier(0.09, 0.6, 0.36, 1.34) 0.3s;
  -webkit-transform: translateY(20%) scale(0.6);
          transform: translateY(20%) scale(0.6);
  opacity: 0;
  transition: all 0.3s cubic-bezier(0.09, 0.6, 0.36, 1.34) 0.3s;
}
.popShow.is-anim {
  -webkit-transform: translateY(0) scale(1);
          transform: translateY(0) scale(1);
  opacity: 1;
}

.popShowLogo {
  -webkit-transition: all 0.3s cubic-bezier(0.09, 0.6, 0.36, 1.34) 0.3s;
  -webkit-transform: translateY(20%) scale(0.6);
          transform: translateY(20%) scale(0.6);
  opacity: 0;
  transition: all 0.3s cubic-bezier(0.09, 0.6, 0.36, 1.34) 0.3s;
}
.popShowLogo.is-anim {
  -webkit-transform: translateY(0) scale(1);
          transform: translateY(0) scale(1);
  opacity: 1;
}

.cardShow {
  -webkit-transition: all 0.3s cubic-bezier(0.09, 0.6, 0.36, 1.34) 0.3s;
  -webkit-transform: translateY(20%);
          transform: translateY(20%);
  opacity: 0;
  transition: all 0.3s cubic-bezier(0.09, 0.6, 0.36, 1.34) 0.3s;
}
.cardShow:nth-child(1) {
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
}
.cardShow:nth-child(2) {
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
}
.cardShow:nth-child(3) {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}
.cardShow:nth-child(4) {
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.cardShow:nth-child(5) {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
.cardShow:nth-child(6) {
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}
.cardShow:nth-child(7) {
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}
.cardShow:nth-child(8) {
  -webkit-transition-delay: 0.7s;
          transition-delay: 0.7s;
}
.cardShow:nth-child(9) {
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}
.cardShow:nth-child(10) {
  -webkit-transition-delay: 0.9s;
          transition-delay: 0.9s;
}
.cardShow.is-anim {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
}

.textBg {
  -webkit-animation-name: bgTextAnime;
  -webkit-animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
          animation-duration: 1s;
          animation-fill-mode: forwards;
          animation-name: bgTextAnime;
  opacity: 0;
}
.textBg.is-bg::before {
  -webkit-transform-origin: left center;
  -webkit-animation: bgTextAnimeLR 1.4s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  display: inline-block;
  z-index: -1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0 auto;
          transform-origin: left center;
  background-color: #128f43;
  content: "";
          animation: bgTextAnimeLR 1.4s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

@-webkit-keyframes bgTextAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes bgTextAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes bgTextAnimeLR {
  0% {
    -webkit-transform: scaleX(0) translateX(-5%);
            transform: scaleX(0) translateX(-5%);
    opacity: 0;
  }
  30% {
    -webkit-transform: scaleX(1) translateX(0);
            transform: scaleX(1) translateX(0);
  }
  100% {
    -webkit-transform: scaleX(1) translateX(0);
            transform: scaleX(1) translateX(0);
  }
  30%, 100% {
    opacity: 1;
  }
}
@keyframes bgTextAnimeLR {
  0% {
    -webkit-transform: scaleX(0) translateX(-5%);
            transform: scaleX(0) translateX(-5%);
    opacity: 0;
  }
  30% {
    -webkit-transform: scaleX(1) translateX(0);
            transform: scaleX(1) translateX(0);
  }
  100% {
    -webkit-transform: scaleX(1) translateX(0);
            transform: scaleX(1) translateX(0);
  }
  30%, 100% {
    opacity: 1;
  }
}
.bgTextTriggerLR {
  opacity: 0;
}

.bgTextTrigger {
  opacity: 0;
}
.bgTextTrigger.is-anim {
  -webkit-animation-name: bgTextAnimeSecond;
  -webkit-animation-delay: 0s;
  -webkit-animation-fill-mode: forwards;
          animation-delay: 0s;
          animation-fill-mode: forwards;
          animation-name: bgTextAnimeSecond;
  opacity: 0;
}

@-webkit-keyframes bgTextAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes bgTextAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
a,
p,
span,
em,
small,
strong,
sub,
sup,
mark,
del,
ins,
strike,
abbr,
dfn,
blockquote,
q,
cite,
code,
pre,
ol,
ul,
li,
dl,
dt,
dd,
div,
section,
article,
main,
aside,
nav,
header,
hgroup,
footer,
img,
figure,
figcaption,
address,
time,
audio,
video,
canvas,
iframe,
details,
summary,
fieldset,
form,
input,
textarea,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

* {
  font-size: inherit;
  line-height: inherit;
  font-family: inherit;
}

a,
a:visited,
a:link,
a:active {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

article,
aside,
footer,
header,
nav,
section,
main {
  display: block;
}

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

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

ol li,
ul li {
  list-style: none;
}

img,
iframe,
video {
  max-width: 100%;
}

img {
  height: auto;
  border: none;
  vertical-align: top;
}

br {
  line-height: 1;
}

blockquote,
q {
  quotes: none;
}

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

[hidden] {
  display: none !important;
}

[disabled] {
  cursor: not-allowed;
}

:focus:not(:focus-visible) {
  outline: none;
}

.sr-only {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
  top: -9999px;
  left: -9999px;
}

input,
select,
label {
  vertical-align: middle;
}

[type=text] {
  line-height: normal;
}

input[type=text],
input[type=email],
input[type=tel],
input[type=submit] {
  -webkit-appearance: none;
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
}

textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: 0;
  border-radius: 0;
  outline: none;
  background: transparent;
  resize: none;
  resize: vertical;
}

*:focus {
  outline: none;
}

button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0;
  border: none;
  outline: none;
  background-color: transparent;
  cursor: pointer;
}

address {
  font-style: normal;
}

.l-main {
  background-image: -webkit-linear-gradient(rgba(18, 143, 67, 0.2) 1px, transparent 0), -webkit-linear-gradient(left, rgba(18, 143, 67, 0.2) 1px, transparent 0);
  background-image: linear-gradient(rgba(18, 143, 67, 0.2) 1px, transparent 0), linear-gradient(90deg, rgba(18, 143, 67, 0.2) 1px, transparent 0);
  background-position: -1.5rem 1rem;
  background-size: 9rem 9rem;
  background-color: #fff;
}

html {
  font-size: 2.6666666667vw;
}

* {
  -webkit-font-smoothing: antialiased;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

body {
  -ms-scroll-chaining: none;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
  -webkit-font-kerning: normal;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  height: 100%;
  overflow-x: hidden;
      overscroll-behavior: none;
  color: #128f43;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.15;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
          font-kerning: normal;
  letter-spacing: 0.1em;
  counter-reset: number 0;
}
body.is-menuOpen {
  overflow: hidden;
}

.wrap {
  overflow-x: hidden;
}

a {
  -webkit-transition: 0.5s;
  outline: none;
  color: inherit;
  transition: 0.5s;
}
a:hover {
  opacity: 0.7;
}
a::after {
  -webkit-transition: 0.5s;
  transition: 0.5s;
}

/* container
----------------------------------------- */
.l-container {
  width: 100%;
  max-width: 1254px;
  margin: 0 auto;
  padding-right: 1.65rem;
  padding-left: 1.65rem;
}

/* footer
----------------------------------------- */
.l-footer {
  padding: 7.5rem 0 2.6rem;
  background-image: -webkit-linear-gradient(rgba(18, 143, 67, 0.2) 1px, transparent 0), -webkit-linear-gradient(left, rgba(18, 143, 67, 0.2) 1px, transparent 0);
  background-image: linear-gradient(rgba(18, 143, 67, 0.2) 1px, transparent 0), linear-gradient(90deg, rgba(18, 143, 67, 0.2) 1px, transparent 0);
  background-position: -1.5rem 1rem;
  background-size: 9rem 9rem;
  background-color: #fff;
}

.l-footer__about {
  padding: 2.8rem 1.9rem 2rem;
  border-radius: 3.4rem;
  background-image: url(../images/home/footer_about_bg.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.l-footer__aboutTitle {
  margin: 0 0 2.5rem 0;
  color: #fff;
  font-size: 2.3rem;
  line-height: 1.8;
  letter-spacing: 0.2em;
  text-align: center;
}
.l-footer__aboutTitle span {
  font-weight: 500;
  font-family: "Jost", sans-serif;
}

.l-footer__aboutCatch {
  margin: 0 0 2rem 0;
  color: #fff;
  font-weight: 600;
  font-size: 1.7rem;
  line-height: 1.87;
  letter-spacing: 0.2em;
  text-align: center;
}

.l-footer__aboutText {
  color: #fff;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.9;
  letter-spacing: 0.125em;
  text-align: justify;
}
.l-footer__aboutText br {
  display: none;
}

.l-footer__contact {
  margin: 5.5rem 0 6.6rem;
}

.l-footer__contactText {
  margin: 0 0 1.5rem 0;
  font-size: 1.5rem;
  line-height: 2;
  letter-spacing: 0.165em;
  text-align: center;
}
.l-footer__contactText br.sp {
  display: block;
}

.l-footer__contactLink {
  -webkit-transition: all 0.5s ease;
  display: block;
  position: relative;
  width: 23.8rem;
  margin: 0 auto;
  padding: 0.7rem 2.9rem 0.7rem 3.7rem;
  border: 0.3rem solid #128f43;
  border-radius: 0.88rem;
  background-color: #128f43;
  color: #fff;
  font-weight: 500;
  font-size: 2.3rem;
  line-height: 1;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.125em;
  transition: all 0.5s ease;
}
.l-footer__contactLink .arrow {
  -webkit-transition: all 0.5s ease;
  -webkit-transform: translate(0%, -50%);
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 2.9rem;
          transform: translate(0%, -50%);
  font-weight: 600;
  font-size: 2.3rem;
  transition: all 0.5s ease;
}
.l-footer__contactLink:hover {
  background-color: #fff;
  color: #128f43;
  opacity: 1;
}
.l-footer__contactLink:hover .arrow {
  -webkit-transform: translate(0.5rem, -50%);
          transform: translate(0.5rem, -50%);
  color: #128f43;
}

.l-footer-bottom {
  position: relative;
}

.l-footer-bottom__company {
  -webkit-transform: translate(0%, 0%);
          transform: translate(0%, 0%);
}

.l-footer-bottom__text {
  margin: 0 0 2.5rem 0;
  color: #140b0b;
  font-size: 1.5rem;
  line-height: 1;
  letter-spacing: 0.16em;
  text-align: center;
}

.l-footer-bottom__companyImg {
  margin: 0 auto;
  text-align: center;
}
.l-footer-bottom__companyImg:not(:last-child) {
  margin: 0 auto 0.9rem;
}
.l-footer-bottom__companyImg img {
  -o-object-fit: contain;
  width: 100%;
     object-fit: contain;
}
.l-footer-bottom__companyImg:nth-child(1) {
  width: 24.7rem;
}
.l-footer-bottom__companyImg:nth-child(2) {
  width: 7.85rem;
}

.l-footer__logo {
  margin: 4.6rem 0 6.5rem;
}

.l-footer__logoLink {
  display: block;
  text-align: center;
}
.l-footer__logoLink img {
  -o-object-fit: contain;
  width: 15.3rem;
     object-fit: contain;
}

.l-footer__copy {
  color: #130b0b;
  font-weight: 600;
  font-size: 1.1rem;
  line-height: 1.625;
  letter-spacing: 0.01em;
  text-align: center;
}

/* hamburger
----------------------------------------- */
.l-header__la {
  z-index: 4;
  position: absolute;
  top: 3.4rem;
  right: 7.2rem;
  width: 6rem;
}

.l-header__laList {
  -webkit-box-pack: justify;
  display: -webkit-box;
  display: flex;
          justify-content: space-between;
}

.l-header__laItem {
  position: relative;
  width: 50%;
  line-height: 1;
}
.l-header__laItem:last-child {
  text-align: right;
}
.l-header__laItem:last-child::before {
  -webkit-transform: translateY(-50%);
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 1px;
  height: 1.4rem;
          transform: translateY(-50%);
  background-color: #fff;
  content: "";
}

.l-header__laLink {
  display: inline-block;
  color: #fff;
  font-weight: 500;
  font-size: 1.4rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.1em;
  white-space: nowrap;
}

.l-hamburger__toggle {
  -webkit-transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1);
  -webkit-transform: translate3d(0, 2rem, 0);
  display: block;
  z-index: 4;
  position: fixed;
  top: 2.3rem;
  right: 2rem;
  width: 3.2rem;
          transform: translate3d(0, 2rem, 0);
  cursor: pointer;
  opacity: 0;
  transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1);
}
.l-hamburger__toggle.is-active {
  width: 2.5rem;
  height: 2.5rem;
}
.l-hamburger__toggle.is-active .l-hamburger__toggleWrap {
  height: 2.5rem;
}
.l-hamburger__toggle.is-active .l-hamburger__toggleWrap span {
  background-color: #128f43;
}
.l-hamburger__toggle.is-active .l-hamburger__toggleWrap span:nth-of-type(1) {
  -webkit-transform: translateX(-0.3rem) translateY(1.2rem) rotate(-45deg);
          transform: translateX(-0.3rem) translateY(1.2rem) rotate(-45deg);
}
.l-hamburger__toggle.is-active .l-hamburger__toggleWrap span:nth-of-type(2) {
  -webkit-transform: translateX(-0.3rem) translateY(50%);
  top: 50%;
          transform: translateX(-0.3rem) translateY(50%);
  opacity: 0;
}
.l-hamburger__toggle.is-active .l-hamburger__toggleWrap span:nth-of-type(3) {
  -webkit-transform: translateX(-0.3rem) translateY(-1.2rem) rotate(45deg);
          transform: translateX(-0.3rem) translateY(-1.2rem) rotate(45deg);
}
.l-hamburger__toggle.is-active .l-hamburger__toggleText {
  display: none;
}
.l-hamburger__toggle:hover {
  opacity: 1;
}
.l-hamburger__toggle.is-anim {
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  opacity: 1;
}

.l-hamburger__toggleWrap {
  -webkit-transition: all 0.5s ease;
  position: relative;
  width: 100%;
  height: 1.1rem;
  transition: all 0.5s ease;
}
.l-hamburger__toggleWrap span {
  -webkit-transition: all 0.5s ease;
  display: inline-block;
  position: absolute;
  width: 3.2rem;
  height: 0.1rem;
  background-color: #fff;
  transition: all 0.5s ease;
}
.l-hamburger__toggleWrap span:nth-of-type(1) {
  top: 0;
  left: 0;
}
.l-hamburger__toggleWrap span:nth-of-type(2) {
  -webkit-transition: all 0.5s ease;
  top: 0.5rem;
  left: 0;
  transition: all 0.5s ease;
}
.l-hamburger__toggleWrap span:nth-of-type(3) {
  bottom: 0;
  left: 0;
}

.l-hamburger__toggleText {
  -webkit-transition: all 0.5s ease;
  -webkit-transform: scale(0.7);
  margin: 0 0 0.3rem 0;
          transform: scale(0.7);
  color: #fff;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1;
  font-family: "Jost", sans-serif;
  transition: all 0.5s ease;
}

/* header
----------------------------------------- */
.l-header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 8.87rem;
  background-image: -webkit-linear-gradient(rgba(18, 143, 67, 0.2) 1px, transparent 0), -webkit-linear-gradient(left, rgba(18, 143, 67, 0.2) 1px, transparent 0);
  background-image: linear-gradient(rgba(18, 143, 67, 0.2) 1px, transparent 0), linear-gradient(90deg, rgba(18, 143, 67, 0.2) 1px, transparent 0);
  background-position: -1.5rem 1rem;
  background-size: 9rem 9rem;
  background-color: #fff;
}

.l-header__logo {
  -webkit-transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1);
  -webkit-transform: translate(-50%, 0%) translate3d(0, 2rem, 0);
  position: absolute;
  top: 4.8rem;
  left: 50%;
  width: 9rem;
          transform: translate(-50%, 0%) translate3d(0, 2rem, 0);
  opacity: 0;
  transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1);
}
.l-header__logo.is-active {
  width: 6rem;
}
.l-header__logo.is-anim {
  -webkit-transform: translate(-50%, 0%) translate3d(0, 0, 0);
          transform: translate(-50%, 0%) translate3d(0, 0, 0);
  opacity: 1;
}

.l-header__logoLink {
  display: block;
}

/* menu
----------------------------------------- */
.l-menu {
  -webkit-transition: all 0.5s ease;
  display: block;
  visibility: hidden;
  z-index: -1;
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  padding: 5.45rem 4.5rem 8.4rem;
  overflow-y: scroll;
  background-color: #fff;
  opacity: 0;
  transition: all 0.5s ease;
}
.l-menu.is-active {
  -webkit-animation-duration: 0.5s;
  visibility: visible;
  z-index: 3;
          animation-duration: 0.5s;
  opacity: 1;
}

.l-menu__logo {
  width: 14rem;
}
.l-menu__logo img {
  -o-object-fit: contain;
  width: 100%;
     object-fit: contain;
}

.l-menu__logoLink {
  display: block;
}

.l-menu__list {
  margin: 5.56rem 0 0;
}

.l-menu__item:not(:last-child) {
  margin: 0 0 4.2rem 0;
}

.l-menu__link {
  padding: 0 0 0 1.6rem;
  border-left: 1px solid #128f43;
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 1.75;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.06em;
}

/* section
----------------------------------------- */
.l-section__title {
  -webkit-text-stroke: 1px #128f43;
  color: rgba(255, 255, 255, 0);
  font-weight: 600;
  font-size: 3.5rem;
  line-height: 1.23;
  letter-spacing: 0.125em;
}

.l-section__titleWrap {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: start;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: flex-start;
}
.l-section__titleWrap .text {
  font-weight: 600;
  font-family: "Poppins", sans-serif;
}

/* climate
----------------------------------------- */
.p-home-climate {
  position: relative;
  padding: 8rem 0 3.7rem;
}
.p-home-climate .l-section__title {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

.p-home-climate__title {
  font-weight: 600;
  font-size: 1.8rem;
  line-height: 1.85;
  letter-spacing: 0.31em;
}
.p-home-climate__title .l-section__titleWrap .text {
  border-bottom: 2px solid #128f43;
}
.p-home-climate__title .l-section__titleWrap .text.sp {
  display: block;
}
.p-home-climate__title .l-section__titleWrap .text.pc {
  display: none;
}

.p-home-climate__text {
  margin: 1.5rem 0 0;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.89;
  letter-spacing: 0.15em;
  text-align: justify;
}
.p-home-climate__text br.pc {
  display: none;
}

.p-home-climate__img {
  position: relative;
  overflow: hidden;
  border-radius: 1.05rem;
}
.p-home-climate__img::before {
  display: block;
  padding-top: 53.62%;
  content: "";
}
.p-home-climate__img img {
  -o-object-fit: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
     object-fit: cover;
  font-family: "object-fit: cover;";
}

.p-home-climate__textWrap {
  margin: -1.2rem 0 0;
  padding: 0 0.6rem 0;
}
.p-home-climate__titleText .text {
  display: block;
  z-index: 1;
  position: relative;
  padding: 0 0.9rem;
  color: #fff;
  font-weight: 600;
  font-size: 1.35rem;
  line-height: 2.4;
  letter-spacing: 0.16em;
}
.p-home-climate__titleText .textBg {
  display: inline-block;
}

/* event
----------------------------------------- */
.p-home-event {
  padding: 4.2rem 0 3.6rem;
}
.p-home-event .l-container .l-section__title .l-section__titleWrap {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: center;
}

.p-home-event__list {
  width: 100vw;
  margin: 4.2rem calc(50% - 50vw);
}

.p-home-event__item {
  pointer-events: none;
  position: relative;
}
.p-home-event__item:not(:last-child) {
  margin: 0 0 3.2rem 0;
}
.p-home-event__item figure {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.p-home-event__item figure::before {
  display: block;
  padding-top: 67.43%;
  content: "";
}
.p-home-event__item figure img {
  -o-object-fit: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
     object-fit: cover;
  font-family: "object-fit: cover;";
}
.p-home-event__item:hover {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.p-home-event__link {
  -webkit-transition: all 0.3s ease;
  pointer-events: none;
  transition: all 0.3s ease;
}
.p-home-event__link:hover {
  opacity: 1;
}

.p-home-event__link--sp{
  width: 100%;
  height: 35.4rem;
  display: block;
  pointer-events: auto;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
}

.p-home-event__desc {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: flex;
          flex-direction: column;
          align-items: center;
          justify-content: center;
  width: 100%;
  padding: 2.45rem 1.75rem 0;
  background-image: url(../images/home/event_item_bg_sp.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.p-home-event__descWrap {
  width: 100%;
}

.p-home-event__title {
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.333333;
  letter-spacing: 0.115em;
  text-align: left;
}
.p-home-event__title span {
  display: inline-block;
  font-family: "Jost", sans-serif;
}

.p-home-event__date {
  margin: 1.2rem 0 0 0;
  padding: 0 0 1.5rem 0;
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 2.316;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.115em;
}

.p-home-event__text {
  display: none;
  margin: 0 0 3.2rem 0;
  padding: 0 0 2.1rem 0;
  border-bottom: 1px solid #128f43;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.8915;
  letter-spacing: 0.125em;
}

.p-home-event__next {
  -webkit-box-pack: center;
  display: -webkit-box;
  display: flex;
          justify-content: center;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  padding: 4rem 0.9rem 3.5rem;
  background-image: url(../images/home/event_next_bg.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-color: #aaa;
}

.p-home-event__nextImg {
  display: none;
}

.p-home-event__nextText {
  width: 81.8%;
  margin: 0 auto;
}

.p-home-event__nextTitle {
  -webkit-box-pack: center;
  -webkit-box-align: center;
  display: -webkit-box;
  display: flex;
          align-items: center;
          justify-content: center;
  margin: 0 0 1.5rem 0;
}
.p-home-event__nextTitle span {
  color: #fff;
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 1.43;
  letter-spacing: 0.075em;
}
.p-home-event__nextTitle span.date {
  font-size: 2rem;
  font-family: "Montserrat", sans-serif;
}
.p-home-event__nextTitle span.ja {
  margin-left: 1rem;
}
.p-home-event__nextFigure::before, .p-home-event__nextFigure::after {
  display: inline-block;
  position: absolute;
  top: -4rem;
  width: 24.5rem;
  height: 17rem;
  background-image: url("../images/common/evemt_tree_icon.svg");
  background-position: 0 0;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  vertical-align: middle;
}
.p-home-event__nextFigure::before {
  left: -28rem;
}
.p-home-event__nextFigure::after {
  right: -28rem;
}

.p-home-event__no {
  margin: 1.4rem 0 0;
  color: #fff;
  font-weight: 600;
  font-size: 2rem;
  line-height: 1.46;
  font-family: "Montserrat", sans-serif;
  letter-spacing: 0.075em;
  text-align: center;
}

.p-home-event__cta {
  margin-top: 2rem;
}

.p-home-event__ctaText {
  color: #fff;
  font-weight: 600;
  font-size: 1.2rem;
  text-align: center;
}

.p-home-event__ctaLink {
  -webkit-box-pack: center;
  -webkit-box-align: center;
  display: -webkit-box;
  display: flex;
          align-items: center;
          justify-content: center;
  width: 22rem;
  margin: 1.2rem auto 0;
  padding: 1rem 0;
  border-radius: 10rem;
  background-color: #fff;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1;
  letter-spacing: 0.2em;
  text-align: center;
}
.p-home-event__ctaLink::after {
  display: inline-block;
  width: 2.4rem;
  height: 2.4rem;
  margin-left: 1rem;
  background-image: url("../images/home/green_circle_arrow.png");
  background-position: 0 0;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  vertical-align: middle;
}
.p-home-event__ctaLink:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  opacity: 1;
}
.p-home-event__ctaLink:hover .arrow {
  -webkit-transform: scale(1.05) translateX(0.5rem);
          transform: scale(1.05) translateX(0.5rem);
}

.p-home-event__accordion {
  border-top: 1px solid #128f43;
}

.p-home-event__accordionBtn {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: start;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: flex-start;
  padding: 2rem 0;
  cursor: pointer;
  pointer-events: all;
}
.p-home-event__accordionBtn .icon {
  display: inline-block;
  position: relative;
  width: 1.9rem;
  height: 1.9rem;
  margin: 0 1.3rem 0 0;
}
.p-home-event__accordionBtn .icon::before {
  -webkit-transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transform: translate(-50%, -50%);
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.9rem;
  height: 0.1rem;
          transform: translate(-50%, -50%);
  background-color: #128f43;
  content: "";
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}
.p-home-event__accordionBtn .icon::after {
  -webkit-transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transform: translate(-50%, -50%);
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.1rem;
  height: 1.9rem;
          transform: translate(-50%, -50%);
  background-color: #128f43;
  content: "";
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}
.p-home-event__accordionBtn.close .close {
  display: none;
}
.p-home-event__accordionBtn.close .read {
  display: inline-block;
}
.p-home-event__accordionBtn.open .close {
  display: inline-block;
}
.p-home-event__accordionBtn.open .read {
  display: none;
}
.p-home-event__accordionBtn.open .icon::before {
  -webkit-transform: translate(-50%, -50%) rotateZ(45deg);
          transform: translate(-50%, -50%) rotateZ(45deg);
}
.p-home-event__accordionBtn.open .icon::after {
  -webkit-transform: translate(-50%, -50%) rotateZ(45deg);
          transform: translate(-50%, -50%) rotateZ(45deg);
}
.p-home-event__accordionBtn .read {
  -webkit-transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
  margin: 0.2rem 0 0;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.65;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.14em;
  transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}
.p-home-event__accordionBtn .close {
  -webkit-transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
  margin: 0.2rem 0 0;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.65;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.14em;
  transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}

/* join
----------------------------------------- */
.p-home-join {
  padding: 3.5rem 0 4rem;
  background-image: url(../images/home/join_bg_sp.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.p-home-join .l-section__titleWrap {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: center;
}
.p-home-join .l-section__title {
  -webkit-text-stroke: 1px #fff;
  color: #fff;
  text-align: center;
}

.p-home-join__text {
  margin: 1.6rem 0 0;
  color: #fff;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.89;
  letter-spacing: 0.15em;
  text-align: justify;
}
.p-home-join__text br.pc {
  display: none;
}

.p-home-join__wrap {
  position: relative;
  width: 100vw;
  margin: 2.5rem calc(50% - 50vw) 3rem;
}

.p-home-join__box {
  width: 84.8%;
  margin: 0 auto;
  padding: 2rem 0 2.6rem;
  background-image: url(../images/home/join_bg_white_sp.png);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
.p-home-join__box:not(:last-child) {
  margin: 0 auto 1.6rem;
}
.p-home-join__box figure {
  width: 84%;
  margin: 0 auto;
}
.p-home-join__box:first-of-type .p-home-join__boxText {
  margin: 1.85rem 0 0;
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1.4;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-home-join__box:first-of-type figure {
  width: 75.4%;
}
.p-home-join__box:nth-of-type(2) .p-home-join__boxText {
  margin: 3.15rem 0 0;
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1.4;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-home-join__box:nth-of-type(2) figure {
  width: 69.5%;
}

.p-home-join__title {
  margin: 0 0 3.2rem 0;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1;
  letter-spacing: 0.2em;
  text-align: center;
}
.p-home-join__title span {
  font-size: 1.1rem;
  letter-spacing: 0.2em;
}

.p-home-join__link {
  -webkit-transition: all 0.2s ease;
  display: block;
  width: 25.6rem;
  margin: 0 auto;
  padding: 0.625rem 0;
  border: 1px solid #128f43;
  border-radius: 2.2rem;
  background-color: #fff;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 2.15;
  letter-spacing: 0.2em;
  text-align: center;
  transition: all 0.2s ease;
}
.p-home-join__link .arrow {
  -webkit-transition: all 0.2s ease;
  display: inline-block;
  font-weight: 600;
  font-size: 1.2rem;
  transition: all 0.2s ease;
}
.p-home-join__link:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  opacity: 1;
}
.p-home-join__link:hover .arrow {
  -webkit-transform: scale(1.05) translateX(0.5rem);
          transform: scale(1.05) translateX(0.5rem);
}

.p-home-join__handshake {
  -webkit-transform: translate(-50%, -50%);
  z-index: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 4.5rem;
  height: 2.9rem;
          transform: translate(-50%, -50%);
  background-image: url(../images/home/handshake_icon.svg);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.p-home-join__handshake.popShow.is-anim {
  -webkit-transform: translate(-50%, -50%) scale(1);
  -webkit-animation: laggy 2000ms infinite step-end;
          transform: translate(-50%, -50%) scale(1);
          animation: laggy 2000ms infinite step-end;
}

@-webkit-keyframes laggy {
  0% {
    -webkit-transform: translate(-50%, -50%) rotateZ(2deg);
            transform: translate(-50%, -50%) rotateZ(2deg);
  }
  10% {
    -webkit-transform: translate(-50%, -50%) rotateZ(0);
            transform: translate(-50%, -50%) rotateZ(0);
  }
  20% {
    -webkit-transform: translate(-50%, -50%) rotateZ(2deg);
            transform: translate(-50%, -50%) rotateZ(2deg);
  }
  30% {
    -webkit-transform: translate(-50%, -50%) rotateZ(0);
            transform: translate(-50%, -50%) rotateZ(0);
  }
  100% {
    -webkit-transform: translate(-50%, -50%) rotateZ(0);
            transform: translate(-50%, -50%) rotateZ(0);
  }
}

@keyframes laggy {
  0% {
    -webkit-transform: translate(-50%, -50%) rotateZ(2deg);
            transform: translate(-50%, -50%) rotateZ(2deg);
  }
  10% {
    -webkit-transform: translate(-50%, -50%) rotateZ(0);
            transform: translate(-50%, -50%) rotateZ(0);
  }
  20% {
    -webkit-transform: translate(-50%, -50%) rotateZ(2deg);
            transform: translate(-50%, -50%) rotateZ(2deg);
  }
  30% {
    -webkit-transform: translate(-50%, -50%) rotateZ(0);
            transform: translate(-50%, -50%) rotateZ(0);
  }
  100% {
    -webkit-transform: translate(-50%, -50%) rotateZ(0);
            transform: translate(-50%, -50%) rotateZ(0);
  }
}
/* member
----------------------------------------- */
.p-home-member {
  padding: 3.6rem 0 0;
}
.p-home-member .l-section__title {
  margin: 0 0 3.8rem 0;
}
.p-home-member .l-section__titleWrap {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: center;
}
.p-home-member__block:not(:last-child) {
  margin: 0 0 1.9rem 0;
}

.p-home-member__title {
  font-size: 1.3rem;
  line-height: 1;
  letter-spacing: 0.115em;
}

.p-home-member__list {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: start;
  -webkit-box-pack: start;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
  flex-wrap: wrap;
          align-items: flex-start;
          justify-content: flex-start;
  margin: 1.75rem 0 0;
}

.p-home-member__item {
  width: 44.6%;
}
.p-home-member__item:not(:nth-child(2n)) {
  margin: 0 10.8% 3.3rem 0;
}
.p-home-member__item figure {
  position: relative;
  margin: 0 0 1rem 0;
  overflow: hidden;
}
.p-home-member__item figure::before {
  display: block;
  padding-top: 100%;
  content: "";
}
.p-home-member__item figure img {
  -o-object-fit: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
     object-fit: cover;
  font-family: "object-fit: cover;";
}

.p-home-member__detail {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: end;
  -webkit-box-pack: justify;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: flex-end;
          justify-content: space-between;
}

.p-home-member__name01 {
  color: #150d0e;
  font-weight: 600;
  font-size: 1.1rem;
  line-height: 1;
  letter-spacing: 0.16em;
}

.p-home-member__name02 {
  -webkit-transform: scale(0.7);
  display: block;
  margin: 0 -0.8rem 0 0;
          transform: scale(0.7);
  color: #150d0e;
  font-weight: 600;
  font-size: 1rem;
  line-height: 0.7;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.05em;
}

/* home-mv
----------------------------------------- */
.p-home-mv {
  position: relative;
  height: 100vh;
}

.p-home-mv__joinWrap {
  position: absolute;
  top: 0.8rem;
  left: 0.6rem;
  width: 7.1rem;
  height: 7.1rem;
}

.p-home-mv__join {
  -webkit-transition: all 0.2s ease;
  -webkit-transform: translate(-50%, -50%);
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 7.1rem;
  height: 7.1rem;
          transform: translate(-50%, -50%);
  border: 3px solid #fabe00;
  border-radius: 50%;
  background-color: #fabe00;
  transition: all 0.2s ease;
}
.p-home-mv__join::before {
  -webkit-transform: scale(1);
  -webkit-animation: ripples 1.5s cubic-bezier(0.075, 0.82, 0.165, 1) infinite;
  display: block;
  z-index: -1;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 6.4rem;
  height: 6.4rem;
  margin: -3.2rem 0 0 -3.2rem;
  transform: scale(1);
  border-radius: 50%;
  background: #fabe00;
  content: "";
          animation: ripples 1.5s cubic-bezier(0.075, 0.82, 0.165, 1) infinite;
  opacity: 0;
}
.p-home-mv__join:hover {
  border: 3px solid #fabe00;
  background-color: #fff;
  opacity: 1;
}
.p-home-mv__join:hover::before {
  -webkit-animation: hoverRipples 1.5s cubic-bezier(0.075, 0.82, 0.165, 1) infinite;
  background: #fabe00;
          animation: hoverRipples 1.5s cubic-bezier(0.075, 0.82, 0.165, 1) infinite;
}
.p-home-mv__join:hover span {
  color: #fabe00;
}
.p-home-mv__join span {
  -webkit-transition: all 0.2s ease;
  -webkit-transform: translate(-50%, -50%);
  position: absolute;
  top: 50%;
  left: 50%;
          transform: translate(-50%, -50%);
  color: #fff;
  font-weight: 600;
  font-size: 1.1rem;
  line-height: 1.58;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.08em;
  text-align: center;
  transition: all 0.2s ease;
}
.p-home-mv__join.popShow {
  -webkit-transform: translateX(-50%) translateY(-50%) scale(0.6);
          transform: translateX(-50%) translateY(-50%) scale(0.6);
}
.p-home-mv__join.popShow.is-anim {
  -webkit-transform: translateX(-50%) translateY(-50%) scale(1);
          transform: translateX(-50%) translateY(-50%) scale(1);
}

@-webkit-keyframes ripples {
  0% {
    -webkit-transform: scale(1);
    -webkit-animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
    transform: scale(1);
    animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
    opacity: 1;
  }
  75% {
    opacity: 0;
  }
  100% {
    -webkit-transform: scale(1.5);
    transform: scale(1.5);
    opacity: 0;
  }
}

@keyframes ripples {
  0% {
    -webkit-transform: scale(1);
    -webkit-animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
    transform: scale(1);
    animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
    opacity: 1;
  }
  75% {
    opacity: 0;
  }
  100% {
    -webkit-transform: scale(1.5);
    transform: scale(1.5);
    opacity: 0;
  }
}
@-webkit-keyframes hoverRipples {
  0% {
    -webkit-transform: scale(1);
    -webkit-animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
    transform: scale(1);
    animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
    opacity: 1;
  }
  75% {
    opacity: 0;
  }
  100% {
    -webkit-transform: scale(1.5);
    transform: scale(1.5);
    opacity: 0;
  }
}
@keyframes hoverRipples {
  0% {
    -webkit-transform: scale(1);
    -webkit-animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
    transform: scale(1);
    animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
    opacity: 1;
  }
  75% {
    opacity: 0;
  }
  100% {
    -webkit-transform: scale(1.5);
    transform: scale(1.5);
    opacity: 0;
  }
}
.p-home-mv__scroll {
  display: none;
}
.p-home-mv__scroll span {
  -webkit-transform: translate(-50%, 0%);
  position: absolute;
  top: 0;
  left: 50%;
  width: 2rem;
  height: 3.4rem;
          transform: translate(-50%, 0%);
  border: 1px solid #128f43;
  border-radius: 0.84rem;
}
.p-home-mv__scroll span::before {
  -webkit-transform: translate(-50%, 0%);
  position: absolute;
  top: 0.5rem;
  left: 50%;
  width: 0.4rem;
  height: 0.4rem;
          transform: translate(-50%, 0%);
  border-radius: 100%;
  background-color: #128f43;
  content: "";
}
.p-home-mv__scroll span:after {
  -webkit-transform: translate(-50%, 0%) rotate(-45deg);
  -webkit-animation: arrowDown 1.5s infinite;
  position: absolute;
  bottom: -1.2rem;
  left: 50%;
  width: 1.1rem;
  height: 1.1rem;
          transform: translate(-50%, 0%) rotate(-45deg);
  border-bottom: 1px solid #128f43;
  border-left: 1px solid #128f43;
  content: "";
          animation: arrowDown 1.5s infinite;
}

@-webkit-keyframes arrowDown {
  0% {
    -webkit-transform: translate(-50%, 0%) rotate(-45deg);
            transform: translate(-50%, 0%) rotate(-45deg);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(-50%, 40%) rotate(-45deg);
            transform: translate(-50%, 40%) rotate(-45deg);
    opacity: 0;
  }
}

@keyframes arrowDown {
  0% {
    -webkit-transform: translate(-50%, 0%) rotate(-45deg);
            transform: translate(-50%, 0%) rotate(-45deg);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(-50%, 40%) rotate(-45deg);
            transform: translate(-50%, 40%) rotate(-45deg);
    opacity: 0;
  }
}

.p-home-mv__textWrap {
  -webkit-transform: translate(-50%, 20%);
  position: absolute;
  top: 9rem;
  left: 50%;
          transform: translate(-50%, 20%);
}
.p-home-mv__textWrap.cardShow.is-anim {
  -webkit-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
  opacity: 1;
}

.p-home-mv__text {
  margin: 0 0 1.8rem 0;
  color: #fff;
  font-size: 1.8rem;
  line-height: 1.7778;
  letter-spacing: 0.2em;
  text-align: center;
}

.p-home-mv__logo {
  width: 24.6rem;
}

.p-home-mv__bg {
  height: 100%;
}
.p-home-mv__bg figure {
  height: 100%;
}
.p-home-mv__bg figure img {
  -o-object-fit: cover;
  width: 100%;
  height: 100%;
     object-fit: cover;
}

/* project-list
----------------------------------------- */
.p-home-plist {
  padding: 3rem 0 3.4rem;
}

.p-home-plist__list {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: start;
  -webkit-box-pack: start;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
  flex-wrap: wrap;
          align-items: flex-start;
          justify-content: flex-start;
  width: 100vw;
  margin: 2.4rem calc(50% - 50vw) 2rem;
}

.p-home-plist__item {
  width: 47.5%;
  padding: 0.4rem 0.7rem 1.2rem;
  background-image: url(../images/common/plist_bg.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.p-home-plist__item:not(:nth-child(2n)) {
  margin: 0 5% 1.1rem 0;
}
.p-home-plist__item figure {
  position: relative;
  margin: 0 0 1.6rem 0;
  overflow: hidden;
}
.p-home-plist__item figure::before {
  display: block;
  padding-top: 82.6%;
  content: "";
}
.p-home-plist__item figure img {
  -o-object-fit: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
     object-fit: cover;
  font-family: "object-fit: cover;";
}

.p-home-plist__no {
  display: block;
  padding: 0 0 0 0.7rem;
  font-weight: 600;
  font-size: 2.7rem;
  line-height: 1.46;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.08em;
}

.p-home-plist__textWrap {
  padding: 0 0.7rem 0;
}

.p-home-plist__title {
  -webkit-box-align: center;
  display: -webkit-box;
  display: flex;
          align-items: center;
  height: 4.54rem;
  margin: 0 0 1rem 0;
  padding: 0 0 1.2rem 0;
  border-bottom: 1px solid #128f43;
  font-size: 1.2rem;
  line-height: 1.35;
  letter-spacing: 0.15em;
  white-space: nowrap;
}
.p-home-plist__title br.sp {
  display: block;
}

.p-home-plist__text {
  height: 8.6rem;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.712;
  letter-spacing: 0em;
  text-align: justify;
}

.p-home-plist__more {
  -webkit-transition-delay: 0.6s;
  display: block;
  position: relative;
  width: 12.3rem;
  height: 11.1rem;
  margin: 0 auto;
  background-image: url(../images/home/plist_more_bg.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
          transition-delay: 0.6s;
}
.p-home-plist__more span {
  -webkit-transform: translate(-50%, -50%);
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
          transform: translate(-50%, -50%);
  font-weight: 600;
  font-size: 1.5rem;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.08em;
  text-align: center;
}

/* project
----------------------------------------- */
.p-home-project {
  padding: 6rem 0 3rem;
}
.p-home-project .l-container {
  padding: 0 1.9rem;
}
.p-home-project .l-container .l-section__title {
  font-size: 3.2rem;
}

.p-home-project__titleDesc {
  margin: 1.6rem 0 0;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.916;
  letter-spacing: 0.2em;
}
.p-home-project__titleDesc br {
  display: none;
}

.p-home-project__list {
  margin: 4rem 0 0;
}

.p-home-project__item {
  position: relative;
  width: 100vw;
  padding: 2.4rem 1.75rem 0.5rem;
}
.p-home-project__item:nth-child(1) .p-home-project__icon {
  background-image: url(../images/home/project_icon_01.png);
}
.p-home-project__item:nth-child(2) .p-home-project__icon {
  background-image: url(../images/home/project_icon_02.png);
}
.p-home-project__item:nth-child(3) .p-home-project__icon {
  background-image: url(../images/home/project_icon_03.png);
}
.p-home-project__item:nth-child(4) .p-home-project__icon {
  margin: 0 0 0 2rem;
  background-image: url(../images/home/project_icon_04.png);
}
.p-home-project__item:nth-child(4) .p-home-project__top .p-home-project__name {
  line-height: 1.6;
}
.p-home-project__item:nth-child(5) .p-home-project__icon {
  background-image: url(../images/home/project_icon_05.png);
}
.p-home-project__item:nth-child(odd) {
  background-image: url(../images/home/project_bg_odd.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.p-home-project__item:nth-child(even) {
  background-image: url(../images/home/project_bg_even.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.p-home-project__item:nth-child(even) .p-home-project__head {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-box-align: center;
  -webkit-box-pack: end;
  display: -webkit-box;
  display: flex;
          flex-direction: row-reverse;
          align-items: center;
          justify-content: flex-end;
}
.p-home-project__item:not(:last-child) {
  margin: 0 calc(50% - 50vw) 2.7rem;
}
.p-home-project__item:last-child {
  margin: 0 calc(50% - 50vw) 0;
}
.p-home-project__item .p-home-project__illustration {
  display: none;
}

.p-home-project__head {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: start;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: flex-start;
}

.p-home-project__img {
  position: relative;
  overflow: hidden;
}
.p-home-project__img::before {
  display: block;
  padding-top: 76.32%;
  content: "";
}
.p-home-project__img img {
  -o-object-fit: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
     object-fit: cover;
  font-family: "object-fit: cover;";
}

.p-home-project__wrap {
  width: calc(100% - 17.65rem);
}

.p-home-project__no {
  display: inline-block;
  margin: 0 0 1.4rem 0;
  padding: 0 1rem;
  border-right: 1px solid #128f43;
  border-left: 1px solid #128f43;
  font-weight: 600;
  font-size: 1.48rem;
  line-height: 1;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.08em;
  white-space: nowrap;
}

.p-home-project__name {
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.7516;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.p-home-project__name br.sp {
  display: block;
}

.p-home-project__title {
  margin: 2rem 0 0;
  padding: 0 0 1.4rem 0;
  border-bottom: 1px solid #128f43;
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 2;
  letter-spacing: 0.16em;
  white-space: nowrap;
}
.p-home-project__title.sp {
  display: block;
}
.p-home-project__title.pc {
  display: none;
}
.p-home-project__title br.sp {
  display: block;
}

.p-home-project__text {
  display: none;
  padding: 0 0 2.4rem 0;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.89;
  letter-spacing: 0.125em;
  text-align: justify;
}

.p-home-project__icon {
  display: block;
  width: 15.4rem;
  height: 11.56rem;
  margin: 0 2.25rem 0 0;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.p-home-project__accordionBtn {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: start;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: flex-start;
  padding: 2rem 0;
  cursor: pointer;
}
.p-home-project__accordionBtn .icon {
  display: inline-block;
  position: relative;
  width: 1.9rem;
  height: 1.9rem;
  margin: 0 1.3rem 0 0;
}
.p-home-project__accordionBtn .icon::before {
  -webkit-transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transform: translate(-50%, -50%);
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.9rem;
  height: 0.1rem;
          transform: translate(-50%, -50%);
  background-color: #128f43;
  content: "";
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}
.p-home-project__accordionBtn .icon::after {
  -webkit-transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transform: translate(-50%, -50%);
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.1rem;
  height: 1.9rem;
          transform: translate(-50%, -50%);
  background-color: #128f43;
  content: "";
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}
.p-home-project__accordionBtn.close .close {
  display: none;
}
.p-home-project__accordionBtn.close .read {
  display: inline-block;
}
.p-home-project__accordionBtn.open .close {
  display: inline-block;
}
.p-home-project__accordionBtn.open .read {
  display: none;
}
.p-home-project__accordionBtn.open .icon::before {
  -webkit-transform: translate(-50%, -50%) rotateZ(45deg);
          transform: translate(-50%, -50%) rotateZ(45deg);
}
.p-home-project__accordionBtn.open .icon::after {
  -webkit-transform: translate(-50%, -50%) rotateZ(45deg);
          transform: translate(-50%, -50%) rotateZ(45deg);
}
.p-home-project__accordionBtn .read {
  -webkit-transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
  margin: 0.2rem 0 0;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.65;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.14em;
  transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}
.p-home-project__accordionBtn .close {
  -webkit-transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
  margin: 0.2rem 0 0;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.65;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.14em;
  transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}

/* vision
----------------------------------------- */
.p-home-vision {
  padding: 3.7rem 0 4.2rem;
  background: #128f43;
  background-image: url(../images/common/green_bg_pattern_sp.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.p-home-vision .l-container {
  padding: 0 2rem;
}

.p-home-vision__title .text {
  display: block;
  color: #fff;
  font-weight: 600;
  font-size: 2rem;
  line-height: 1.7464;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.075em;
}
.p-home-vision__title.sp {
  display: block;
}
.p-home-vision__title.pc {
  display: none;
}

.p-home-vision__titleWrap {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: center;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: center;
          justify-content: center;
}

.p-home-vision__text {
  margin: 2.8rem 0 2rem;
  color: #fff;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.96;
  letter-spacing: 0.115em;
  text-align: left;
}
.p-home-vision__text span {
  display: block;
  margin: 0 0 1.8rem 0;
  font-size: 3.2rem;
  line-height: 1.516;
  letter-spacing: 0.2em;
  text-align: center;
}
.p-home-vision__text span br {
  display: block;
}
.p-home-vision__text br {
  display: none;
}

.p-home-vision__link {
  -webkit-transition: all 0.2s ease;
  display: block;
  position: relative;
  width: 11.1rem;
  margin: 0 auto;
  padding: 0.1rem 1.4rem 0.1rem 1.4rem;
  border-radius: 1.74rem;
  background-color: #fff;
  font-weight: 600;
  font-size: 1.9rem;
  line-height: 1.74;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.075em;
  transition: all 0.2s ease;
}
.p-home-vision__link .arrow {
  -webkit-transition: all 0.2s ease;
  -webkit-transform: translate(0%, -50%);
  position: absolute;
  top: calc(50% - 0.1rem);
  right: 1.4rem;
  width: 1rem;
  height: 1.3rem;
          transform: translate(0%, -50%);
  background-image: url(../images/common/green_arrow_more.svg);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
  transition: all 0.2s ease;
}
.p-home-vision__link:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  opacity: 1;
}
.p-home-vision__link:hover .arrow {
  -webkit-transform: translate(0.2rem, -50%);
          transform: translate(0.2rem, -50%);
}
.p-home-vision__img img {
  width: 100%;
}
.p-home-vision__img.sp {
  display: block;
  width: 20.65rem;
  margin: 4rem auto 0;
}
.p-home-vision__img.pc {
  display: none;
}

/* what
----------------------------------------- */
.p-home-what {
  padding: 4.5rem 0 7.8rem 0;
}
.p-home-what .l-container {
  padding: 0 1.5rem;
}

.p-home-what__title {
  font-size: 3.7rem;
  line-height: 1.45;
  letter-spacing: 0.095em;
  text-align: center;
  word-spacing: 50%;
}
.p-home-what__title br.sp {
  display: block;
}
.p-home-what__title.sp {
  display: block;
}
.p-home-what__title.pc {
  display: none;
}

.p-home-what__titleText {
  position: relative;
  width: 94%;
  margin: 2.8rem auto 0;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.89;
  letter-spacing: 0.1em;
  text-align: justify;
}
.p-home-what__titleText br.pc {
  display: none;
}
.p-home-what__titleText::after {
  display: block;
  width: 22.3rem;
  height: 8.8rem;
  margin: 4rem auto 0;
  background-image: url("../images/home/logo_good_design.png");
  background-position: 0 0;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
}
.p-home-what__titleWrap .text {
  font-family: "Jost", sans-serif;
}
.p-home-what__titleWrap .text.pc {
  display: none;
}
.p-home-what__titleWrap span {
  font-family: "Jost", sans-serif;
}

.p-home-what__list {
  margin: 3.2rem 0 0;
}
.p-home-what__item:nth-child(1) .p-home-what__itemTitle img {
  width: 22.4rem;
}
.p-home-what__item:nth-child(2) .p-home-what__itemTitle img {
  width: 20.9rem;
}
.p-home-what__item:nth-child(3) .p-home-what__itemTitle img {
  width: 13.4rem;
  margin: 0 auto 1.2rem;
}
.p-home-what__item:nth-child(3) figure {
  margin: 1.1rem 0 1.3rem 0;
}
.p-home-what__item:not(:last-child) {
  margin: 0 0 5.4rem 0;
}
.p-home-what__item figure {
  position: relative;
  width: 100%;
  margin: 0 0 1.3rem 0;
  overflow: hidden;
  border-radius: 45px;
}
.p-home-what__item figure::before {
  display: block;
  padding-top: 85.35%;
  content: "";
}
.p-home-what__item figure img {
  -o-object-fit: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
     object-fit: cover;
  font-family: "object-fit: cover;";
}

.p-home-what__itemTitle {
  display: block;
  position: relative;
  margin: 0 0 -2.6rem 0;
  padding: 2.7rem 0;
}
.p-home-what__itemTitle::before {
  -webkit-transform: translate(-50%, -50%);
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 0.15rem;
          transform: translate(-50%, -50%);
  background-color: #128f43;
  content: "";
}
.p-home-what__itemTitle img {
  -o-object-fit: contain;
  display: block;
  position: relative;
  margin: 0 auto 2.3rem;
  padding: 0 1.2rem;
     object-fit: contain;
  background-color: #fff;
}

.p-home-what__text {
  font-weight: 600;
  font-size: 1.65rem;
  line-height: 1.87;
  letter-spacing: 0.165em;
  text-align: center;
}

/* why
----------------------------------------- */
.p-home-why {
  padding: 7.2rem 0 4.2rem;
  border-top: 2px solid #128f43;
}
.p-home-why .l-container {
  padding: 0 2.5rem;
}

.p-home-why__title {
  margin: 0 0 2.6rem 0;
  font-size: 3.7rem;
  line-height: 1.45;
  letter-spacing: 0.095em;
  text-align: center;
}

.p-home-why__titleWrap .text {
  font-family: "Jost", sans-serif;
}

.p-home-why__desc {
  margin: 0 0 2.4rem 0;
}

.p-home-why__titleText {
  margin: 0 0 2rem 0;
  font-weight: 600;
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.175em;
  text-align: center;
  white-space: nowrap;
}

.p-home-why__text {
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.89;
  letter-spacing: 0.15em;
  text-align: justify;
}

.p-home-why__img {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-box-align: start;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: flex;
          flex-direction: row;
          align-items: flex-start;
          justify-content: center;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
}
.p-home-why__img figure {
  width: 49.2%;
}
.p-home-why__img figure:first-child {
  margin: 0 1.6% 0 0;
}

/* home-movie
----------------------------------------- */
.p-home-movie {
  margin: 1rem 0 2rem;
}
.p-home-movie .l-container {
  max-width: 1134px;
}

.p-home-movie__youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.p-home-movie__youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.p-home-movie__youtube img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

/* en
----------------------------------------- */
.en .p-home-mv__text {
  font-weight: 700;
  font-size: 1.8rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.035em;
  white-space: nowrap;
}
.en .p-home-climate__titleText .text {
  font-weight: 700;
  font-size: 1rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0em;
}
.en .p-home-climate__text {
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 1.789;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-what__titleText {
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 1.647;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-what__text {
  font-weight: 500;
  font-size: 1.6rem;
  line-height: 1.647;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-why__titleText {
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.46;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-why__text {
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 1.647;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-vision__text {
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 1.647;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
  text-align: justify;
}
.en .p-home-vision__text span {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.4;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.035em;
}
.en .p-home-project__titleDesc {
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1.632;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
  text-align: justify;
}
.en .p-home-project__name {
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1.632;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
  text-align: justify;
}
.en .p-home-project__title {
  font-weight: 700;
  font-size: 2.1rem;
  line-height: 1.7;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
  white-space: normal;
}
.en .p-home-project__text {
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 1.75;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.02em;
}
.en .p-home-plist__title {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1.35;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
  white-space: normal;
}
.en .p-home-plist__text {
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 1.47;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.02em;
  text-align: left;
}
.en .p-home-plist__text {
  height: 20.6rem;
}
.en .p-home-join__text {
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1.684;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-join__box + .p-home-join__box {
  padding: 4rem 0 2.6rem;
}
.en .p-home-join__box + .p-home-join__box .p-home-join__boxText {
  margin: 1.5rem 0 0;
}
.en .p-home-join__title {
  margin: 0 0 2rem 0;
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.4;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-join__title span {
  font-weight: 700;
  font-size: 1.2rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-join__link {
  padding: 1.2rem 0;
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-event__text {
  font-weight: 700;
  font-size: 1.2rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.025em;
}
.en .p-home-event__nextTitle .date {
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: 0.03em;
  text-align: center;
}
.en .p-home-event__nextTitle br.sp {
  display: block;
}
.en .p-home-event__ctaText {
  font-weight: 700;
  font-size: 1.8rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.065em;
}
.en .p-home-event__ctaLink {
  width: 30rem;
  font-weight: 700;
  font-size: 1.6rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.065em;
}
.en .p-home-member__title {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.065em;
}
.en .p-home-member__title br.sp {
  display: block;
}
.en .p-home-member__name01 {
  font-weight: 700;
  font-size: 1.4rem;
  font-family: "Jost", sans-serif;
  letter-spacing: 0.05em;
}
.en .l-footer__aboutCatch {
  font-weight: 500;
  font-size: 2.1rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.055em;
}
.en .l-footer__aboutText {
  font-weight: 500;
  font-size: 1.2rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.02em;
}
.en .l-footer__contactText {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1.71;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.015em;
}
.en .l-footer-bottom__text {
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1.4;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0;
}
.en .l-footer__aboutTitle {
  line-height: 1.4;
}

.test {
  -o-object-fit: cover;
  display: block;
  position: relative;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
     object-fit: cover;
  background-attachment: fixed;
  font-family: "object-fit: cover;";
}

@media screen and (min-width: 768px) {
  .l-main {
    background-position: -10.2rem 6.5rem;
    background-size: 18.2rem 18.2rem;
  }
  .l-container {
    padding-right: 8rem;
    padding-left: 8rem;
  }
  .l-footer {
    padding: 9.5rem 0 7.2rem;
    background-position: -10.2rem -6.4rem;
    background-size: 18.2rem 18.2rem;
  }
  .l-footer__about {
    padding: 6.3rem 12.2rem 6.5rem;
    border-radius: 5.1rem;
    background-image: url(../images/common/footer_about_bg_pc.png);
  }
  .l-footer__aboutTitle {
    margin: 0 0 5.8rem 0;
    font-size: 3.8rem;
    line-height: 1.55;
  }
  .l-footer__aboutCatch {
    margin: 0 0 6.4rem 0;
    font-size: 2.7rem;
    line-height: 1;
  }
  .l-footer__aboutText {
    font-size: 1.4rem;
    line-height: 2;
    text-align: center;
  }
  .l-footer__aboutText br {
    display: block;
  }
  .l-footer__contact {
    margin: 14.5rem 0 20rem;
  }
  .l-footer__contactText {
    margin: 0 0 5rem 0;
    font-size: 2.3rem;
    line-height: 1;
  }
  .l-footer__contactText br.sp {
    display: none;
  }
  .l-footer__contactLink {
    width: 31.5rem;
    padding: 0.65rem 3.8rem 0.65rem 5rem;
    border-radius: 0.4rem;
    font-size: 3.1rem;
    line-height: 1.588;
  }
  .l-footer__contactLink .arrow {
    right: 3.8rem;
    font-size: 3.4rem;
  }
  .l-footer-bottom {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: end;
    -webkit-box-pack: justify;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: flex-end;
            justify-content: space-between;
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    padding: 0 9rem;
  }
  .l-footer-bottom__block {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-box-align: end;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: row-reverse;
            align-items: flex-end;
            justify-content: flex-start;
  }
  .l-footer-bottom__company {
    -webkit-transform: translate(-50%, 0%);
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: start;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
    position: absolute;
    bottom: 0;
    left: 50%;
            flex-direction: row;
            align-items: flex-start;
            justify-content: center;
            transform: translate(-50%, 0%);
  }
  .l-footer-bottom__company.textUp.is-anim {
    -webkit-transform: translate(-50%, 0%);
            transform: translate(-50%, 0%);
  }
  .l-footer-bottom__text {
    margin: 0 9.7rem 0 0;
    font-size: 1.6rem;
    line-height: 0.7;
  }
  .l-footer-bottom__companyList {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-box-align: start;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: row-reverse;
            align-items: flex-start;
            justify-content: flex-start;
  }
  .l-footer-bottom__companyImg:not(:last-child) {
    margin: 0;
  }
  .l-footer-bottom__companyImg:nth-child(1) {
    width: 25.835rem;
  }
  .l-footer-bottom__companyImg:nth-child(2) {
    width: 11.2rem;
    margin: 0 3.8rem 0 0;
  }
  .l-footer__logo {
    margin: 0 9.5rem 0 0;
  }
  .l-footer__logoLink img {
    width: 15.3rem;
  }
  .l-footer__copy {
    -webkit-transform: scale(1);
            transform: scale(1);
    font-size: 1.2rem;
  }
  .l-header__la {
    top: 10rem;
    right: 4.9rem;
    width: 10.4rem;
    padding: 1.5rem;
  }
  .l-header__laItem:last-child::before {
    height: 1.2rem;
    background-color: #128f43;
  }
  .l-header__laLink {
    color: #128f43;
    font-size: 1.3rem;
  }
  .l-hamburger__toggle {
    top: 2rem;
    right: 4.9rem;
    width: 10.4rem;
    padding: 1.5rem;
  }
  .l-hamburger__toggle.is-active {
    top: 1.2rem;
    width: 8.2rem;
    height: 8.2rem;
  }
  .l-hamburger__toggle.is-active .l-hamburger__toggleWrap {
    height: 5.2rem;
  }
  .l-hamburger__toggle.is-active .l-hamburger__toggleWrap span:nth-of-type(1) {
    -webkit-transform: translateX(-1.1rem) translateY(2.6rem) rotate(-45deg);
            transform: translateX(-1.1rem) translateY(2.6rem) rotate(-45deg);
  }
  .l-hamburger__toggle.is-active .l-hamburger__toggleWrap span:nth-of-type(2) {
    -webkit-transform: translateX(-1.1rem) translateY(50%);
            transform: translateX(-1.1rem) translateY(50%);
  }
  .l-hamburger__toggle.is-active .l-hamburger__toggleWrap span:nth-of-type(3) {
    -webkit-transform: translateX(-1.1rem) translateY(-2.5rem) rotate(45deg);
            transform: translateX(-1.1rem) translateY(-2.5rem) rotate(45deg);
  }
  .l-hamburger__toggleWrap {
    height: 2.3rem;
  }
  .l-hamburger__toggleWrap span {
    width: 7.4rem;
    background-color: #128f43;
  }
  .l-hamburger__toggleWrap span:nth-of-type(2) {
    top: 1.1rem;
  }
  .l-hamburger__toggleText {
    -webkit-transform: scale(1);
    margin: 0 0 0.7rem 0;
            transform: scale(1);
    color: #128f43;
    font-size: 1.6rem;
  }
  .l-header {
    height: 10rem;
    background-position: -10.2rem 6.5rem;
    background-size: 18.2rem 18.2rem;
  }
  .l-header__inner {
    height: 10rem;
  }
  .l-header__logo {
    width: 34.4rem;
  }
  .l-header__logo.is-active {
    width: 15rem;
  }
  .l-menu {
    height: auto;
    padding: 4.7rem 7.5rem 2.8rem 4.5rem;
  }
  .l-menu__logo {
    width: 34.4rem;
  }
  .l-menu__list {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: end;
    display: -webkit-box;
    display: flex;
    position: absolute;
    top: 4.85rem;
    right: 19.4rem;
            flex-direction: row;
            align-items: center;
            justify-content: flex-end;
    margin: 0;
  }
  .l-section__title {
    font-size: 4.7rem;
  }
  .p-home-climate {
    padding: 17.8rem 0 1.8rem;
  }
  .p-home-climate .l-container {
    position: relative;
  }
  .p-home-climate__textWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: flex-start;
    margin: 0 0 5.2rem 0;
  }
  .p-home-climate__title {
    margin: 0 5.3% 0 0;
    font-size: 3.75rem;
    line-height: 1;
  }
  .p-home-climate__title .l-section__titleWrap:not(:last-child) {
    margin: 0 0 3.6rem 0;
  }
  .p-home-climate__title .l-section__titleWrap .text.sp {
    display: none;
  }
  .p-home-climate__title .l-section__titleWrap .text.pc {
    display: block;
  }
  .p-home-climate__text {
    margin: 3.2rem 0 0;
    font-size: 1.7rem;
    line-height: 2;
    letter-spacing: 0.135em;
  }
  .p-home-climate__text br.pc {
    display: block;
  }
  .p-home-climate__img {
    position: relative;
    overflow: hidden;
    border-radius: 3.3rem;
  }
  .p-home-climate__img::before {
    display: block;
    padding-top: 53.66%;
    content: "";
  }
  .p-home-climate__textWrap {
    display: block;
    width: 93.4%;
    margin: -3.4rem auto 0;
    padding: 0;
  }
  .p-home-climate__titleText {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-box-align: start;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: column;
            align-items: flex-start;
            justify-content: flex-start;
  }
  .p-home-climate__titleText .text {
    padding: 0 2.6rem;
    font-size: 3.3rem;
    line-height: 2.446;
    letter-spacing: 0.175em;
  }
  .p-home-climate__titleText .textBg:not(:last-child) {
    margin: 0 0 1.4rem 0;
  }
  .p-home-event {
    padding: 16.25rem 0 11.5rem;
  }
  .p-home-event .l-container {
    max-width: 1286px;
  }
  .p-home-event .l-container .l-section__title .l-section__titleWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: center;
  }
  .p-home-event__list {
    width: 100%;
    margin: 9rem 0 18.5rem;
  }
  .p-home-event__item {
    -webkit-transition: all 0.3s ease;
    position: relative;
    cursor: pointer;
    transition: all 0.3s ease;
  }
  .p-home-event__item:not(:last-child) {
    margin: 0 0 6rem 0;
  }
  .p-home-event__item figure {
    width: 45%;
  }
  .p-home-event__item:hover::before {
    opacity: 0.1;
  }
  .p-home-event__item::before {
    -webkit-transition: all 0.3s ease;
    -webkit-transform: translate(-50%, -50%);
    z-index: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
            transform: translate(-50%, -50%);
    background-color: #128f43;
    content: "";
    opacity: 0;
    transition: all 0.3s ease;
  }
  .p-home-event__link {
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            justify-content: flex-start;
    pointer-events: all;
  }
  .p-home-event__desc {
    width: 55%;
    padding: 0 4.5rem 0 7.7rem;
  }
  .p-home-event__title {
    font-size: 2.8rem;
    line-height: 1.46;
    text-align: left;
  }
  .p-home-event__title span {
    display: inline-block;
  }
  .p-home-event__date {
    -webkit-transform: scale(1);
    margin: 1.4rem 0 0 0;
    padding: 0;
            transform: scale(1);
    font-size: 1.8rem;
  }
  .p-home-event__text {
    display: block;
    margin: 2.8rem 0 0;
    padding: 0;
    border-bottom: none;
    font-size: 1.4rem;
    line-height: 2;
    letter-spacing: 0.14em;
  }
  .p-home-event__next {
    padding: 7rem 0 5rem;
    background-image: url(../images/common/event_next_bg_pc.png);
  }
  .p-home-event__nextImg {
    display: block;
    width: 18.8%;
  }
  .p-home-event__nextText {
    width: 100%;
    margin: 0 2.76%;
  }
  .p-home-event__nextTitle {
    margin: 0 0 3.5rem 0;
    font-size: 3.8rem;
  }
  .p-home-event__nextTitle span.date {
    font-size: 4.2rem;
  }
  .p-home-event__nextTitle span.ja {
    margin-left: 2rem;
    font-size: 3.6rem;
  }
  .p-home-event__nextFigure {
    position: relative;
    max-width: 68.8rem;
    margin: 0 auto;
  }
  .p-home-event__no {
    margin: 2.6rem 0 0;
    font-size: 4.7rem;
  }
  .p-home-event__cta {
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
            align-items: center;
            justify-content: center;
    margin-top: 3.6rem;
  }
  .p-home-event__ctaText {
    position: relative;
    font-size: 2.3rem;
  }
  .p-home-event__ctaText::after {
    -webkit-transform: translateY(-50%);
    display: inline-block;
    position: absolute;
    top: 50%;
    right: -5rem;
    width: 2.6rem;
    height: 4.8rem;
            transform: translateY(-50%);
    background-image: url("../images/home/icon_white_arrow.png");
    background-position: 0 0;
    background-size: contain;
    background-repeat: no-repeat;
    content: "";
    vertical-align: middle;
  }
  .p-home-event__ctaLink {
    -webkit-transition: all 0.2s ease;
    width: auto;
    margin: 0;
    margin-left: 8rem;
    padding: 1.2rem 2.4rem 1.2rem 3.2rem;
    font-size: 2.3rem;
    line-height: 1;
    transition: all 0.2s ease;
  }
  .p-home-event__ctaLink::after {
    width: 3.4rem;
    height: 3.4rem;
    margin-left: 1.2rem;
  }
  .p-home-event__accordion {
    border-top: none;
  }
  .p-home-event__accordionBtn {
    display: none;
  }
  .p-home-join {
    padding: 11rem 0 12.2rem;
  }
  .p-home-join .l-section__title .l-section__titleWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: center;
  }
  .p-home-join__text {
    margin: 3.6rem 0 0;
    font-size: 1.6rem;
    line-height: 2.156;
    text-align: center;
  }
  .p-home-join__text br.pc {
    display: block;
  }
  .p-home-join__wrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: center;
    width: 100%;
    margin: 8rem 0 5rem;
  }
  .p-home-join__box {
    width: 45.6%;
    margin: auto;
    padding: 5.8rem 0 8.6rem;
    background-image: url(../images/home/join_bg_white.png);
  }
  .p-home-join__box:not(:last-child) {
    margin: 0 8.8% 0 0;
  }
  .p-home-join__box:first-of-type {
    padding: 6.2rem 0 4.65rem;
  }
  .p-home-join__box:first-of-type .p-home-join__boxText {
    margin: 4.2rem 0 0;
    font-size: 2.2rem;
  }
  .p-home-join__box:first-of-type figure {
    width: 84.3%;
  }
  .p-home-join__box:nth-of-type(2) {
    padding: 6.2rem 0 4.65rem;
  }
  .p-home-join__box:nth-of-type(2) .p-home-join__boxText {
    margin: 4.2rem 0 0;
    font-size: 2.2rem;
  }
  .p-home-join__box:nth-of-type(2) figure {
    width: 78.6%;
  }
  .p-home-join__title {
    margin: 0 0 6.4rem 0;
    font-size: 2.8rem;
  }
  .p-home-join__title span {
    font-size: 1.4rem;
  }
  .p-home-join__link {
    width: 33.65rem;
    padding: 2rem 0;
    border-radius: 2.9rem;
    font-size: 1.6rem;
    line-height: 1.188;
  }
  .p-home-join__link .arrow {
    font-size: 1.8rem;
  }
  .p-home-join__handshake {
    width: 13.5rem;
    height: 8.7rem;
  }
  .p-home-member {
    padding: 11.5rem 0 0;
  }
  .p-home-member .l-section__title {
    margin: 0 0 10rem 0;
  }
  .p-home-member .l-section__titleWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: flex-start;
  }
  .p-home-member__block {
    width: 87.6%;
  }
  .p-home-member__block:not(:last-child) {
    margin: 0 0 3rem 0;
  }
  .p-home-member__title {
    font-size: 2.4rem;
  }
  .p-home-member__list {
    margin: 3.5rem 0 0;
  }
  .p-home-member__item {
    width: 28.65%;
  }
  .p-home-member__item:not(:nth-child(2n)) {
    margin: 0 7.025% 8.6rem 0;
  }
  .p-home-member__item:not(:nth-child(3n)) {
    margin: 0 7.025% 8.6rem 0;
  }
  .p-home-member__item:nth-child(3n) {
    margin: 0 0 8.6rem 0;
  }
  .p-home-member__item figure {
    margin: 0 0 1.7rem 0;
  }
  .p-home-member__name01 {
    -webkit-transform: scale(1);
    margin: 0;
            transform: scale(1);
    font-size: 1.5rem;
  }
  .p-home-member__name02 {
    -webkit-transform: scale(1);
    margin: 0;
            transform: scale(1);
    font-size: 1.2rem;
  }
  .p-home-mv {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: start;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: flex-start;
            justify-content: center;
    height: 100vh;
  }
  .p-home-mv__joinWrap {
    position: absolute;
    top: 3.6rem;
    left: 4.8rem;
    width: 15.2rem;
    height: 15.2rem;
  }
  .p-home-mv__join {
    width: 15.2rem;
    height: 15.2rem;
  }
  .p-home-mv__join::before {
    width: 13.6rem;
    height: 13.6rem;
    margin: -6.8rem 0 0 -6.8rem;
  }
  .p-home-mv__join span {
    font-size: 2rem;
  }
  .p-home-mv__scroll {
    -webkit-transform: translate(-50%, 0%);
    display: inline-block;
    z-index: 2;
    position: absolute;
    bottom: 5.2rem;
    left: 50%;
    padding: 5.6rem 0 0;
            transform: translate(-50%, 0%);
    color: #128f43;
    font-weight: 300;
    font-size: 1.1rem;
    font-family: "Montserrat", sans-serif;
    text-decoration: none;
    pointer-events: none;
  }
  .p-home-mv__right {
    position: relative;
    width: 28.125%;
    height: 100%;
    background-color: #fff;
  }
  .p-home-mv__textWrap {
    -webkit-transform: translate(-50%, 20%);
    top: 50%;
    left: 50%;
            transform: translate(-50%, 20%);
  }
  .p-home-mv__textWrap.cardShow.is-anim {
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  .p-home-mv__text {
    margin: 0 0 6.4rem 0;
    color: #128f43;
    font-size: 2.7rem;
    line-height: 1.84;
  }
  .p-home-mv__logo {
    width: 30.45rem;
  }
  .p-home-mv__bg {
    width: 71.875%;
  }
  .p-home-plist {
    padding: 14.5rem 0 11.4rem;
  }
  .p-home-plist .l-container {
    position: relative;
    max-width: 1280px;
    padding: 0 8rem;
  }
  .p-home-plist .l-section__title .l-section__titleWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: center;
  }
  .p-home-plist__list {
    width: 100%;
    margin: 7.5rem 0 0;
  }
  .p-home-plist__item {
    width: 31.25%;
    padding: 1rem 1.4rem 3rem;
    background-image: url(../images/common/plist_bg_pc.png);
  }
  .p-home-plist__item:not(:nth-child(2n)) {
    margin: 0 3.125% 2.2rem 0;
  }
  .p-home-plist__item:not(:nth-child(3n)) {
    margin: 0 3.125% 2.2rem 0;
  }
  .p-home-plist__item:nth-child(3n) {
    margin: 0 0 2.2rem 0;
  }
  .p-home-plist__item figure {
    margin: 0 0 0.9rem 0;
  }
  .p-home-plist__no {
    padding: 0 0 0 1.5rem;
    font-size: 5.25rem;
    line-height: 1.44;
  }
  .p-home-plist__textWrap {
    padding: 0 1.5rem 0;
  }
  .p-home-plist__title {
    -webkit-box-align: center;
    display: -webkit-box;
    display: flex;
            align-items: center;
    height: 10.45rem;
    margin: 0 0 1.8rem 0;
    padding: 0 0 0rem 0;
    font-size: 1.8rem;
  }
  .p-home-plist__title br.sp {
    display: none;
  }
  .p-home-plist__text {
    height: 9.6rem;
    font-size: 1.4rem;
    letter-spacing: 0.14em;
  }
  .p-home-plist__more {
    position: absolute;
    right: 13rem;
    bottom: 7.8rem;
    width: 24.2rem;
    height: 21.8rem;
  }
  .p-home-plist__more span {
    font-size: 3rem;
  }
  .p-home-project {
    padding: 17.4rem 0 14.5rem;
  }
  .p-home-project .l-container {
    max-width: 1260px;
    padding: 0 8rem;
  }
  .p-home-project .l-container .l-section__title {
    font-size: 4.7rem;
  }
  .p-home-project__titleDesc {
    margin: 3.6rem 0 0;
    font-size: 1.6rem;
    line-height: 2.03;
  }
  .p-home-project__titleDesc br {
    display: block;
  }
  .p-home-project__list {
    margin: 9rem 0 0;
  }
  .p-home-project__item {
    width: 100%;
    margin: auto;
    padding: 4.6rem 4.5rem 4.6rem 5.2rem;
  }
  .p-home-project__item:nth-child(1) .p-home-project__illustration {
    display: block;
    position: absolute;
    top: -4rem;
    right: -13rem;
    width: 32.06rem;
    height: 31.28rem;
    background-image: url(../images/home/project_illustration01.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-home-project__item:nth-child(4) .p-home-project__icon {
    margin: 0 0 0 -6rem !important;
  }
  .p-home-project__item:nth-child(4) .p-home-project__top {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: flex-start;
  }
  .p-home-project__item:nth-child(5) .p-home-project__illustration.illust01 {
    -webkit-transition-delay: 0.75s;
    display: block;
    position: absolute;
    top: 4.5rem;
    right: -11rem;
    width: 25.67rem;
    height: 16.3rem;
    background-image: url(../images/home/project_illustration07.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.75s;
  }
  .p-home-project__item:nth-child(even) .p-home-project__head .p-home-project__icon {
    margin: 0 0 0 -2rem;
  }
  .p-home-project__item:not(:last-child) {
    margin: 0 0 4.5rem 0;
  }
  .p-home-project__item:last-child {
    margin: auto;
  }
  .p-home-project__item .p-home-project__illustration {
    -webkit-transition-delay: 0.5s;
            transition-delay: 0.5s;
  }
  .p-home-project__head {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: justify;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: space-between;
  }
  .p-home-project__img {
    z-index: 1;
    position: relative;
    width: 52.8%;
    margin: -1.8rem -9% 0 0;
    overflow: hidden;
  }
  .p-home-project__img::before {
    display: block;
    padding-top: 76.39%;
    content: "";
  }
  .p-home-project__wrap {
    width: calc(100% - 30.2rem);
  }
  .p-home-project__top {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: end;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: flex-end;
            justify-content: flex-start;
  }
  .p-home-project__no {
    margin: 0 3.9rem 0 0;
    padding: 0 1.5rem;
    border-right: 2px solid #128f43;
    border-left: 2px solid #128f43;
    font-size: 2.65rem;
    line-height: 1;
    white-space: nowrap;
  }
  .p-home-project__name {
    font-size: 1.7rem;
    line-height: 0.9;
  }
  .p-home-project__name br.sp {
    display: none;
  }
  .p-home-project__title {
    margin: 2.5rem 0 0;
    padding: 0;
    border-bottom: none;
    font-size: 3rem;
  }
  .p-home-project__title.sp {
    display: none;
  }
  .p-home-project__title.pc {
    display: block;
  }
  .p-home-project__title br.sp {
    display: none;
  }
  .p-home-project__text {
    display: block;
    margin: 3.15rem 0 0;
    padding: 0;
    font-size: 1.4rem;
  }
  .p-home-project__icon {
    z-index: 1;
    width: 26.7rem;
    height: 20.2rem;
    margin: auto;
  }
  .p-home-project__accordionBtn {
    display: none;
  }
  .p-home-vision {
    padding: 9.6rem 0 10rem;
    background-image: url(../images/common/green_bg_pattern_pc.png);
  }
  .p-home-vision .l-container {
    position: relative;
    padding: 0 8rem;
  }
  .p-home-vision__title .text {
    font-size: 7.25rem;
    line-height: 1.34;
    letter-spacing: 0.08em;
  }
  .p-home-vision__title.sp {
    display: none;
  }
  .p-home-vision__title.pc {
    display: block;
  }
  .p-home-vision__titleWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: flex-start;
  }
  .p-home-vision__text {
    width: 81.6%;
    margin: 6.6rem 0 0;
    font-size: 1.4rem;
    line-height: 2.25;
    letter-spacing: 0.2em;
  }
  .p-home-vision__text span {
    margin: 0 0 3.8rem 0;
    font-size: 3.9rem;
    line-height: 1;
    text-align: left;
  }
  .p-home-vision__text span br {
    display: none;
  }
  .p-home-vision__text br {
    display: block;
  }
  .p-home-vision__link {
    position: absolute;
    right: 15rem;
    bottom: 1rem;
    width: 10.45rem;
    margin: 0 auto 0 0;
    padding: 0.1rem 1.35rem 0 1.6rem;
    border-radius: 1.635rem;
    font-size: 1.8rem;
  }
  .p-home-vision__link .arrow {
    right: 1.35rem;
    width: 0.97rem;
    height: 1.2rem;
  }
  .p-home-vision__img {
    position: absolute;
    top: -0.4rem;
    right: 10.5rem;
    width: 24.3%;
  }
  .p-home-vision__img.sp {
    display: none;
  }
  .p-home-vision__img.pc {
    display: block;
  }
  .p-home-what {
    padding: 13rem 0 11rem 0;
  }
  .p-home-what .l-container {
    padding: 0 8rem;
  }
  .p-home-what__title {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: center;
    font-size: 4.7rem;
    letter-spacing: 0.125em;
  }
  .p-home-what__title br.sp {
    display: none;
  }
  .p-home-what__title.sp {
    display: none;
  }
  .p-home-what__title.pc {
    display: block;
  }
  .p-home-what__titleText {
    width: 100%;
    font-size: 1.6rem;
    line-height: 2;
    letter-spacing: 0.2em;
  }
  .p-home-what__titleText br.pc {
    display: block;
  }
  .p-home-what__titleText::after {
    display: inline-block;
    position: absolute;
    top: -1.5rem;
    right: -1.5rem;
    margin: 0;
  }
  .p-home-what__titleWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
    position: relative;
            flex-direction: row;
            align-items: center;
            justify-content: flex-start;
    white-space: pre;
  }
  .p-home-what__titleWrap .text.pc {
    display: block;
  }
  .p-home-what__titleWrap::before {
    -webkit-transform: translate(0%, -50%);
    position: absolute;
    top: 50%;
    right: 0;
    width: 18%;
    height: 1px;
            transform: translate(0%, -50%);
    background-color: #128f43;
    content: "";
  }
  .p-home-what__list {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: start;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: flex-start;
            justify-content: flex-start;
    margin: 4.2rem 0 0;
  }
  .p-home-what__item {
    width: 28.7%;
  }
  .p-home-what__item:nth-child(1) .p-home-what__itemTitle img {
    width: 18.7rem;
  }
  .p-home-what__item:nth-child(2) .p-home-what__itemTitle img {
    width: 18.4rem;
  }
  .p-home-what__item:nth-child(3) .p-home-what__itemTitle {
    padding: 3.7rem 0;
  }
  .p-home-what__item:nth-child(3) .p-home-what__itemTitle img {
    width: 14.3rem;
    margin: 0 auto 1.1rem;
    padding: 0 2.2rem 0;
  }
  .p-home-what__item:nth-child(3) figure {
    margin: 0 0 2.2rem 0;
  }
  .p-home-what__item:not(:last-child) {
    margin: 0 6.95% 0 0;
  }
  .p-home-what__item figure {
    margin: 0 0 2.2rem 0;
  }
  .p-home-what__itemTitle img {
    -o-object-fit: contain;
    display: block;
    position: relative;
    margin: 0 auto 2.4rem;
    padding: 0 1.2rem;
       object-fit: contain;
    background-color: #fff;
  }
  .p-home-why {
    padding: 7.2rem 0 9rem;
    border-top: none;
  }
  .p-home-why .l-container {
    padding-right: 8rem;
    padding-left: 8rem;
  }
  .p-home-why .l-container .p-home-why__title .p-home-why__titleWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -webkit-box-pack: start;
    display: -webkit-box;
    display: flex;
    position: relative;
            flex-direction: row;
            align-items: center;
            justify-content: flex-start;
  }
  .p-home-why .l-container .p-home-why__title .p-home-why__titleWrap::before {
    -webkit-transform: translate(0%, -50%);
    position: absolute;
    top: 50%;
    right: 0;
    width: 70%;
    height: 1px;
            transform: translate(0%, -50%);
    background-color: #128f43;
    content: "";
  }
  .p-home-why__title {
    margin: 0 0 3.9rem 0;
  }
  .p-home-why__wrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: start;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: flex;
            flex-direction: row;
            align-items: flex-start;
            justify-content: center;
  }
  .p-home-why__desc {
    width: 41.8%;
    margin: 0 4.75% 0 0;
  }
  .p-home-why__titleText {
    margin: 0 0 3.4rem 0;
    font-size: 2.46rem;
    letter-spacing: 0.2em;
    text-align: left;
  }
  .p-home-why__text {
    font-size: 1.4rem;
    line-height: 1.964;
  }
  .p-home-why__img {
    width: 53.45%;
    margin: 0;
  }
  .p-home-movie {
    margin: 14rem 0 12rem;
  }
  .en .p-home-mv__text {
    font-size: 2.3rem;
  }
  .en .p-home-climate__titleText .text {
    font-size: 2.8rem;
    letter-spacing: 0.025em;
  }
  .en .p-home-climate__text {
    font-size: 1.8rem;
  }
  .en .p-home-what__titleText {
    font-size: 1.7rem;
  }
  .en .p-home-what__text {
    font-size: 1.6rem;
  }
  .en .p-home-why__titleText {
    font-size: 2.5rem;
  }
  .en .p-home-why__text {
    font-size: 1.7rem;
  }
  .en .p-home-vision__text {
    font-size: 1.7rem;
  }
  .en .p-home-vision__text span {
    font-size: 3.8rem;
  }
  .en .p-home-project__titleDesc {
    font-size: 1.9rem;
  }
  .en .p-home-project__name {
    font-size: 1.9rem;
  }
  .en .p-home-project__title {
    font-size: 3rem;
    white-space: nowrap;
  }
  .en .p-home-project__text {
    font-size: 1.6rem;
  }
  .en .p-home-project__item:nth-child(5) .p-home-project__title {
    font-size: 2.9rem;
  }
  .en .p-home-plist__title {
    font-size: 2rem;
    white-space: nowrap;
  }
  .en .p-home-plist__text {
    font-size: 1.5rem;
  }
  .en .p-home-plist__text {
    height: 15.6rem;
  }
  .en .p-home-join__text {
    font-size: 1.9rem;
  }
  .en .p-home-join__box + .p-home-join__box {
    padding: 6.2rem 0 4.65rem;
  }
  .en .p-home-join__box + .p-home-join__box .p-home-join__boxText {
    margin: 4.2rem 0 0;
  }
  .en .p-home-join__title {
    margin: 0 0 6.4rem 0;
    font-size: 2.5rem;
  }
  .en .p-home-join__title span {
    font-size: 1.5rem;
  }
  .en .p-home-join__link {
    padding: 2rem 0;
    font-size: 2rem;
  }
  .en .p-home-event__text {
    font-size: 1.5rem;
  }
  .en .p-home-event__nextTitle .date {
    font-size: 3.6rem;
  }
  .en .p-home-event__nextTitle br.sp {
    display: none;
  }
  .en .p-home-event__ctaText {
    font-size: 2.4rem;
  }
  .en .p-home-event__ctaLink {
    width: auto;
    font-size: 2.4rem;
  }
  .en .p-home-member__title {
    font-size: 2.4rem;
  }
  .en .p-home-member__title br.sp {
    display: none;
  }
  .en .p-home-member__name01 {
    font-size: 1.7rem;
  }
  .en .l-footer__aboutCatch {
    font-size: 2.7rem;
  }
  .en .l-footer__aboutText {
    font-size: 1.6rem;
  }
  .en .l-footer__contactText {
    font-size: 2.4rem;
  }
  .en .l-footer-bottom__text {
    font-size: 1.7rem;
    line-height: 1;
  }
}

@media screen and (min-width: 768px) and (max-width: 1365px) {
  html {
    font-size: 0.7320644217vw;
  }
  .p-home-project__item:nth-child(2) .p-home-project__illustration {
    display: block;
    position: absolute;
    top: 10rem;
    left: -20rem;
    width: 27.3rem;
    height: 23.9rem;
    background-image: url(../images/home/project_illustration02.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-home-project__item:nth-child(3) .p-home-project__illustration.illust01 {
    -webkit-transition-delay: 0.5s;
    display: block;
    position: absolute;
    top: 8.6rem;
    right: -11rem;
    width: 13.88rem;
    height: 13.88rem;
    background-image: url(../images/home/project_illustration03.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.5s;
  }
  .p-home-project__item:nth-child(3) .p-home-project__illustration.illust02 {
    -webkit-transition-delay: 0.6s;
    display: block;
    position: absolute;
    top: -3.2rem;
    left: -12rem;
    width: 24.48rem;
    height: 24.345rem;
    background-image: url(../images/home/project_illustration04.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.6s;
  }
  .p-home-project__item:nth-child(3) .p-home-project__illustration.illust03 {
    -webkit-transition-delay: 0.6s;
    display: block;
    position: absolute;
    bottom: -2.4rem;
    left: -6.4rem;
    width: 10.08rem;
    height: 14.34rem;
    background-image: url(../images/home/project_illustration05.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.6s;
  }
  .p-home-project__item:nth-child(4) .p-home-project__illustration {
    display: block;
    position: absolute;
    top: -3rem;
    right: -13.6rem;
    width: 28rem;
    height: 24.4rem;
    background-image: url(../images/home/project_illustration06.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-home-project__item:nth-child(5) .p-home-project__illustration.illust02 {
    -webkit-transition-delay: 0.6s;
    display: block;
    position: absolute;
    top: -1rem;
    left: -12rem;
    width: 12.765rem;
    height: 12.765rem;
    background-image: url(../images/home/project_illustration08.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.6s;
  }
}

@media screen and (min-width: 1366px) {
  html {
    font-size: 62.5%;
  }
  .p-home-project__item:nth-child(2) .p-home-project__illustration {
    display: block;
    position: absolute;
    top: 5rem;
    left: -22rem;
    width: 27.3rem;
    height: 23.9rem;
    background-image: url(../images/home/project_illustration02.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-home-project__item:nth-child(3) .p-home-project__illustration.illust01 {
    -webkit-transition-delay: 0.5s;
    display: block;
    position: absolute;
    top: 8.6rem;
    right: -14rem;
    width: 13.88rem;
    height: 13.88rem;
    background-image: url(../images/home/project_illustration03.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.5s;
  }
  .p-home-project__item:nth-child(3) .p-home-project__illustration.illust02 {
    -webkit-transition-delay: 0.6s;
    display: block;
    position: absolute;
    top: -2.5rem;
    left: -15.5rem;
    width: 24.48rem;
    height: 24.345rem;
    background-image: url(../images/home/project_illustration04.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.6s;
  }
  .p-home-project__item:nth-child(3) .p-home-project__illustration.illust03 {
    -webkit-transition-delay: 0.6s;
    display: block;
    position: absolute;
    bottom: -3.6rem;
    left: -14rem;
    width: 10.08rem;
    height: 14.34rem;
    background-image: url(../images/home/project_illustration05.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.6s;
  }
  .p-home-project__item:nth-child(4) .p-home-project__illustration {
    display: block;
    position: absolute;
    top: -3.4rem;
    right: -15.6rem;
    width: 28rem;
    height: 24.4rem;
    background-image: url(../images/home/project_illustration06.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-home-project__item:nth-child(5) .p-home-project__illustration.illust02 {
    -webkit-transition-delay: 0.6s;
    display: block;
    position: absolute;
    top: -1rem;
    left: -15.6rem;
    width: 12.765rem;
    height: 12.765rem;
    background-image: url(../images/home/project_illustration08.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
            transition-delay: 0.6s;
  }
}

@media screen and (min-width: 768px) and (max-width: 1500px) {
  .l-menu__item:not(:last-child) {
    margin: 0 3.6rem 0 0;
  }
}

@media screen and (min-width: 1501px) {
  .l-menu__item:not(:last-child) {
    margin: 0 6.72rem 0 0;
  }
}
/*# sourceMappingURL=style.css.map */

/* 20230629 */
.p-home-bnr__img{
  position: relative;
}
.p-home-bnr__img img{
  width: 100%;
}
.p-home-bnr__txtBox{
  width: 100%;
  position: absolute;
  bottom: 5rem;
  left: 50%;
  transform: translateX(-50%);
}
.p-home-bnr__txt{
  width: 100%;
  margin-bottom: 2rem;
  font-weight: 600;
  font-size: 2rem;
  letter-spacing: 0.12em;
  text-align: center;
  color: #fff;
}
.p-home-bnr__txt::after{
  content: "";
  display: block;
  width: 1.7rem;
  height: .8rem;
  margin: 1.5rem auto 0;
  background: url(../images/common/ico_arrow-white.svg) no-repeat;
  background-size: contain;
}
.p-home-bnr__btn{
  width: 100%;
}
.p-home-bnr__btn a{
  display: block;
  width: 88.46%;
  margin: 0 auto;
  padding: 1.2rem 3.2rem 0.9rem;
  font-weight: 600;
  font-size: 2rem;
  letter-spacing: 0.1em;
  text-align: center;
  color: #009544;
  background: #fff;
  border-radius: 2.6rem;
}
.p-home-bnr__btn a::after{
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 2.8rem;
  height: 2.8rem;
  margin: -.2rem 0 0 2.5rem;
  background: url(../images/common/ico_arrow-circle.svg) no-repeat;
  background-size: contain;
}
@media screen and (min-width: 768px){
  .p-home-bnr__txtBox{
    bottom: 2.6vw;
  }
  .p-home-bnr__txt::after{
    content: none;
  }
  .p-home-bnr__btn a{
    width: 42.9rem;
    padding: 2rem 4rem 1.8rem;
    font-size: 2.5rem;
    border-radius: 3.1rem;
    transition: all .3s ease;
  }
  .p-home-bnr__btn a::after{
    margin: -.2rem 0 0 4.3rem;
  }
  .p-home-bnr__btn a:hover{
    opacity: 1;
    transform: scale(1.03);
  }
}
@media screen and (min-width: 768px) and (max-width: 1500px){
  .p-home-bnr__btn a{
    padding: 1.4rem 4rem 1.2rem;
    font-size: 2.2rem;
  }
}