/* ---------------------------------------
  project
-----------------------------------------*/
.p-project {
  padding: 8rem 0 12rem;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .p-project {
    padding-top: 4.8rem;
  }
}

/* ---------------------------------------
  project-lead
-----------------------------------------*/
.p-project-lead .lead {
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-project-lead .lead {
    font-size: 1.6rem;
    line-height: 190%;
    text-align: left;
  }
}

/* ---------------------------------------
  project-list
-----------------------------------------*/
.p-project-list {
  margin-top: 6.4rem;
}
@media screen and (max-width: 767px) {
  .p-project-list {
    margin-top: 5.6rem;
  }
}
.p-project-list .c-inner {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 4rem 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 9.6rem 4rem;
  padding: 0 1.95rem;
}
@media screen and (max-width: 767px) {
  .p-project-list .c-inner {
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    gap: 6.4rem 0;
    padding: 0 4%;
  }
}
.p-project-list .project-clm .img-box {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1.6rem 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 1.6rem;
}
@media screen and (max-width: 767px) {
  .p-project-list .project-clm .img-box {
    gap: 0 1.5rem;
  }
}
.p-project-list .project-clm .img-box .img {
  position: relative;
}
.p-project-list .project-clm .img-box .img .cat {
  padding: 0.6rem 2rem;
  position: absolute;
  right: 0;
  bottom: 0;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .p-project-list .project-clm .img-box .img .cat {
    padding: 0.6rem 0.8rem;
  }
}
.p-project-list .project-clm .img-box .img .cat.civil {
  background-color: #E60012;
}
.p-project-list .project-clm .img-box .img .cat.architecture {
  background-color: #8B1129;
}
.p-project-list .project-clm .ttl {
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  .p-project-list .project-clm .ttl {
    margin-top: 1.6rem;
  }
}
.p-project-list .project-clm .ttl a {
  font-size: 3.6rem;
  font-weight: 600;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  border-bottom: solid 1px #fff;
  padding-bottom: 0.8rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-project-list .project-clm .ttl a {
    font-size: 2.4rem;
  }
}
.p-project-list .project-clm .ttl a::before {
  content: "";
  width: 0;
  height: 1px;
  background: #E60012;
  position: absolute;
  bottom: -1px;
  left: 0;
  -webkit-transition: width 0.4s;
  transition: width 0.4s;
}
.p-project-list .project-clm .ttl a::after {
  content: "";
  width: 4.2rem;
  height: 0.7rem;
  background: url(../img/btn_arw_wh.svg) no-repeat top/contain;
  margin-left: 1.6rem;
}
@media screen and (any-hover: hover) {
  .p-project-list .project-clm .ttl a:hover::before {
    width: 100%;
  }
}
.p-project-list .project-clm .lead {
  margin-top: 1.6rem;
  font-size: 2rem;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-project-list .project-clm .lead {
    margin-top: 0.8rem;
    font-size: 1.4rem;
    line-height: 170%;
  }
}
.p-project-list .project-clm .cat-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.8rem 0.6rem;
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  .p-project-list .project-clm .cat-list {
    gap: 0.6rem;
    margin-top: 1.2rem;
  }
}
.p-project-list .project-clm .cat-list li {
  padding: 0.8rem 1.2rem;
  border: solid 1px #656363;
}
@media screen and (max-width: 767px) {
  .p-project-list .project-clm .cat-list li {
    padding: 0.4rem 0.8rem;
  }
}

.l-page-head.m-under .-headline .ttl-txt {
  color: #fff;
  font-size: 2.4rem;
  font-weight: 600;
  padding-left: 2rem;
  margin-top: 1.2rem;
}
@media screen and (max-width: 767px) {
  .l-page-head.m-under .-headline .ttl-txt {
    font-size: 1.8rem;
    margin-top: -5rem;
    margin-bottom: 6rem;
  }
}

/* ---------------------------------------
  project-under-lead
-----------------------------------------*/
.p-project-under-lead {
  text-align: center;
  color: #fff;
  line-height: 180%;
  font-size: 2rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-project-under-lead {
    font-size: 1.8rem;
    line-height: 170%;
    text-align: left;
  }
}

/* ---------------------------------------
  project-under-list
-----------------------------------------*/
.p-project-under-list {
  margin-top: 6.4rem;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .p-project-under-list {
    margin-top: 2.8rem;
  }
}
.p-project-under-list .c-inner {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 6.5rem 1fr 6.5rem 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 8rem 6.5rem;
}
@media screen and (max-width: 767px) {
  .p-project-under-list .c-inner {
    -ms-grid-columns: (1fr)[1];
    grid-template-columns: repeat(1, 1fr);
  }
}
.p-project-under-list .project-clm .img {
  position: relative;
}
.p-project-under-list .project-clm .img .cat {
  padding: 0.6rem 2rem;
  position: absolute;
  right: 0;
  bottom: 0;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .p-project-under-list .project-clm .img .cat {
    padding: 0.6rem 1.6rem;
  }
}
.p-project-under-list .project-clm .img .cat.civil {
  background-color: #E60012;
}
.p-project-under-list .project-clm .img .cat.architecture {
  background-color: #8B1129;
}
.p-project-under-list .project-clm .ttl {
  margin-top: 1.6rem;
  line-height: 180%;
  text-align: center;
  font-size: 3.2rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-project-under-list .project-clm .ttl {
    margin-top: 0.8rem;
    font-size: 2.4rem;
  }
}
.p-project-under-list .project-clm .lead {
  line-height: 180%;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-project-under-list .project-clm .lead {
    line-height: 170%;
  }
}

/* ---------------------------------------
  project-under-soilenvironment
-----------------------------------------*/
.p-project-under-soilenvironment {
  margin-top: 8rem;
}
.p-project-under-soilenvironment .u-btn {
  width: 34.1rem;
}
@media screen and (max-width: 767px) {
  .p-project-under-soilenvironment .u-btn {
    width: 100%;
  }
}

/* ---------------------------------------
  project-under-information
-----------------------------------------*/
.p-project-under-information {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .p-project-under-information .u-headline {
    font-size: 2.2rem;
  }
}
.p-project-under-information .info-box {
  padding: 4rem 4.8rem;
  background-color: #F4F2F1;
}
@media screen and (max-width: 767px) {
  .p-project-under-information .info-box {
    padding: 3.2rem 2.4rem;
  }
}
.p-project-under-information .list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .p-project-under-information .list li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.p-project-under-information .list li .cat {
  min-width: 12rem;
  padding: 0.8rem;
  text-align: center;
  border: solid 1px #E60012;
}
@media screen and (max-width: 767px) {
  .p-project-under-information .list li .cat {
    min-width: auto;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: 0.7rem 1.6rem;
  }
}
.p-project-under-information .list li .txt {
  line-height: 160%;
  margin-left: 1.6rem;
}
@media screen and (max-width: 767px) {
  .p-project-under-information .list li .txt {
    line-height: 170%;
    margin-left: 0;
    margin-top: 0.4rem;
  }
}
.p-project-under-information .list li + li {
  margin-top: 1.6rem;
}
@media screen and (max-width: 767px) {
  .p-project-under-information .list li + li {
    margin-top: 3.2rem;
  }
}

/* ---------------------------------------
  project-under-foot
-----------------------------------------*/
.p-project-under-foot .-list {
  -ms-grid-columns: 1fr 4.8rem 1fr 4.8rem 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 3.2rem 4.8rem;
}
@media screen and (max-width: 767px) {
  .p-project-under-foot .-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    gap: 2.4rem 0;
  }
}
.p-project-under-foot .-list li a {
  font-weight: 600;
  padding: 1.7rem 0 1.7rem;
}
.p-project-under-foot .-list li a .att {
  color: #A2A0A0;
  display: block;
  font-size: 1.4rem;
  font-weight: 400;
  margin-top: 1rem;
}