@charset "UTF-8";
/*----------------------------------------------------------------

メディアクエリ

----------------------------------------------------------------*/
.red {
  color: #DC423D;
}

.red_bg {
  background-color: #DC423D;
}

.black {
  color: #000000;
}

.black_bg {
  background-color: #000000;
}

main {
  /*----------------------------------------------------------------

  common

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

  sub_anchor_area

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

  about

  ----------------------------------------------------------------*/
}
main .section_btn_sub .text {
  transition: 0.4s;
}
main .section_btn_sub .material-symbols-outlined {
  transition: 0.4s;
}
@media (hover: hover) and (pointer: fine) {
  main .section_btn_sub:hover {
    opacity: 1;
    background-color: #fff;
  }
  main .section_btn_sub:hover .text {
    color: #DC423D;
  }
  main .section_btn_sub:hover .material-symbols-outlined {
    background-color: #DC423D;
    color: #fff;
  }
}
main .mv_sub {
  background-image: url(../img/common/mv_sub_bg.jpg);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  position: relative;
  z-index: 0;
}
main .mv_sub .bg_img {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
main .mv_sub .mv_sub_inner {
  position: relative;
  z-index: 0;
}
main .mv_sub .mv_sub_inner .mv_sub_text {
  position: relative;
  z-index: 0;
}
main .mv_sub .mv_sub_inner .mv_sub_text .bg_img_icon {
  position: absolute;
  top: 136px;
  left: -96px;
  width: 100px;
}
main .mv_sub .mv_sub_inner .bg_img_icon02 {
  position: absolute;
  bottom: -16%;
  right: 10%;
  width: 280px;
}
main .sub_anchor_area .sub_anchor_area_inner .section_btn {
  width: 380px;
}
main .sub_anchor_area .sub_anchor_area_inner .section_btn .text {
  transition: 0.4s;
}
main .sub_anchor_area .sub_anchor_area_inner .section_btn .material-symbols-outlined {
  transition: 0.4s;
}
@media (hover: hover) and (pointer: fine) {
  main .sub_anchor_area .sub_anchor_area_inner .section_btn:hover {
    opacity: 1;
    background-color: #DC423D;
  }
  main .sub_anchor_area .sub_anchor_area_inner .section_btn:hover .text {
    color: #fff;
  }
}
main .sub_anchor_area .sub_anchor_area_inner_company_3col .section_btn_company {
  width: 330px;
}
main .business_cont01 {
  position: relative;
  z-index: 0;
  padding: 300px 0;
}
main .business_cont01 .bg_img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
main .business_cont01 .bg_img_lower {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  top: unset;
}
main .business_cont02 {
  position: relative;
  z-index: 0;
}
main .business_cont02 .bg_img {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
main .business_cont02 .business_cont02_inner .production_area {
  background-image: url(../img/business/processing_bg.jpg);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
main .business_cont02 .business_cont02_inner .business_cont02_inner_upper {
  position: relative;
  z-index: 0;
}
main .business_cont02 .business_cont02_inner .business_cont02_inner_upper .bg_img {
  width: 220px;
  position: absolute;
  top: 140px;
  left: 400px;
}
main .business_cont03 {
  position: relative;
  z-index: 0;
}
main .business_cont03 .business_cont03_inner .left {
  position: relative;
  z-index: 0;
}
main .business_cont03 .business_cont03_inner .bg_img {
  position: absolute;
  top: -22%;
  left: -2%;
  right: 0;
  width: 80%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
main .business_cont03 .business_cont03_inner .flow_area .flow_area_card .flow_area_card_item_circle {
  width: 240px;
  height: 240px;
}
main .business_cont04 {
  background-image: url(../img/business/manage_bg.jpg);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  height: 43vw;
  width: 100%;
  position: relative;
  z-index: 0;
}
main .business_cont04 .bg_img {
  position: absolute;
  top: 0;
  left: 0;
}
main .business_cont04 .bg_img01 {
  bottom: 0;
  left: 0;
  right: 0;
  top: unset;
}
main .about_cont01 {
  position: relative;
  z-index: 0;
  padding: 300px 0;
  background-image: url(../img/about/about01.jpg);
  background-position: center;
  background-size: cover;
  overflow: hidden;
  background-repeat: no-repeat;
}
main .about_cont01 .bg_img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
main .about_cont01 .bg_img_lower {
  bottom: 0;
  left: 0;
  right: 0;
  top: unset;
}
main .about_cont01 .about_cont01_inner .about_cont01_inner_content .right {
  position: relative;
  z-index: 10;
}
main .about_cont01 .about_cont01_inner .about_cont01_inner_content .right .bg_icon {
  position: absolute;
  top: -30px;
  right: -80px;
  width: 220px;
  height: auto;
  z-index: -10;
}
main .about_cont02 {
  position: relative;
  z-index: 0;
}
main .about_cont02 .about_cont02_upper {
  position: relative;
  z-index: 0;
}
main .about_cont02 .about_cont02_upper .bg_img {
  position: absolute;
  top: 80px;
  left: 48%;
  transform: translateX(-50%);
  bottom: 0;
  width: -moz-fit-content;
  width: fit-content;
}
main .about_cont02 .about_cont02_upper .bg_img_lower {
  bottom: 0;
  left: 0;
  right: 0;
  top: unset;
}
main .about_cont02 .about_cont02_inner .about_cont02_inner_content .left {
  border-radius: 0 60px 60px 0;
  background-image: url(../img/about/quality_bg02.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
main .about_cont02 .about_cont02_inner .about_cont02_inner_content .right img {
  margin-right: 0;
  margin-left: auto;
  max-width: 900px;
}
main .about_cont03 {
  background-image: url(../img/about/quality_bg.jpg);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  height: 43vw;
  width: 100%;
  position: relative;
  z-index: 0;
}
main .about_cont03 .bg_img {
  position: absolute;
  top: 0;
  left: 0;
}
main .about_cont03 .bg_img01 {
  bottom: 0;
  left: 0;
  right: 0;
  top: unset;
}
main .about_cont04 .about_cont02_inner .about_cont02_inner_content .left {
  border-radius: 60px 0 0 60px;
  background-image: url(../img/about/factory_bg02.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
main .about_cont04 .about_cont02_inner .about_cont02_inner_content .left p {
  margin-left: 15%;
}
main .about_cont04 .about_cont02_inner .about_cont02_inner_content .right img {
  margin-right: auto;
  margin-left: 0;
  max-width: 900px;
}
main .about_cont05 {
  background-image: url(../img/about/factory_bg.jpg);
}
main .about_cont06 {
  background-image: url(../img/about/response_bg.jpg);
}
main .about_cont07 .about_cont07_inner {
  position: relative;
  z-index: 0;
}
main .about_cont07 .about_cont07_inner .bg_img {
  position: absolute;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: 450px;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: -10;
}
main .about_cont08 {
  background-image: url(../img/about/last_bg.jpg);
}

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

about

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

company

----------------------------------------------------------------*/
.company_profile_area {
  position: relative;
  z-index: 0;
}
.company_profile_area .bg_img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.company_profile_area .bg_img_lower {
  bottom: 0;
  left: 0;
  right: 0;
  top: unset;
}
.company_profile_area .company_profile_table {
  max-width: 1000px;
}
.company_profile_area .company_profile_table .profile_table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
}
.company_profile_area .company_profile_table .profile_table th {
  width: 30%;
  text-align: left;
  vertical-align: top;
}
.company_profile_area .company_profile_table .profile_table td {
  width: 70%;
}

.greeting_area {
  position: relative;
  z-index: 0;
}
.greeting_area .bg_img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.greeting_area .bg_img_lower {
  bottom: 0;
  left: 0;
  right: 0;
  top: unset;
}
.greeting_area .greeting_content .greeting_image img {
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}

.machining_area {
  position: relative;
  z-index: 0;
}
.machining_area .bg_img {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

.history_area {
  position: relative;
  z-index: 0;
}
.history_area .bg_img {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

.history_timeline {
  background: #fff;
  padding: 60px;
  border-radius: 30px;
}
.history_timeline .history_item {
  position: relative;
  border-left: 2px solid rgba(220, 66, 61, 0.2);
  padding-left: 40px;
}
.history_timeline .history_item::before {
  content: "";
  position: absolute;
  left: -8px;
  top: 5px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background-color: #DC423D;
  border: 3px solid #ffffff;
}
.history_timeline .history_item .history_year {
  min-width: 180px;
}

.company_profile_area .history_timeline {
  padding: 0px 0;
  margin-left: auto;
  margin-right: auto;
  max-width: 1000px;
}

.radial_area {
  position: relative;
  z-index: 0;
}
.radial_area .bg_img {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

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

recruit

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

contact

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