@charset "UTF-8";

main{
    color: #231815;
}
section + section{
    padding-top: 0;
}
.mb_l{
    margin-bottom: 2em!important;
}
.mb_m{
    margin-bottom: 1em!important;
}
.mb_s{
    margin-bottom: 0.5em!important;
}


.ta_c{
    text-align: center;
}
.ta_r{
    text-align: right;
}

.container {
    max-width: 1080px;
    margin: 0 auto;
}

#fv{
/*
    overflow: hidden;
    max-height: 467px;
*/
}
#fv .textbox{
    background: initial;
    color: #9B003A;
}
#fv .slider01 .swiper-slide {
    border-radius: 0;
}
#fv .slider01 {
    width: 100%;
}

#message{
    padding-top: 60px;
}
.message-txtarea{
    max-width: 800px;
    margin: 0 auto;
}

#motto{
    padding-top: 55px;
}
.green-box{
    border: 2px solid #009B63;
    border-radius: 1em;
    padding: 1em;
}
.green-box div + div{
    margin: 1em;
}
@media screen and (max-width: 767px){
    #firstview .swiper-wrapper{
            height: auto;
    }
    #firstview .swiper-slide{
        background-color: #E6E6E6;
        height: auto;
    }
    #firstview .swiper-slide .firstview_box{
        height: 100%;
    }
    #firstview h1{
        min-height: 7em;
        display: flex;
        align-items: center;
    }
    #firstview h1 span{
        display: block;
        width: 100%;
    }
}
@media screen and (min-width: 1080px){
    .green-box .img_area{
        width: 40%;
    }
    .green-box .textbox{
        width: 60%;
    }
}

.service-circle {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(auto-fit, minmax(135px, 1fr));
}

.service-circle li {
  border-radius: 100%;
  padding: 16px;
  background: #c06234;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
}
.service-circle li:nth-child(2) {
  background: #00baf1;
}
.service-circle li:nth-child(3) {
  background: #11b387;
}
.service-circle li:nth-child(4) {
  background: #4365b0;
}
.service-circle li:nth-child(5) {
  background: #a53653;
}
.service-circle li:nth-child(6) {
  background: #ef59a1;
}
.service-circle li:nth-child(7) {
  background: #8351a0;
}

.service-circle li::before {
  display: block;
  content: '';
  padding-top: 100%;
}
.ten{
    line-height: 1;
    font-size: 10px;
    display: block;
    font-weight: bold;
}
@media screen and (min-width: 880px) {
    .service-circle li:nth-child(odd){
        margin-bottom: 80px;

    }
    .service-circle li:nth-child(even){
        margin-top: 80px;
    }
}
@media screen and (min-width: 1080px){
    .service-circle {
      display: grid;
      gap: 20px;
      grid-template-columns: repeat(auto-fit, minmax(135px, 1fr));
    }
}

.challenge{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -moz-justify-content: space-between;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.challenge dt{
    width: 100%;
    margin-bottom: 0.5em;
}
.challenge dt div{
    background-color: #009B63;
    color: #fff;
    border-radius: 50px;
    text-align: center;
}
.challenge dd{
    width: 100%;
    margin-bottom: 1em;
}

.list-green li{
  position: relative;
  padding-left: 1.5em;
}
 
.list-green li:before {
  content: "";
  position: absolute;
  top: .4em;
  left: 0;
  width: 1em;
  height: 1em;
  background-color: #009B63;
  border-radius: 50%;
}
@media screen and (min-width: 768px){
    .challenge dt{
        width: 20%;
        margin-bottom: 1em;
    }
    .challenge dd{
        width: 75%;
        margin-bottom: 1em;
    }
}

.bb-green{
    padding-bottom: 50px;
    border-bottom: 10px solid #009B63;
}


.ttl-green{
    background-color: #009B63;
    color: #fff;
    padding: 0 0.5em;
}
.bb-gray {
    border-bottom: 10px solid #8B8C8C;
    padding-bottom: 10px;
}

.yakuin{
    font-size: 1.3rem;
    width: 100%;
}
.yakuin_s{
    font-size: 1.3rem;
}
.d-flex{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.flex-wrap{
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.justify-between{
    -moz-justify-content: space-between;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.justify-around{
    -ms-flex-pack: distribute;
    justify-content: space-around;
}
@media screen and (max-width: 767px){
    .profile .yakuin-dl dl {
        width: 100% !important;
    }
}
@media screen and (max-width: 1079px){
    .yakuin_s{
        font-size: 1.3rem;
        width: 100%;
    }
    .flex-wrap_s{
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
}
@media screen and (min-width:768px) and ( max-width:1079px) {
    #index_company .profile .yakuin-dl {
        flex-wrap: wrap;
    }
    #index_company .profile .yakuin-dl dd .flex.ajust {
        min-width: 200px;
    }
    .profile .yakuin-dl > dd {
        width: 40% !important;
    }
    .yakuin-dl-dd2{
        margin-left: 200px;
    }
}
@media screen and (min-width: 768px){
    .yakuin{
        font-size: 1.1rem;
    }
    #index_company .profile > dl > dt {
        width: 200px;
        min-width: 200px;
    }
    #index_company .profile > dl > dd {
        width: calc(100% - 200px);
    }
    #index_company .profile > dl dd .flex {
        justify-content: start;
        transform: initial;
    }
    #index_company .profile .yakuin-dl {
        padding-right: 0;
    }
    .yakuin-dl > dd{
        width: fit-content!important;
    }
    .d-flex_tb{
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
}
@media screen and (min-width: 1080px){
    #index_company .profile .yakuin-dl {
        -moz-justify-content: space-between;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
    .yakuin-dl > dt{
        flex: 280px;
    }
    .yakuin-dl-dd2{
        justify-content: right;
    }
    .yakuin{
        font-size: 1.3rem;
    }
    .d-flex_pc{
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
}

.color-green{
    color: #009B63;
}
.text-lll{
    font-size: 3rem;
    line-height: 2;
}

.text-ll{
    font-size: 2.5rem;
    line-height: 2;
}
.text-l{
    font-size: 2.0rem;
    line-height: 2;
}
.text-mm{
    font-size: 1.75rem;
    line-height: 2;
}
.text-m{
    font-size: 1.5rem;
    line-height: 2;
}
.text-s{
    font-size: 1.4rem;
    line-height: 2;
}
@media screen and (min-width: 768px){
    .text-lll{
        font-size: 3.5rem;
        line-height: 2;
    }

    .text-ll{
        font-size: 2.8rem;
        line-height: 2;
    }
    .text-l{
        font-size: 2rem;
        line-height: 2;
    }
    .text-mm{
        font-size: 1.8rem;
        line-height: 2;
    }
    .text-m{
        font-size: 1.6rem;
        line-height: 2;
    }
    .text-s{
        font-size: 1.5rem;
        line-height: 2;
    }
}
@media screen and (min-width: 1080px){
    .text-lll{
        font-size: 4rem;
        line-height: 2;
    }

    .text-ll{
        font-size: 3.2rem;
        line-height: 2;
    }
    .text-l{
        font-size: 2.4rem;
        line-height: 2;
    }
    .text-mm{
        font-size: 2rem;
        line-height: 2;
    }
    .text-m{
        font-size: 1.6rem;
        line-height: 2;
    }
    .text-s{
        font-size: 1.5rem;
        line-height: 2;
    }
}


.ttl-build{
    margin-bottom: 1em;
}
.ttl-build_en{
    background-color: #009B63;
    color: #fff;
    background-image: url(../../img/2023/sankaku_white.svg);
    background-repeat: no-repeat;
    background-position: right -1px top;
    padding: 5px 1.5em 5px 0.5em;
    font-size: 2rem;
}
.ttl-build_jp{
    padding: 5px 0.5em;
    font-size: 2rem;
}

.ttl-build:before{
    content: url(../../img/2023/billicon.svg);
    display: block;
    width: 100%;
    line-height: 0;
    max-width: 100px;
    margin-left: 30px;
}
.ttl-build_inner{
    border-top: 10px solid #009B63;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.service-box{
    border: 4px solid #009FE8;
    border-radius: 1em;
    padding: 1em;
}
.service-box_navy{
    border-color: #036EB7;
}
.service-box_orange{
    border-color: #F08A44;
}
.service-box_green{
    border-color: #508C57;
}
.service-box_4{
    border-color: #CD6100;
}
.service-box_6{
    border-color: #A72C48;
}
.service-box_kentiku{
    border-color: #00A37B;
}

.service-box + .service-box{
    margin-top: 1em;
}

.service-box-item + .service-box-item{
    margin-top: 5em;
}
.service-box-item > div:nth-child(1){
    width: 100px;
}
.service-box-item > div:nth-child(2){
    flex: 1;
}
.service-box-item > div:nth-child(3){
}
.kakko{
    padding: 0px 20px;
    border-radius: 10px/50%;
    border-style: solid;
    border-width: 0 1px;
    border-color: #000;
    display: inline-block
}
.kakko span{
    display: inline-block;
}
.business-bg_green{
    background-color: #E5F5EF;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 1em;
}


.flex-build > div:nth-child(1){
    width: 100px;
}
.flex-build > div:nth-child(2){
    flex: 1;
}
.flex-img{
}
@media screen and (min-width: 768px){
    .service-box{
        padding: 2em;
    }
    .service-box-item{
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -moz-justify-content: space-between;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
    .service-box-item > div:nth-child(2){
        flex: 1;
        margin: 0 1em;
    }
    .service-box-item > div:nth-child(3){
        width: 200px;
    }
    .flex-build{
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    .ttl-build_en{
        min-width: 40%;
    }
    .flex-build{
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    }
    .flex-item{
        margin-left: 1em;
    }
    .flex-img{
        width: 200px;
        margin-left: 1em;
    }
    .business-bg_green .list-green + .list-green{
        margin-left: 1em;
    }
}
@media screen and (min-width: 1080px){
    .service-box-item > div:nth-child(3){
        width: 300px;
    }
    .ttl-build_en{
        letter-spacing: 0.5em;
    }
}
.anchor-point{
    margin-top: -100px;
    padding-top: 100px;
}


.real-list{
    width: 100%;
}
.real-list_tr{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -moz-justify-content: space-between;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    border: 1px solid #854798;
    border-radius: 1em;
    margin-bottom: 1em;
    padding: 0.5em;
}
.real-list_ttl{
    width: 100%;
    color: #854798;
    text-align: center;
}
.real-list_txt{
    width: 100%;
    text-align: center;
}
@media screen and (min-width: 768px){
    .real-list{
        width: 100%;
    }
    .real-list_ttl{
        width: 25%;
    }
    .real-list_txt{
        width: 70%;
        text-align: left;
    }
}
@media screen and (min-width: 1080px){
    .real-list{
        width: 50%;
        margin-right: 1em;
    }
    .real-list_ttl{
        width: 25%;
    }
    .real-list_txt{
        width: 70%;
    }
}

.pdflink{
    background-color: #921F3C;
    color: #fff;
    padding: 0.5em 1em;
    border-radius: 5px;
}
.pdflink img{
    height: 2em;
}


.promote-bg_green{
    background-color: #E5F5EF;
    padding: 1em;
    border-radius: 1em 1em 0 0;
}

.swiper-slide img{
    object-fit: cover;
    width: 100%;
/*    height: 466px;*/
}
#firstview{
    position: relative;
}
#firstview h1{
    z-index: 100;
    text-align: center;
    color: #9B003A;
    padding: 5vw;
    width: 100%;

}
@media screen and (min-width: 768px){
    #firstview h1{
        position: absolute;
        top: 45%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
    }
}
@media screen and (min-width: 1080px){
    #firstview{
        margin-top: 60px;
    }
}

@media screen and (min-width: 1080px){
    #index_company .profile > dl {
        padding: 30px 0px;
    }
}
#index_company .profile{
    margin-top: 1em;
}
#index_company .profile > dl:first-child{
    border: none;
}





.index_iso_list dl{
    margin-bottom: 1em;
}
.index_iso_list dt{
    width: 200px;
}
.index_iso_list dt span{
    border-left: 5px solid green;
    padding-left: 10px;
}
.index_iso_list dd{
}
@media screen and (min-width: 1080px){
    .index_iso_list dl{
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
}

.promote-txt{
    margin-right: 1em;
}
.promote-bg_green div:first-child{
    flex: 1;
}
@media screen and (max-width: 767px){
    .promote-bg_green div:last-child{
        margin-top: 1em;
    }
}
@media screen and (min-width: 768px){
    .promote-bg_green div:last-child{
        width: 132px;
        margin-left: 1em;
    }
}





.company_guide-pdfwrap .d-flex_pc{
    margin-bottom: 3em;
}
@media screen and (min-width: 768px){
    #company_guide .flex-icon{
        max-width: 40%;
    }
}





.topbtn {
    position: fixed;
    right: 10px;
    bottom: 60px;
    width: 60px;
    height: 60px;
    z-index: 2;

  border-radius: 100%;
  padding: 16px;
  background: #931D3A;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
}
.topbtn::before {
  display: block;
  content: '';
  padding-top: 100%;
}
.topbtn span {
  display: inline-block;
  vertical-align: middle;
  color: #fff;
  line-height: 1;
  width: 1em;
  height: 1em;
  border: 3px solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  transform: translateY(25%) rotate(-45deg);
}
@media screen and (min-width: 1080px){
    .topbtn {
        bottom: 10px;
    }
}


#header .btn_area .btn_job{
  background-color: #159a65;
}
#header .btn_area .btn_job small,
#navigation small{
  font-size: 10px;
  line-height: 1;
  display: block;
}
#header .btn_area {
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
}
@media screen and (min-width: 1080px) {
  #header {
    padding: 0px 320px 0px 20px;
  }
  #header .btn_area .btn_job {
    padding: 9px 25px;
  }
  .pc_none{
    display: none;
  }
}
@media screen and (min-width: 1080px) and (min-width: 1180px) {
  #header {
    padding: 0px 400px 0px 20px;
  }
}

@media screen and (max-width: 1079px) {
  #footer {
    margin-bottom: 40px;
  }
}

