@charset "UTF-8";

/**************************************

common

**************************************/

.section_cmn .section_sub {
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: 20px;
}

.page_lead {
  text-align: center;
  font-size: 1.6rem;
  margin-bottom: 70px;
}

@media screen and (max-width: 760px) {
  .section_cmn {
    padding-bottom: 15%;
  }

  .section_cmn .section_sub {
    font-size: 1.6rem;
    margin-bottom: 5%;
  }

  .page_lead {
    font-size: 1.3rem;
    margin: 0 auto 10%;
    text-align: left;
    width: 86%;
  }
}

/**************************************

works

**************************************/
.section_works {
  padding: 0;
  max-height: none;
  margin: 0;
}

.section_works .inner_box {
  background: #FEF6BF;
  padding: 90px 4%;
}

.section_works .phase_wrapper {
  width: 100%;
  height: auto;
  padding-bottom: 0;
  overflow: initial;
}

.section_works .phase_slide {
  position: relative;
  display: block;
  background: none;
  border-radius: 0;
  padding: 0;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  background: none;
  padding: 0;
}

.section_works .phase_slide .box {
  width: 100%;
  max-width: none;
  position: relative;
  background: #FFF;
  border-radius: 10px;
  padding: 4vw 5.5%;
  margin: 0 auto 42px;
}

.section_works .phase_slide .box:last-child {
  margin-bottom: 0;
}

.section_works .phase_slide .box:not(:last-child):after {
  content: "";
  position: absolute;
  bottom: -28px;
  left: 50%;
  transform: translateX(-50%);
  width: 34px;
  height: 15px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background: #1C1C1C;
}

.section_works .phase_slide .tit_phase {
  margin-bottom: 20px;
}

.section_works .phase_slide .num {
  font-size: 1.4rem;
}

.section_works .phase_slide h4 span {
  font-size: min(3.6vw, 4.2rem);
}

.section_works .phase_slide .txt {
  font-size: min(1.3vw, 1.6rem);
  line-height: 1.8;
}

@media screen and (min-width: 761px) {
  .section_works .phase_slide .tit_phase {
    margin-bottom: 0;
    position: absolute;
    top: 50px;
    left: 5.5%;
    background: #ffffffc7;
    padding-bottom: 20px;
    padding-right: 20px;
  }
}

@media screen and (max-width: 760px) {
  .section_works .inner_box {
    padding: 10% 3%;
  }

  .section_works .phase_slide .box {
    margin-bottom: 22px;
    border-radius: 8px;
    padding: 4.5% 5.5%;
  }

  .section_works .phase_slide .box:not(:last-child):after {
    bottom: -16px;
    width: 20px;
    height: 10px;
  }

  .section_works .phase_slide .tit_phase {
    margin-bottom: 4%;
  }

  .section_works .phase_slide .num {
    font-size: 1.2rem;
  }

  .section_works .phase_slide h4 span {
    font-size: 2.6rem;
  }

  .section_works .phase_slide .txt {
    font-size: 1.3rem;
  }
}


/**************************************

project

**************************************/

.section_project {
  padding-top: 120px;
  margin-top: 0;
}

.section_project .article_h2 {
  padding: 0;
  margin-bottom: 3vw;
}

.section_project .project_slide_box .box {
  background: url(../works/img/bg_project.png) top left no-repeat;
  background-size: 100% 100%;
  width: 100%;
  height: auto;
  margin-right: 0;
}

.section_project .project_slide_box .box:not(:last-child) {
  margin-bottom: 20px;
}

.section_project .project_slide_box .box > a {
  display: flex;
  align-items: stretch;
  padding: 5% 2.5% 3%;
  column-gap: 3%;
  height: auto;
}

.section_project .project_slide_box .num {
  top: 4%;
  left: 2%;
  font-size: min(1.3vw, 1.6rem);
}

.section_project .project_slide_box .ph {
  flex-basis: 42%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
}

.section_project .project_slide_box .ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.section_project .project_slide_box .info_box {
  flex-basis: 54%;
}

.section_project .project_slide_box .name {
  font-size: min(2.2vw, 3rem);
  margin: 10px 0 6px;
}

.section_project .project_slide_box .sub {
  font-size: min(1.3vw, 1.6rem);
  margin-bottom: 12px;
}

.section_project .project_slide_box .contents {
  font-size: 1.3rem;
  line-height: 1.6;
}

.section_project .project_slide_box .detail {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid #1C1C1C;
  line-height: 1.6;
}

.section_project .project_slide_box .btn_more {
  position: relative;
  bottom: auto;
  left: auto;
  margin-top: 4%;
}

.section_project .project_slide_box .btn_more span {
  padding-right: 46px;
}

.section_project .project_slide_box .btn_more span::after {
  width: 36px;
  height: 36px;
  background-image: url(../img/cmn/icon_blank.svg);
}

.section_project .lead_txt {
  font-size: 2.4rem;
  margin-bottom: 20px;
  font-weight: 700;
  text-align: center;
  line-height: 1.8;
}

.section_project .client_list {
  margin-top: 100px;
  padding: 80px;
  background: #F5F5F5;
  border-radius: 6px;
}

.section_project .client_list .box_y {
  display: flex;
  flex-wrap: nowrap;
  column-gap: 40px;
}

.section_project .client_list .box_y:not(:last-child) {
  margin-bottom: 30px;
}

.section_project .client_list .tit {
  line-height: 3.4;
  flex-basis: 60px;
}

.section_project .client_list ul {
  flex-basis: calc(100% - 100px );
  max-width: calc(100% - 100px);
}

.section_project .client_list ul li {
  line-height: 1.4;
  margin-top: 15px;
}

@media screen and (max-width: 760px) {
  .section_project {
    padding-top: 15%;
  }

  .section_project .article_h2 {
    margin-bottom: 5%;
  }

  .section_project .project_slide_box .box {
    background-image: url(../works/img/bg_project_sp.png);
  }

  .section_project .project_slide_box .box:not(:last-child) {
    margin-bottom: 4%;
  }

  .section_project .project_slide_box .box > a {
    display: block;
    padding: 10% 4.5% 4%;
  }

  .section_project .project_slide_box .num {
    top: 2.3%;
    left: 4.5%;
    font-size: 1.2rem;
  }

  .section_project .project_slide_box .ph {
    margin-bottom: 3%;
  }

  .section_project .project_slide_box .info_box {
    padding: 0 2%;
  }

  .section_project .project_slide_box .name {
    font-size: 2.2rem;
    margin: 0 0 2%;
  }

  .section_project .project_slide_box .sub {
    font-size: 1.4rem;
    margin-bottom: 4%;
  }

  .section_project .project_slide_box .contents {
    font-size: 1.2rem;
  }

  .section_project .project_slide_box .detail {
    margin-top: 4%;
    padding-top: 4%;
  }

  .section_project .project_slide_box .btn_more {
    margin-top: 3%;
  }

  .section_project .lead_txt {
    font-size: 1.8rem;
    margin-bottom: 4%;
    line-height: 1.4;
  }

  .section_project .client_list {
    margin-top: 12%;
    padding: 8% 7%;
    width: 108%;
    margin-left: -4%;
  }

  .section_project .client_list .box_y {
    display: block;
  }

  .section_project .client_list .box_y:not(:last-child) {
    margin-bottom: 10%;
  }

  .section_project .client_list .tit {
    line-height: 1.0;
    margin-bottom: 3%;
  }

  .section_project .client_list ul {
    flex-basis: 100%;
    max-width: 100%;
  }

  .section_project .client_list ul li {
    line-height: 1.4;
    margin-top: 3%;
  }
}



/**************************************

about

**************************************/

.section_about .lead_block {
  display: flex;
  margin-bottom: 80px;
}

.section_about .lead_block .txt_box {
  flex-basis: 40%;
}

.section_about .lead_block .txt_box h3 {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 25px;
}

.section_about .lead_block .ph {
  flex-basis: 60%;
}

.section_about .lead_block .ph img {
  border-radius: 8px;
}

.section_about .member_block h4 {
  font-size: 2.8rem;
  font-weight: 700;
  margin-bottom: 25px;
}

.section_about .member_block .list_box {
  display: flex;
  flex-wrap: wrap;
  column-gap: 7%;
  row-gap: 30px;
}

.section_about .member_block .list_box li {
  flex-basis: 46.5%;
  display: flex;
  align-items: center;
  column-gap: 25px;
  line-height: 1.8;
}

.section_about .member_block .list_box .icon {
  flex-basis: 200px;
}

.section_about .member_block .list_box .name {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.0;
}

.section_about .member_block .list_box .name.en {
  margin-bottom: 8px;
}

.section_about .member_block .list_box .sub {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.0;
  opacity: .5;
  margin: 8px 0 12px;
}


@media screen and (max-width: 760px) {
  .section_about .lead_block {
    margin-bottom: 14%;
    flex-wrap: wrap;
    flex-direction: column-reverse;
  }

  .section_about .lead_block .txt_box {
    flex-basis: 100%;
  }

  .section_about .lead_block .txt_box h3 {
    font-size: 2.4rem;
    margin-bottom: 3%;
  }

  .section_about .lead_block .ph {
    flex-basis: 100%;
    margin-bottom: 5%;
  }

  .section_about .lead_block .ph img {
    border-radius: 6px;
  }

  .section_about .member_block h4 {
    font-size: 2.0rem;
    margin-bottom: 6%;
  }

  .section_about .member_block .list_box {
    column-gap: 0;
    row-gap: 15px;
  }

  .section_about .member_block .list_box li {
    flex-basis: 100%;
    column-gap: 5%;
  }

  .section_about .member_block .list_box .icon {
    flex-basis: 120px;
  }

  .section_about .member_block .list_box .name {
    font-size: 2rem;
  }

  .section_about .member_block .list_box .name.en {
    margin-bottom: 2%;
  }

  .section_about .member_block .list_box .sub {
    font-size: 1.3rem;
    margin: 4% 0 6%;
  }
}


/**************************************

company

**************************************/

.section_company {
  padding: 150px 8% 0;
}

.section_company .article_h2 {
  padding: 0;
}

.section_company .information_box dl {
  border-bottom: 1px solid rgba(89,87,87,0.14);
  padding: 25px 20px;
  position: relative;
}

.section_company .information_box dl::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 20%;
  height: 1px;
  background: #000;
}

.section_company .information_box dt {
  width: 20%;
  font-weight: 500;
  display: inline-block;
  vertical-align: top;
  line-height: 1.6;
}

.section_company .information_box dd {
  width: 78%;
  display: inline-block;
  vertical-align: top;
  line-height: 1.6;
}

.section_company .information_box dd em {
  font-weight: 700;
}

.section_company .information_box dd .job {
  display: inline-block;
  width: 140px;
}

.section_company .information_box .ph_iso {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .section_company {
    padding: 18% 0 0;
  }

  .section_company .information_box dl {
    padding: 4% 0;
  }

  .section_company .information_box dl::after {
    width: 32%;
  }

  .section_company .information_box dt {
    width: 32%;
  }

  .section_company .information_box dd {
    width: 65%;
  }

  .section_company .information_box dd .job {
    width: 115px;
  }

  .section_company .information_box .ph_iso {
    width: 100%;
  }
}


/**************************************

policy

**************************************/

.section_policy {
  text-align: left;
  font-size: 1.6rem;
  background: #FFF;
}

.section_policy .inner {
  padding: 80px 8%;
}

.section_policy .policy_box:not(:last-child) {
  margin-bottom: 60px;
}

.section_policy .box {
  margin-top: 30px;
  margin-bottom: 40px;
}

.section_policy .box:last-child {
  margin-bottom: 0px;
}

.section_policy h3 {
  font-size: 2.8rem;
  color: #1B254D;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 20px;
}

.section_policy h4 {
  font-size: 2.0rem;
  font-weight: 700;
}

.section_policy .sign_box {
  padding: 3px 0 5px 20px;
  border-left: 2px solid #1B254D;
}

.section_policy .txt a {
  text-decoration: underline;
  color: #1B254D;
}

@media screen and (max-width: 760px) {
  .main_policy .container_inner {
    padding: 0 3%;
  }

  .section_policy {
    width: 100%;
    font-size: 1.3rem;
  }

  .section_policy .inner {
    padding: 8% 6%;
  }

  .section_policy .policy_box:not(:last-child) {
    margin-bottom: 10%;
  }

  .section_policy .box {
    margin-top: 8%;
    margin-bottom: 8%;
  }

  .section_policy h3 {
    font-size: 1.8rem;
    margin-bottom: 4%;
  }

  .section_policy h4 {
    font-size: 1.6rem;
    margin-bottom: 2%;
    line-height: 1.4;
  }
}


/**************************************

sitemap

**************************************/

.section_sitemap {
  text-align: left;
  background: #FFF;
}

.section_sitemap .inner {
  padding: 80px 8%;
}

.section_sitemap .sitemap_block:not(:last-child) {
  margin-bottom: 40px;
}

.section_sitemap h3 {
  font-size: 2.8rem;
  font-weight: 700;
  color: #1B254D;
  margin-bottom: 30px;
  line-height: 1.0;
}

.section_sitemap .sitemap_box ul {
  flex-basis: 25%;
}


@media screen and (max-width: 760px) {
  .main_sitemap .container_inner {
    padding: 0 3%;
  }

  .section_sitemap .inner {
    padding: 8% 8%;
  }

  .section_sitemap .sitemap_block:not(:last-child) {
    margin-bottom: 10%;
  }

  .section_sitemap .sitemap_box {
    flex-wrap: wrap;
  }

  .section_sitemap .sitemap_box ul {
    flex-basis: 100%;
  }

  .section_sitemap .sitemap_box li {
    margin-bottom: 2%;
  }

  .section_sitemap .sitemap_box ul.sub li a {
    line-height: 1.8;
  }

  .section_sitemap h3 {
    font-size: 2.0rem;
    margin-bottom: 5%;
  }
}
