@charset "utf-8";

/*--------------------------------------------------------------------------------------------------

   object
         - index
         - business
         

--------------------------------------------------------------------------------------------------*/


/*--------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------*/
.p-home-banner {
  width: 100%;
  position: relative;
}

.p-home-banner img {
  width: 100%;
}

.p-home-banner__text {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 65px;
  letter-spacing: 0.5px;
  line-height: 1.4;
  font-weight: 800;
  color: #fff;
}

.bx-wrapper {
  position: relative;
}

.bx-has-pager {
  position: absolute;
  bottom: 30px;
  z-index: 100;
  left: 0;
  right: 0;
  text-align: center;
}

.bx-pager-item {
  display: inline-block;
  margin: 0 9px;
}

.bx-pager-link {
  width: 10px;
  height: 10px;
  background-color: #a6a6a6;
  text-indent: -99999px;
  border-radius: 50%;
}

.bx-pager-link.active,
.bx-pager-link:hover {
  background-color: #000;
}

.p-home-about,
.p-home-project,
.p-business-main-line,
.p-business-main-work {
  position: relative;
  width: 100%;
}

.p-home-about,
.p-home-project {
  padding-top: 45px;
  height: 500px;
}

.p-home-about__text,
.p-home-project__text,
.p-business-main__text {
  height: 100%;
}

.p-home-about {
  background: linear-gradient(70deg, #0303ae, #2871fa);
}

.p-home-project {
  background-color: #ccc;
}

.p-home-desc {
  margin: 20px 0 55px 0;
  font-weight: 500;
}

.p-home-about::after,
.p-home-project::before,
.p-business-main-line::before,
.p-business-main-work::after {
  content: "";
  height: 500px;
  position: absolute;
  z-index: 1;
  top: 0;
}

.p-home-about::after {
  width: calc(50% + 120px);
}

.p-home-project::before,
.p-business-main-line::before {
  width: calc(50% + 70px);
}

.p-home-about::after {
  background: url(../image/top/img-about-top.png) no-repeat right top; 
  background-size: cover;
  right: 0;
}

.p-home-project::before {
  background: url(../image/top/img-project-top.png) no-repeat left top; 
  background-size: cover;
  left: 0;
}

.p-home-heading__main--line {
  padding-bottom: 12px;
  border-bottom: 2px solid #fff;
}

.p-home-heading__main--about,
.p-home-heading__sub--about {
  padding-left: calc(50% - 510px);
}

.p-home-heading__main--project,
.p-home-heading__sub--project,
.p-home-project__text,
.p-business-main-line__text {
  padding-left: calc(50% + 110px);
}

.p-home-recruit {
  padding: 75px 0 60px 0;
  background: url(../image/top/bg-main-recruit-top.png) no-repeat top right;
  background-size: cover;
}

.p-home-recruit__text {
  margin-left: 115px;
  width: 280px;
  text-align: center;
}

.p-home-new {
  padding: 20px 0 48px 0;
}

.p-listnew--home {
  margin: 30px 0 30px 0;
}

/*--------------------------------------------------------------------------------------------
  business main
--------------------------------------------------------------------------------------------*/
.p-business-main-line {
  margin: 60px 0 30px 0;
}

.p-business-main-work {
  margin-bottom: 50px;
}

.p-business-main-line,
.p-business-main-work {
  padding-top: 30px;
  height: 345px;
  background: #ccc;
}

.p-business-heading__main--line {
  padding-bottom: 12px;
  border-bottom: 3px solid #fff;
}

.p-business-main-line::before,
.p-business-main-work::after {
  height: 345px;
}

.p-business-main-line::before {
  background: url(../image/business/img1-business-main.png) no-repeat left center; 
  background-size: cover;
  left: 0;
}

.p-business-main-work::after {
  background: url(../image/business/img2-business-main.png) no-repeat right top; 
  background-size: cover;
  right: 0;
}

.p-business-main-work::after {
  width: calc(50% + 70px);
}

.p-business-main-desc {
  font-size: 18px;
  letter-spacing: 0.5px;
  line-height: 1.4;
  margin: 10px 0 20px 0;
  font-weight: 500;
}
/*--------------------------------------------------------------------------------------------
  business child
--------------------------------------------------------------------------------------------*/
.p-content-page {
  margin: 40px 0;
}

.p-content-business {
  margin: 40px 0 0 0;
  background: url(../image/business/bg-content-business.jpg) no-repeat left top;
  background-size: cover;
}

.p-content-business--work {
  padding-bottom: 50px;
}

.p-content-business__item {
  padding: 55px 0 30px 0;
  justify-content: space-between;
}

.p-content-business__photo-list img {
  margin-bottom: 18px;
  max-height: 100%;
  object-fit: contain;
}

.p-content-business__item h3 {
  font-size: 30px;
  font-weight: 800;
  color: #0303ae;
  line-height: 1.4;
  margin-bottom: 20px;
  letter-spacing: 0.5px;
}

.p-content-business__desc,
.p-content-business__desc_2  {
  width: 91%;
  margin-bottom: 30px;
  font-size: 18px;
  letter-spacing: 0.5px;
  line-height: 1.6;
  font-weight: 500;
}

.p-content-business__desc_2 {
  width: 100%;
}


.p-content-business__engineering {
  justify-content: space-between;
  flex-wrap: wrap;
  padding-top: 10px;
  padding-bottom: 35px;
}

.p-content-business__engineering li {
  width: calc(33.33333% - 10px);
  margin-bottom: 25px;
  padding: 18px 25px 18px 55px;
  background-color: #0303ae;
  color: #fff;
  font-size: 22px;
  position: relative;
  letter-spacing: 0.5px;
}

.p-content-business__engineering li::before {
  content: "";
  position: absolute;
  left: 25px;
  top: 22px;
  width: 20px;
  height: 20px;
  background-color: #fff;
}

/*--------------------------------------------------------------------------------------------
  company
--------------------------------------------------------------------------------------------*/
.p-content-company {
  padding: 60px 0 70px 0px;
  background: url(../image/business/bg-content-business.jpg) no-repeat left top;
  background-size: cover;
}

.p-content-company .l-container {
  width: 724px;
}

.p-content-company__intro {
  margin-top: 3px;
  margin-bottom: 97px;
}

.p-content-company__intro-title {
  font-size: 30px;
  font-weight: 800;
  color: #384cc8;
}

.p-content-company__intro-desc {
  font-weight: 500;
  font-size: 18px;
  line-height: 1.8;
  margin-top: 7px;
}

.p-content-company--history {
  padding: 100px 0 85px 0;
}

.p-company-about::before {
  background: url(../image/company/img1-company.png) no-repeat left top;
  background-size: cover;
}

.p-company-history::after {
  background: url(../image/company/img2-company.png) no-repeat left top;
  background-size: cover;
}

.p-company-education::before {
  background: url(../image/company/img3-company.png?v=2) no-repeat left top;
  background-size: cover;
}

/*--------------------------------------------------------------------------------------------
  news
--------------------------------------------------------------------------------------------*/
.p-content-news {
  padding: 130px 0 120px 0;
  background: url(../image/business/bg-content-business.jpg) no-repeat left top;
  background-size: cover;
  position: relative;
}

.p-content-news::after {
  content: "";
  position: absolute;
  top: 130px;
  width: 100%;
  height: calc(100% - 250px);
  background-color: rgba(204, 204, 204, 0.3);
}

.p-content-news .l-container {
  width: 960px;
  background-color: #fff;
  margin: 70px auto;
  padding: 37px 35px;
  border-radius: 20px;
  position: relative;
  z-index: 1;
}

.p-content-news .p-listnew__item {
  margin-bottom: 70px;
  width: calc(33.33333% - 23px);
}

.p-content-news__title-detail {
  font-size: 20px;
  font-weight: 800;
  color: #0303ae;
}

.p-content-news__date-detail {
  padding-left: 40px;
  background: url(../image/news/icon-calendar.jpg) no-repeat left center;
  line-height: 30px;
  font-size: 14px;
  font-weight: 600;
  color: #0303ae;
  margin-top: 20px;
}

.p-content-news__info-detail {
  padding: 22px 0 30px 0;
}

.p-content-news__desc-detail {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 35px;
}

.p-content-news .c-btn {
  min-width: 260px;
  padding: 14px 35px 14px 0;
  border-width: 2px;
  font-weight: 700;
  position: relative;
  font-size: 20px;
}

.p-content-news--detail .l-container {
  padding: 57px 65px 60px 65px;
}

/*--------------------------------------------------------------------------------------------
  contact
--------------------------------------------------------------------------------------------*/
.p-content-contact {
  padding: 70px 0 80px 0;
  background: url(../image/business/bg-content-business.jpg) no-repeat left top;
  background-size: cover;
}

.p-content-contact__intro {
  line-height: 1.8;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
}

.p-content-contact__note {
  font-size: 14px;
  font-weight: 600;
  padding-left: 180px;
  margin: 67px 0 10px 0;
}

.p-content-contact__form {
  width: 655px;
  padding: 100px 70px 25px 70px;
  margin: 0 auto;
  background-color: #fff;
}

.p-table-contact td,
.p-table-contact th {
  width: 150px;
  padding-bottom: 15px;
  color: #4e4a4a;
  font-weight: 500;
}

.p-table-contact th {
  font-size: 14px;
  font-weight: 600;
  padding-top: 5px;
  vertical-align: top;
}

.p-table-contact td p {
  font-size: 10px;
  padding-top: 5px;
}

.p-table-contact input {
  border: 1px solid #b6b1b1;
  width: 260px;
  height: 26px;
  padding: 0 5px;
}

.p-table-contact .input-small {
  width: 36px;
  height: 17px;
}

.p-table-contact .input-medium {
  width: 50px;
  height: 17px;
}

.p-table-contact textarea {
  width: 347px;
  height: 133px;
}

.p-content-contact .font-red {
  color: #d23226;
  margin-left: 5px;
}

.p-content-contact .c-btn {
  border: 2px solid #000;
  margin-top: 75px;
  background: url(../image/contact/icon-next.png) no-repeat right 20px center;
  cursor: pointer;
}

.p-content-contact .button-box li {
  display: inline-block;
  margin: 0 10px;
}

/*--------------------------------------------------------------------------------------------
  privacy
--------------------------------------------------------------------------------------------*/
.p-content-privacy {
  background: url(../image/business/bg-content-business.jpg) no-repeat left top;
  background-size: cover;
}

.p-content-privacy .l-container {
  padding: 0 30px;
  margin-top: 70px;
}

.p-content-privacy h3 {
  font-size: 26px;
  border: 2px solid #2929b4;
  padding: 5px 10px;
  display: inline-block;
  font-weight: 700;
}

.p-content-privacy__text {
  font-weight: 500;
  padding:  20px 0 70px 0;
  font-size: 18px;
  line-height: 1.6;
}

.p-content-privacy li {
  margin-bottom: 20px;
  list-style: decimal;
  margin-left: 20px;
}

/*--------------------------------------------------------------------------------------------
  recruit
--------------------------------------------------------------------------------------------*/

.p-recruit-voice::before {
  background: url(../image/recruit/img1-recruit.png) no-repeat left center;
  background-size: cover;
}

.p-recruit-guideline1::after {
  background: url(../image/recruit/img2-recruit.png?v=2) no-repeat left center;
  background-size: cover;
}

.p-recruit-guideline2::before {
  background: url(../image/recruit/img3-recruit.png) no-repeat left center;
  background-size: cover;
}

.p-content-voice__photo-list img {
  margin-bottom: 10px;
  margin-top: 15px;
}