.sub-container .txt_blue_small, 
.sub-bnr-container .txt_blue_small {
    font-family: "Poppins", sans-serif;
    font-size: 2.0rem;
    line-height: 2.7rem;
    font-weight: 600;
    color: #4769FD;
}
.sub-container .txt_black_small {
    font-size: 2.2rem;
    line-height: 3.2rem;
    font-weight: 500;
    color: #2D3545;
}
.sub-container h3{
    font-size:50px;
    line-height: 68px;
    color:#2D3545;
    font-weight: 700;
}

/* company-container */
.company-container .sub-bnr-container .sub-img-bnr {
    /*background: url(../img/sub_bg_about.jpg) no-repeat center / cover;*/
}

.company-info {
    /*margin-bottom: 17rem;*/
}
.company-top {
    height: 100vh;
    background: url(../img/sub/bizmap_top_img.png) no-repeat center center / cover;
    text-align: center;
    display: flex;
    align-items: center;
}
.company-top-txt {
    padding-top: 4vw;
}
.company-top-txt .main-txt{
    font-size:40px;
    font-weight: 600;
    line-height: 75px;
    color:#fff;
    margin-bottom: 40px;
}
.company-top-txt > p img {width:561px;}
.company-top-txt .sub-txt{
    font-size:24px;
    font-weight: 500;
    line-height: 38px;
    color:#fff;
    margin-top: 122px;
}
/*
.company-info-contents {
    display: flex;
}
*/
.contents-tit {
    max-width: 1060px;
}

.contents-tit .tit-align {
    font-family: "Poppins", sans-serif;
    font-size: 94px;
    font-weight: 600;
    line-height: 120px;
    letter-spacing: -3px;
    color:#D9D9D9;
    margin: 116px 0 65px;
    
}
.contents-tit .tit-align div:nth-child(1) {
    float: left;
}
.contents-tit .tit-align div:nth-child(2) {
    float: right;
}
.contents-tit .tit-align:after {
    content: "";
    display: block;
    clear: both;
}

.company-info-text {padding-bottom: 71px;}
.company-info-text li {
    position: relative;
    padding-left:96px;
    margin-bottom: 38px;
    font-size: 20px;
    line-height: 32px;
    color:#2E3545;
}
.company-info-text li:before{
    content: "";
    display: block;
    width:44px;
    height: 18px;
    background-repeat: no-repeat;
    background-position: left top;
    position: absolute;
    left:0;
    top:-3px;
}

.company-info-text li:nth-child(1):before{background-image:url(../img/sub/icon_text01.svg);}
.company-info-text li:nth-child(2):before{background-image:url(../img/sub/icon_text02.svg);}
.company-info-text li:nth-child(3):before{background-image:url(../img/sub/icon_text03.svg);}


.metrics-wrap {
    background-color:#F8FAFD; 
    padding:140px 0 80px;
}
.metrics-wrap .txt_blue_small {margin-bottom: 30px;text-align: center;}
.metrics-wrap h3 {margin-bottom: 55px; text-align: center;}
.metrics-wrap .txt_black_small {margin-bottom: 100px; text-align: center;}
.metrics-wrap .count-list{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}


.metrics-wrap .count-list li {width: 44%; text-align: center; padding-right: 0; margin-bottom: 80px;}

.metrics-wrap .count-list li:first-child {margin-right: 0;}
.metrics-wrap .count-list li .count {font-size:158px; line-height: 116px;}
.metrics-wrap .count-list li div:first-child {display: inline-block; position: relative; padding-right: 62px;}
.metrics-wrap .count-list li:nth-child(1) .c-blue {width:296px;}
.metrics-wrap .count-list li:nth-child(2) .c-blue {width:342px;}
.metrics-wrap .count-list li:nth-child(3) .c-blue {width:210px;}
.metrics-wrap .count-list li:nth-child(4) .c-blue {width:130px;}
.metrics-wrap .count-list li span:nth-child(2){
  background:url(../img/icon_plus_blue.png) no-repeat center center / cover;
}

.metrics-wrap .count-list .info-txt-01 {
    font-size:24px;
    line-height: 38px;
    color:#000;
    font-weight: 500;
    margin-top: 30px;
}
.metrics-wrap .count-list .info-txt-02 {
    font-size:16px;
    line-height: 24px;
    color:#B4B4B4;
    font-weight: 500;
    margin-top: 6px;
}

.company_solution {
    background-color:#272727;
}
.company_solution li {
    display: flex;
    height: 444px;
    color:#fff;
    font-size:24px;
    font-weight: 500;
    line-height: 29px;
}
.company_solution li > div {
    width:50%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    display: flex;
    align-items: flex-end;
    padding : 20px;
    text-align: left;
}
.solution_bg_01 {background-image: url(../img/sub/bizmap_section4_img01.png);}
.solution_bg_02 {background-image: url(../img/sub/bizmap_section4_img02.png);}
.solution_bg_03 {background-image: url(../img/sub/bizmap_section4_img03.png);}

.company_solution li .solution_point_txt {
    align-items: center;
    justify-content: center;
}
.company_solution li .solution_point_txt h3{
    color:#fff;
}
.company_solution li:nth-child(2) > div:nth-child(1) {justify-content: right;}
.company_solution li:nth-child(2) > div:nth-child(2) {padding-right: 10vw;}



.company_history {padding:170px 0 107px;}
.company_history .flex-container {justify-content: space-between;}
.company_history_left {max-width:536px;} 
.company_history_left h3 {
    font-size: 44px; 
    line-height: 56px;
    margin-top: 32px;
}
.company_history_right {
    width:calc(100% - 536px);
    padding-top:60px;
}
.history-process li {
    font-size: 20px;
    line-height: 28px;
    color:#2D3545;
    font-weight: 600;
    margin-bottom: 32px;
    position: relative;
    padding: 14px 0 14px 206px;
}
.history-process li span.hs_date {
    font-family: "Poppins", sans-serif;
    position: absolute;
    left:0;
    top:15px;
    width:206px;
    color:#4769FD;
    font-size:40px;
    font-weight: 600;
    padding-left:25px;
}
.history-process li:before {
    content: "";
    display: block;
    position: absolute;
    width: 8px;
    height: 8px;
    left: 5px;
    top: 25px;
    background-color: #4769FD;
    border-radius: 5px;
}
.history-process li:after {
    content: "";
    display: block;
    position: absolute;
    width: 1px;
    left: 8px;
    top: 24px;
    background-color: #4769FD;
    height: 119px;
}
.history-process li:last-child:after {
    content: "";
    display: block;
    position: absolute;
    width: 0; height: 0;
    
}

.company_banner {
    width:100%;
    padding:60px;
    border-radius: 30px;
    color:#fff;
    background:#476AFD url(../img/sub/bizmap_section5_img01.png) no-repeat right 29px bottom;
}
.company_banner .txt_blue_small {
    color:#fff;
    margin-bottom: 20px;
}
.company_banner h3 {
    font-size:44px;
    line-height: 57px;
    letter-spacing: -2.2px;
    margin-bottom: 106px;
    color:#fff;
}
/* e::company-container */


/* business-container */

.business-top-wrap > img {width:100%;}
.business-top-wrap .flex-container {
    /*justify-content: space-between;*/
    padding:97px 0 127px;
}
.b-top-left {width:487px;}
.b-top-left  h3 {
    font-size:44px;
    line-height: 56px;
}
.b-top-right {
    font-size: 18px; 
    line-height: 30px;
    color:#2D3545;
}
.business-for-wrap { 
    background-color: #272727;
    padding : 100px 0 174px;
    color:#fff;
    text-align: center;
}

.business-for-wrap h3 {margin:32px 0 80px; color:#fff;}

.business-for-wrap ul {
    justify-content: center;
}

.business-for-wrap li {
    width:calc(33% - 40px);
    margin: 0 20px;
    max-width: 308px;
    text-align: left;
}
.business-for-wrap li > div {
    margin-top: 20px;
    text-align: center;
    
}

.business-process {
    background: url(../img/sub/business_section3_bg.png) no-repeat center center / cover;
    padding:100px 0 98px;
}
.business-process h3 {margin:30px 0 48px;}

.business-process ul {
    justify-content: center;
    align-items: end;
}
.business-process li {
    width:calc(25% - 16px);
    max-width: 308px;
    background-color: #476AFD;
    border-radius: 30px;
    margin: 0 8px;
    color:#fff;
    padding:30px;
}

.business-process li:nth-child(1) {height: 315px;}
.business-process li:nth-child(2) {height: 375px;}
.business-process li:nth-child(3) {height: 435px;}
.business-process li:nth-child(4) {height: 495px;}

.business-process li > p{
    font-size:18px;
    line-height: 25px;
    margin-bottom: 23px;
}
.business-process li > h4{
    font-size:34px;
    line-height: 40px;
    font-weight: 600;
    padding-bottom:38px;
    background: url(../img/sub/arrow01.svg) no-repeat right bottom;
}
.business-process li > div {
    font-size:20px;
    line-height: 26px;
    font-weight: 500;
    margin-top: 33px;
    letter-spacing: -0.5px;
}

.business-result {
    background-color: #476AFD;
    padding:100px 0 154px;
    color:#fff;
    text-align: center;
}
.business-result .txt_blue_small {color:#fff;}
.business-result h3 {color:#fff; margin: 32px 0 60px;}

.business-result ul {
    justify-content: center;
    align-items: flex-start;
}
.business-result li {
    width:calc(25% - 16px);
    max-width: 200px;
    aspect-ratio : 5 / 4;
    margin: 0 8px;
}

.business-result li .step_img {
    width:100%;
    height: min(160px, 100%);
    max-width: 200px;
    aspect-ratio : 5 / 4;
}
.business-result li .step_txt:before {
    content: "";
    display: block;
    width:50%;
    max-width: 44px;
    margin: 0 auto;
    padding-top: 50%;
    height:0;
    background: url(../img/sub/icon_check.svg) no-repeat center center / contain;
}
.business-result li:nth-child(1) .step_img {background: url(../img/sub/business_sec4_icon1.png) no-repeat center center / contain;}
.business-result li:nth-child(2) .step_img {background: url(../img/sub/business_sec4_icon2.png) no-repeat center center / contain;}
.business-result li:nth-child(3) .step_img {background: url(../img/sub/business_sec4_icon3.png) no-repeat center center / contain;}
.business-result li:nth-child(4) .step_img {background: url(../img/sub/business_sec4_icon4.png) no-repeat center center / contain;}


/* e::business-container */


@media (max-width: 1600px) {
    .company-container .inner {
        width: 95%;
        min-width: auto;
    }
    .greeting-container .inner {
        width: 95%;
        min-width: auto;
    }
    
    .company-info-text li.info-text-title {
        font-size: 2.6rem;
    }
    .company-info-text li.info-text-title span {
        font-size: 3.8rem;
    }
    .company-info-text li.info-text-sub-title {
        font-size: 2.4rem;
    }
    .company-info-text li {
        font-size: 1.8rem;
    }


    .greeting-info-contents {
        width: auto;
    }

    .greeting-info-text li {
        font-size: 1.8rem;
    }

    .greeting-info-right {
        padding-right: 10px;
    }

    .org-info-contents img {
        width: 100%;
    }
    .org-chart-director span {
        /*height: 5rem;*/
        font-size: 2.2rem;
    }
    .org-factory-name {
        font-size: 2.2rem;
    }
    /*
    .org-team-title {
        font-size:2.0rem;
        padding-bottom:0;
    }
    */
    /*
    .org-team-list li {
        font-size: 2.2rem;
        line-height: 3.0rem;
    }
    */
    /*
    .org-team-list li:before {
        padding: 0 10px;
    }
*/

}

@media (max-width: 1400px) {
    .location-info-list ul {
        max-height: 25.0rem;
    }
    .location-info-list li {width:50% !important;}
    .location-info-list .info-address {height: 11rem;}
    .location-info-list .info-name {padding-top: 6rem;}
    .location-info-list .info-mail {border-right: none;}
    .location-info-list .info-tel {border-right: none;}
}
@media (max-width: 1200px) {
    .company-container .inner {
        width: 95%;
        min-width: auto;
    }

}

@media (max-width: 1024px) {
    .company-top-txt .sub-txt {
        font-size: 20px;
        line-height: 32px;
    }
    .company-info-contents {
        flex-wrap: wrap;
    }

    .company-info-img {
        width: 100%;
    }

    .company-info-img img {
        display: block;
    }

    .company-info-left {
        width: 100%;
        margin-right: 0;
    }
    .company-info-text {
        margin-top:3rem;
    }

    .company-info-right {
        display: none;
    }
    
    .sub-container h3 {
        font-size: 38px;
        line-height: 50px;
    }
    .company_solution li {height: 316px; font-size: 20px;}
    
    .company_history_left {
        max-width: 320px;
    }
    .company_history_right { width: calc(100% - 370px);}
    
    .company_banner {background-size: 39%;}
    
    .business-process h3 {
        margin: 18px 0 26px;
    }
    
    .business-process li > h4 {
        font-size: 30px;
        line-height: 40px;
    }
    .business-process li > div {
        font-size: 18px;
        line-height: 26px;
    }
    
    .business-for-wrap li img {
        width:100%;
    }
}

@media (max-width: 1024px) {

    .metrics-wrap .count-list li .count {font-size: 136px; line-height: 99px;}
    .metrics-wrap .count-list li:nth-child(1) .c-blue {width:255px;}
    .metrics-wrap .count-list li:nth-child(2) .c-blue {width:297px;}
    .metrics-wrap .count-list li:nth-child(3) .c-blue {width:183px;}
    .metrics-wrap .count-list li:nth-child(4) .c-blue {width:118px;}
}


@media (max-width: 650px) {
    .sub04 {padding-top:12rem;}
    
    .sub-container h3 {
        font-size: 28px;
        line-height: 36px;
    }
    
    .sub-container .txt_black_small {
        font-size: 1.6rem;
        line-height: 2.2rem;
    }

    .company-top {
        padding: 110px 0 110px;
        height: auto;
    }
    .company-top-txt {
        padding-top: 0;
    }
    .company-top-txt > p img {width: 78%; }
    .company-top-txt .main-txt {
        font-size: 28px;
        line-height: 34px;
        margin-bottom: 30px;
    }
    .company-top-txt .sub-txt {
        font-size: 18px;
        line-height: 28px;
        margin-top: 82px;
    }
    
    .contents-tit .tit-align {
        font-size: 44px;
        line-height: 57px;
        margin: 80px 0 65px;
    }
    
    .company-info {
        margin-bottom: 6rem;
    }
    .company-info-text li {
        font-size: 1.6rem;
        line-height: 28px;
        padding-left: 70px;
    }
    .company-info-text li.info-text-title {
        font-size: 2.0rem;
    }
    .company-info-text li.info-text-title span {
        font-size: 2.4rem;
    }
    .company-info-text li.info-text-sub-title {
        font-size: 1.8rem;
    }
    
    .metrics-wrap { padding: 80px 0 80px; }
    .metrics-wrap .txt_black_small {
        margin-bottom: 72px;
    }
    .metrics-wrap .count-list li {
        width: 50%;
    }
    .metrics-wrap .count-list li .count {font-size: 74px; line-height: 55px;}
    .metrics-wrap .count-list li:nth-child(1) .c-blue {width:144px;}
    .metrics-wrap .count-list li:nth-child(2) .c-blue {width:169px;}
    .metrics-wrap .count-list li:nth-child(3) .c-blue {width:102px;}
    .metrics-wrap .count-list li:nth-child(4) .c-blue {width:70px;}
    
    .metrics-wrap .count-list li div:first-child {
        padding-right: 27px;
    }
    .metrics-wrap .count-list li:nth-child(2) div:first-child {
        padding-right: 44px;
    }
    .metrics-wrap .count-list .info-txt-01 {
        font-size: 16px;
        line-height: 22px;
    }
    .metrics-wrap .count-list .info-txt-02 {
        font-size: 12px;
        line-height: 14px;
    }
    
    

    .company_solution li { 
        flex-direction: column;
        height: auto;
    }
    .company_solution li:first-child { 
        flex-direction: column-reverse;
    }
    .company_solution li:last-child > div:first-child{ 
        display: none;
    }
    .company_solution li > div {
        width: 100%;
        height: 50vw;
        justify-content: center;
        text-align: center;
    }
    .solution_bg_01,
    .solution_bg_02,
    .solution_bg_03 {
        text-shadow: 0px 0px 4px #000;
    }
    .company_solution li:nth-child(2) > div:nth-child(1) {
        justify-content: center;
    }
    .company_solution li:nth-child(2) > div:nth-child(2) {
        padding-right: 20px;
    }
    
    .company_history {
        padding: 80px 0 80px;
    }
    .company_history .flex-container {
        flex-direction: column;
    }
    .company_history .flex-container > div {
        width:100%;
        max-width: 100%;
    }
    .history-process li {
        font-size: 16px;
        line-height: 24px;
        padding: 14px 0 14px 156px;
    }
    .history-process li span.hs_date {
        font-size: 28px;
    }
    .history-process li:after {
        height: 110px;
    }
        
    .company_banner {
        padding: 36px 30px;
        background-size: 49%;
        background-position: right 9px bottom;
    }
    .company_banner h3 {
        letter-spacing: -0.8px;
        margin-bottom: 54px;
        font-size: 24px;
        line-height: 32px;
    }
    .sub-container .txt_blue_small, .sub-bnr-container .txt_blue_small {
        font-size: 1.6rem;
        line-height: 2.0rem;
    }
    
    .b-top-right {
        font-size: 16px;
        line-height: 26px;
    }
    .b-top-right br {
        display: none;
    }
    
    .business-top-wrap > img {
        object-fit: cover;
        object-position: center center;
        width: auto;
        height: 50vw;
    }
    
    .business-top-wrap .flex-container {
        width: 80%;
        padding: 70px 0 70px;
    }
    .business-top-wrap .flex-container > div:first-child {
        margin-bottom: 7vw;
    }
    
    .business-for-wrap {
        padding: 80px 0 84px;
    }
    .business-for-wrap h3 {
        margin: 10px 0 60px;
    }
    .business-for-wrap li {
        width: 100%;
        max-width: none;
        display: flex;
        margin-bottom: 20px;
    }
    .business-for-wrap li img {
        width:30%;
        aspect-ratio: 1 / 1; 
    }
    .business-for-wrap li > div {
        text-align: left;
        margin: 3.5% 0 0 20px;
        font-size: 16px;
        line-height: 22px;
    }
    
    .business-process {
        padding: 80px 0 30px;
    }
    .business-process h3 {
        margin: 20px 0 32px;
    }
    .business-process .inner > p {
        margin-bottom: 30px;
        letter-spacing: -0.8px;
    }
        
    .business-process li {
        width: calc(50% - 16px);
        margin-bottom: 50px;
        padding: 22px;
    }
    .business-process li > p {
        font-size: 14px;
        line-height: 18px;
        margin-bottom: 10px;
    }
    .business-process li > h4 {
        font-size: 20px;
        line-height: 30px;
        background-size: 100%;
        padding-bottom: 25px;
    }
    .business-process li > div {
        font-size: 14px;
        line-height: 20px;
    }
    .business-process li > div br {
        display: none;
    }
    
    .business-process li:nth-child(1),
    .business-process li:nth-child(2),
    .business-process li:nth-child(3),
    .business-process li:nth-child(4) {
        height: 290px;
    }
    
    .business-result {
        padding:80px 0 80px;
    }
    .business-result li {
        width: calc(46% - 30px);
        margin: 0 15px 40px;
    }
    .business-result li .step_txt:before {
        max-width: 32px;
    }
    
    .step_txt {
        font-size: 16px;
    }
    
}

