/* arguments inittial */
/* font style */
/* site style */
/* [ writing-mode ]
-------------------------------------------------*/
/* [ easy breakpoint ]
-------------------------------------------------*/
@media (min-width: 1024px) {
  .c-pagename {
    padding: 58px 0 65px;
  }
}

@media (min-width: 1024px) {
  .c-pagename .tag {
    padding: 2px 8px 3px;
    font-size: 24px;
    font-size: 2.4rem;
    line-height: 1.33333em;
  }
}

#wrap {
  width: 100%;
  overflow: hidden;
}

.project-head {
  padding: 77px 0 43px;
  position: relative;
}

@media (min-width: 1024px) {
  .project-head {
    padding: 93px 0 60px;
  }
}

.project-head__en {
  pointer-events: none;
  opacity: 0.2;
  position: absolute;
  left: 3px;
  top: 22px;
  background-image: linear-gradient(#44278e 0%, #fff 100%);
  background-clip: text;
  -webkit-background-clip: text;
  /* For cross-browser compatibility */
  color: transparent;
  -webkit-text-fill-color: transparent;
  font-size: 56px;
  font-size: 5.6rem;
  line-height: 1em;
  letter-spacing: 0em;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .project-head__en {
    left: -13px;
    top: -1px;
    font-size: 120px;
    font-size: 12rem;
    line-height: 1em;
  }
}

@media only screen and (min-width: 1281px) {
  .project-head__en {
    left: 50%;
    margin-left: -650px;
  }
}

.project-head__heading {
  margin-bottom: 27px;
}

@media (min-width: 1024px) {
  .project-head__heading {
    margin-bottom: 61px;
  }
}

@media (min-width: 1024px) {
  .project-head__heading .lines {
    width: 546px;
  }
}

@media (min-width: 1024px) {
  .project-head__desc {
    max-width: 844px;
  }
}

.project-head__desc p {
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 2.13333em;
  letter-spacing: 0.03em;
  font-weight: 500;
}

@media (min-width: 1024px) {
  .project-head__desc p {
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.86667em;
    letter-spacing: 0.04em;
  }
}

.project-intro {
  padding: 55px 0 60px;
  position: relative;
}

@media (min-width: 1024px) {
  .project-intro {
    padding: 93px 0 161px;
  }
}

.project-intro__en {
  white-space: nowrap;
  pointer-events: none;
  opacity: 0.4;
  position: absolute;
  left: -5px;
  top: 3px;
  background-image: linear-gradient(#8ec400 0%, #fff 100%);
  background-clip: text;
  -webkit-background-clip: text;
  /* For cross-browser compatibility */
  color: transparent;
  -webkit-text-fill-color: transparent;
  font-size: 60px;
  font-size: 6rem;
  line-height: 1em;
  letter-spacing: -0.025em;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .project-intro__en {
    left: -9px;
    top: 11px;
    font-size: 115px;
    font-size: 11.5rem;
    line-height: 1em;
    letter-spacing: 0.01em;
    font-weight: 700;
  }
}

@media only screen and (min-width: 1281px) {
  .project-intro__en {
    left: 50%;
    margin-left: -650px;
  }
}

.project-intro__heading {
  margin-bottom: 27px;
}

@media (min-width: 1024px) {
  .project-intro__heading {
    margin-bottom: 62px;
  }
}

@media (max-width: 1023px) {
  .project-intro__heading .txt-big {
    width: calc(100% + 24px);
  }
}

@media (min-width: 1024px) {
  .project-intro__heading .lines {
    width: 546px;
  }
}

@media (min-width: 1024px) {
  .project-intro__desc {
    max-width: 844px;
  }
}

.project-intro__desc p {
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 2.13333em;
  letter-spacing: 0.04em;
  font-weight: 500;
}

@media (min-width: 1024px) {
  .project-intro__desc p {
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.86667em;
  }
}

.project-intro__whatis {
  position: relative;
  padding: 0 24px 20px;
  margin-top: 34px;
}

@media (min-width: 1024px) {
  .project-intro__whatis {
    margin-top: 76px;
  }
}

.project-intro__whatis .box-white {
  padding: 35px 24px 21px;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  position: relative;
  z-index: 1;
  transition-delay: .5s;
}

@media (min-width: 1024px) {
  .project-intro__whatis .box-white {
    padding: 47px 20px 39px;
    max-width: 1040px;
    margin: 0 auto;
  }
}

@media (min-width: 1024px) {
  .project-intro__whatis .box-white .box-in {
    max-width: 880px;
    margin: 0 auto;
  }
}

.project-intro__whatis .en {
  z-index: 1;
}

@media (min-width: 1024px) {
  .project-intro__whatis .en {
    top: -10px;
  }
}

.project-intro__whatis .ttl {
  margin-bottom: 28px;
  text-align: center;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 1.6em;
  letter-spacing: 0.04em;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .project-intro__whatis .ttl {
    margin-bottom: 40px;
    font-size: 24px;
    font-size: 2.4rem;
  }
}

.project-intro__whatis .ttl > span {
  padding: 0 19px;
  display: inline-block;
  border-bottom: solid 2px #8EC400;
}

@media (min-width: 1024px) {
  .project-intro__whatis .ttl > span {
    padding: 0 1px 4px;
  }
}

.project-intro__whatis .desc {
  margin-top: 23px;
  margin-bottom: -4px;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 2.13333em;
  letter-spacing: 0.04em;
  font-weight: 500;
}

@media (min-width: 1024px) {
  .project-intro__whatis .desc {
    margin-top: -5px;
    margin-bottom: 35px;
  }
}

.project-intro__whatis .scope img {
  width: 100%;
  margin-bottom: 25px;
}

@media (min-width: 1024px) {
  .project-intro__whatis .scope img {
    margin-bottom: 17px;
  }
}

.project-intro__whatis .scope .txt {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.33333em;
  letter-spacing: 0.08em;
  font-weight: 400;
}

.project-intro__whatis .scope .d-flex {
  display: flex;
}

.project-intro__whatis .scope .d-flex .label {
  width: 53px;
}

.project-intro__whatis .line {
  position: absolute;
  z-index: 0;
  top: 88.5%;
  left: 50%;
  width: 198vw;
  margin-left: 18vw;
  margin-top: -17px;
  transform: translate(-50%, -50%);
}

@media (min-width: 1024px) {
  .project-intro__whatis .line {
    top: 75%;
    width: 100%;
    margin: 0;
  }
}

.project-intro__whatis .line svg {
  width: 100%;
}

.project-intro__whatis .line svg rect {
  width: 0;
}

.project-intro__whatis.is-inview .line svg rect {
  animation: line-width-anim 1s linear forwards;
}

.project-intro__member {
  margin-top: 15px;
}

@media (min-width: 1024px) {
  .project-intro__member {
    margin-top: 82px;
  }
}

.project-intro__member .ttl {
  margin-bottom: 32px;
  text-align: center;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 2.13333em;
  letter-spacing: 0.04em;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .project-intro__member .ttl {
    margin-bottom: 45px;
    font-size: 24px;
    font-size: 2.4rem;
  }
}

.project-intro__member .ttl > span {
  padding: 0 1px;
  display: inline-block;
  border-bottom: solid 2px #8EC400;
}

@media (min-width: 1024px) {
  .project-intro__member .ttl > span {
    padding: 0 1px 4px;
  }
}

@media (min-width: 1024px) {
  .project-intro__member .list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    max-width: 880px;
    margin: 0 auto;
  }
}

@media (max-width: 1023px) {
  .project-intro__member .item {
    width: 62.4%;
    min-width: 234px;
    margin: 53px auto 0;
  }
  .project-intro__member .item:first-child {
    margin-top: 0;
  }
}

@media (min-width: 1024px) {
  .project-intro__member .item {
    width: 320px;
  }
}

.project-intro__member .item img {
  width: 100%;
  border-radius: 8px;
}

.project-intro__member .item .name {
  margin-top: 19px;
  text-align: center;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 2em;
  letter-spacing: 0.04em;
  font-weight: 500;
}

@media (min-width: 1024px) {
  .project-intro__member .item .name {
    margin-top: 31px;
    font-size: 20px;
    font-size: 2rem;
  }
}

.project-intro__member .item .txt {
  margin-top: 16px;
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 1.84615em;
  letter-spacing: 0.04em;
  font-weight: 400;
}

@media (min-width: 1024px) {
  .project-intro__member .item .txt {
    margin-top: 25px;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 2.13333em;
  }
}

@media (min-width: 1024px) {
  .project-intro__member .item .txt.l-spacing120 {
    letter-spacing: 0.12em;
  }
}

.project-phase {
  margin-bottom: 63px;
  position: relative;
  z-index: 1;
}

@media (min-width: 1024px) {
  .project-phase {
    margin-bottom: 161px;
  }
}

.project-phase__heading {
  margin-bottom: 26px;
}

@media (min-width: 1024px) {
  .project-phase__heading {
    margin-bottom: 42px;
  }
}

.project-phase__heading .en {
  display: inline-block;
  white-space: nowrap;
  text-align: center;
  opacity: 0.6;
  background-image: linear-gradient(#8ec400 0%, #fff 180%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  font-size: 11px;
  font-size: 1.1rem;
  line-height: 1em;
  letter-spacing: 0.04em;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .project-phase__heading .en {
    font-size: 17px;
    font-size: 1.7rem;
    line-height: 1em;
    letter-spacing: -0.05em;
    font-weight: 700;
  }
}

.project-phase__heading .en .number {
  margin-top: -5px;
  display: block;
  font-size: 41px;
  font-size: 4.1rem;
  line-height: 1em;
  letter-spacing: 0em;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .project-phase__heading .en .number {
    margin-top: -8px;
    margin-left: -1px;
    font-size: 56px;
    font-size: 5.6rem;
    line-height: 1em;
    letter-spacing: 0em;
    font-weight: 700;
  }
}

.project-phase__heading .ttl {
  margin-top: -1px;
  padding-bottom: 6px;
  border-bottom: solid 2px #8EC400;
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.55556em;
  letter-spacing: 0.1em;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .project-phase__heading .ttl {
    margin-top: -2px;
    padding-bottom: 3px;
    font-size: 24px;
    font-size: 2.4rem;
    line-height: 1.66667em;
  }
}

@media (max-width: 1023px) {
  .project-phase__heading .ttl.l-spacing60-sp {
    letter-spacing: 0.06em;
  }
}

.project-phase__content {
  padding: 0 24px;
}

@media (min-width: 1024px) {
  .project-phase__content {
    display: flex;
    justify-content: space-between;
    padding: 0;
  }
}

@media (min-width: 1024px) {
  .project-phase__content .text {
    width: calc(50% + 79px);
  }
}

@media (min-width: 1024px) {
  .project-phase__content .text .box-in {
    max-width: 624px;
    margin: 0 0 0 auto;
    padding-right: 40px;
    padding-left: 24px;
  }
}

.project-phase__content .text p {
  margin-bottom: 32px;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 2.13333em;
  letter-spacing: 0em;
  font-weight: 400;
}

@media (min-width: 1024px) {
  .project-phase__content .text p {
    letter-spacing: 0.04em;
  }
}

.project-phase__content .text p:last-child {
  margin-bottom: 0;
}

@media (min-width: 1024px) {
  .project-phase__content .text p.l-spacing20 {
    letter-spacing: 0.02em;
  }
}

@media (max-width: 1023px) {
  .project-phase__content .text p.l-spacing30-sp {
    letter-spacing: 0.03em;
  }
}

@media (max-width: 1023px) {
  .project-phase__content .text p.l-spacing-01-sp {
    letter-spacing: -0.01em;
  }
}

@media (max-width: 1023px) {
  .project-phase__content .text p.l-spacing-03-sp {
    letter-spacing: -0.03em;
  }
}

.project-phase__content .text .img-sp {
  margin-top: -6px;
  margin-bottom: 27px;
}

.project-phase__content .text .img-sp img {
  border-radius: 8px;
  width: 100%;
}

.project-phase__content .img {
  padding: 26px 0 0;
}

@media (min-width: 1024px) {
  .project-phase__content .img {
    padding: 5px 0 0;
    width: calc(50% - 79px);
  }
}

.project-phase__content .img img {
  border-radius: 8px;
  width: 100%;
}

@media (min-width: 1024px) {
  .project-phase__content .img img {
    max-width: 560px;
  }
}

@media (min-width: 1024px) {
  .project-phase__content.reverse {
    flex-direction: row-reverse;
  }
}

@media (min-width: 1024px) {
  .project-phase__content.reverse .text .box-in {
    margin: 0 auto 0 0;
    padding-right: 24px;
    padding-left: 40px;
  }
}

.project-phase__content.reverse .img {
  text-align: right;
}

@media (min-width: 1024px) {
  .project-phase__content-inside {
    display: flex;
    justify-content: space-between;
  }
}

@media (min-width: 1024px) {
  .project-phase__content-inside .text {
    width: calc(50% - 80px);
  }
}

.project-phase__content-inside .text p {
  margin-bottom: 32px;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 2.13333em;
  letter-spacing: 0em;
  font-weight: 400;
}

@media (min-width: 1024px) {
  .project-phase__content-inside .text p {
    letter-spacing: 0.04em;
  }
}

.project-phase__content-inside .text p:last-child {
  margin-bottom: 0;
}

@media (min-width: 1024px) {
  .project-phase__content-inside .text p.l-spacing20 {
    letter-spacing: 0.02em;
  }
}

.project-phase__content-inside .text .img-sp {
  margin-top: -6px;
  margin-bottom: 27px;
}

.project-phase__content-inside .text .img-sp img {
  border-radius: 8px;
  width: 100%;
}

@media (min-width: 1024px) {
  .project-phase__content-inside .img {
    width: calc(50% + 40px);
  }
}

.project-phase__content-inside .img img {
  border-radius: 8px;
  width: 100%;
}

@media (min-width: 1024px) {
  .project-phase__content-inside .img img {
    max-width: 560px;
  }
}

@media (min-width: 1024px) {
  .project-phase__content-inside.reverse {
    flex-direction: row-reverse;
  }
}

.project-phase__wide {
  margin-top: 32px;
}

@media (min-width: 1024px) {
  .project-phase__wide {
    margin-top: 45px;
  }
}

.project-phase__wide p {
  margin-bottom: 32px;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 2.13333em;
  letter-spacing: 0em;
  font-weight: 400;
}

@media (min-width: 1024px) {
  .project-phase__wide p {
    letter-spacing: 0.04em;
  }
}

.project-phase__wide p:last-child {
  margin-bottom: 0;
}

@media (max-width: 1023px) {
  .project-phase__wide p.l-spacing-0-sp {
    letter-spacing: 0em;
  }
}

@media (max-width: 1023px) {
  .project-phase__wide p.l-spacing-03-sp {
    letter-spacing: -0.03em;
  }
}

.project-phase__wide .img-sp {
  margin-top: -6px;
  margin-bottom: 27px;
}

.project-phase__wide .img-sp img {
  border-radius: 8px;
  width: 100%;
}

.project-phase__gallery {
  margin-top: 162px;
  display: flex;
}

.project-phase__gallery .col {
  width: 50%;
}

.project-phase__gallery img {
  border-radius: 8px;
}

.project-img-wide {
  margin-top: -37px;
  margin-bottom: 63px;
  position: relative;
  z-index: 1;
}

@media (min-width: 1024px) {
  .project-img-wide {
    margin-top: 0;
    margin-bottom: 168px;
  }
}

.project-img-wide img {
  width: 100%;
  border-radius: 8px;
}

@media (max-width: 1023px) {
  .project-img-wide.padding-sp {
    padding: 0 24px;
  }
}

.project-img-bottom {
  position: relative;
  z-index: 1;
  padding: 0 24px;
  margin-top: -37px;
}

@media (min-width: 1024px) {
  .project-img-bottom {
    padding: 0;
    margin: 0;
  }
}

.project-img-bottom img {
  width: 100%;
  border-radius: 8px;
}

.project-img-bottom.layout-twocol {
  display: flex;
  flex-wrap: wrap;
}

.project-img-bottom.layout-twocol .col {
  width: 100%;
  margin-top: 32px;
}

@media (min-width: 1024px) {
  .project-img-bottom.layout-twocol .col {
    width: 50%;
    margin-top: 0;
  }
}

.project-img-bottom.layout-twocol .col:first-child {
  margin-top: 0;
}

.c-bottom-bg {
  z-index: 2;
}

@media (min-width: 1024px) {
  .c-bottom-bg {
    z-index: 0;
  }
}

@media (max-width: 1023px) {
  .project01 .project-head {
    padding: 70px 0 30px;
  }
}

@media (max-width: 1023px) {
  .project01 .project-head__en {
    left: 7px;
    font-size: 64px;
    font-size: 6.4rem;
    line-height: 1em;
  }
}

@media (max-width: 1023px) {
  .project01 .project-head__heading {
    margin-bottom: 45px;
  }
}

@media (max-width: 1023px) {
  .project01 .project-head__desc p {
    letter-spacing: 0.04em;
    line-height: 28px;
  }
}

@media (max-width: 1023px) {
  .project01 .project-intro {
    padding: 0px 0 60px;
  }
}

.project01 .project-intro__whatis {
  margin-top: 0;
  padding-top: 48px;
}

@media (min-width: 1024px) {
  .project01 .project-intro__whatis {
    padding-top: 81px;
  }
}

.project01 .project-intro__whatis .ttl {
  margin-top: 4px;
}

@media (min-width: 1024px) {
  .project01 .project-intro__whatis .ttl {
    margin-top: -3px;
  }
}

.project01 .project-intro__whatis .ttl > span {
  padding: 0 0 4px;
}

@media (min-width: 1024px) {
  .project01 .project-intro__whatis .ttl > span {
    padding: 0 0 1px;
  }
}

.project01 .project-intro__whatis .line {
  top: 89.5%;
}

@media (min-width: 1024px) {
  .project01 .project-intro__whatis .line {
    top: 64%;
  }
}

@media (min-width: 1024px) {
  .project01 .project-intro__member {
    margin-top: 36px;
  }
}

@media (min-width: 1024px) {
  .project01 .project-intro__member .ttl {
    margin-bottom: 63px;
  }
}

@media (min-width: 1024px) {
  .project01 .project-intro__member .list {
    max-width: 966px;
  }
}

@media (max-width: 1023px) {
  .project01 .project-intro__member .item {
    margin-top: 29px;
  }
  .project01 .project-intro__member .item:first-child {
    margin-top: 0;
  }
}

@media (min-width: 1024px) {
  .project01 .project-intro__member .item {
    width: 235px;
  }
}

@media (min-width: 1024px) {
  .project01 .project-intro__member .item .name {
    margin-top: 26px;
  }
}

@media (min-width: 1024px) {
  .project01 .project-intro__member .item .txt {
    margin-top: 21px;
  }
}
