@charset "utf-8";


/* 会社案内
-------------------------------*/



.sub_contents_wrapper {
    width: 90%;
    max-width: 1400px;
    margin: 50px auto;
}
.flow_content {
    display: flex;
    justify-content: space-between;
}
@media (max-width: 910px) {
    .sub_contents_wrapper {
        margin-top: 0;
    }

    .flow_content {
        display: block;
    }
}



/* サイドナビ　固定 */
.category_list_wrapper {
    width: 220px;
    min-width: 11.75rem;
    border-top: none;
}

.category_list_wrapper ul {
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 10rem;
}
.category_list_wrapper li a {
    display: flex;
    align-items: center;
    padding: 10px 0 10px 30px;
    font-size: 16px;
    line-height: 1.2;
    letter-spacing: 0;
    background-repeat: no-repeat;
    background-position: left center;
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
}
.category_list_wrapper li a:hover {
    opacity: 1;
    color: #0096fa;
}
.current {
    color: #0096fa;
    background-image: url(../img/company/maru.png);
    background-repeat: no-repeat;
    background-position: left center;
}
@media (max-width: 910px) {
    .category_list_wrapper {
        display: none;
    }
}



/* コンテンツ */
.sl_main {
    width: calc(100% - 220px);
}
.sl_main ._in{
}
.sl_cont{
    padding: 0;
    padding-top: 120px;/* 調整したい高さ（固定ヘッダーの高さ） */
    margin-top: -120px;/* heightと同じ分のネガティブマージン */
    width: 100%;
    margin-bottom: 130px;
}
.sl_main .sl_cont:last-child{
    margin-bottom: 0;
}

@media (max-width: 910px) {
    .sl_main {
        width: 100%;
    }
}
@media screen and (max-width:640px){
    .sl_cont{
        margin-bottom: 80px;
    }
}







/* メッセージ */
.page_title.bg_company{
    margin-bottom: 0;
}
.com_bg_img{
    padding-top: 150px;
    background: url(../img/company/com_img01.png) center top no-repeat;
}
.com01_box{
    padding-left: 40px;
}

.com01_box .ttl1{
    font-size: 32px;
    line-height: 1.3em;
    font-weight: 500;
    margin-bottom: 20px;
}
.com01_box .ttl2{
    font-size: 21px;
    line-height: 1.2em;
    color: #0096fa;
    font-weight: 700;
    margin-bottom: 30px;
}
.com01_box p{
    font-family: "Noto Serif JP", serif;
    font-weight:500;
    line-height: 2.5em;
}
@media screen and (max-width:1800px){
    .com_bg_img{
        padding-top: 7.8vw;
    }
}
@media screen and (max-width:1300px){
    .com01_box{
        padding-left: 0;
    }
}
@media screen and (max-width:910px){
    .com_bg_img{
        background-position:90% top;
        background-size: 200% auto;
    }
}
@media screen and (max-width:640px){
    .com01_box .ttl1{
        font-size: 26px;
        line-height: 1.3em;
    }
    .com01_box .ttl2{
        font-size: 16px;
        line-height: 1.2em;
        color: #0096fa;
    }
    .com01_box p br.sp{
        display: none;
    }
}
@media screen and (max-width:480px){
    .com01_box .ttl1{
        font-size: 5.4vw;
        line-height: 1.3em;
    }
}







/* 会社概要 */

/* 背景の白 */
.bg_w_1{
    width: 100%;
    height: 1px;
    position: relative;
    z-index: 0;
}
.bg_w_1:after{
    position: absolute;
    top: -50px;
    right: 0;
    z-index: 0;
    width: calc(100% + 50px);
    height: 1900px;
    background-color: #fff;
    border-radius: 20px 0 0 20px;
    content: "";
}
.bg_w_1:before{
    position: absolute;
    top: -50px;
    left: 480px;
    z-index: 0;
    width: 49.4vw;
    height: 1900px;
    background-color: #fff;
    content: "";
}
@media screen and (max-width:1570px){
    .bg_w_1:before{
        left: 50%;
        width: calc(50% + 4.8vw);
    }
}
@media screen and (max-width:1350px){
    .bg_w_1:before{
        left: 50%;
        width: calc(50% + 4.8vw);
    }
    .bg_w_1:after{
        height: 1950px;
    }
    .bg_w_1:before{
        height: 1950px;
    }
}
@media screen and (max-width:1280px){
    .bg_w_1:after{
        height: 1800px;
    }
    .bg_w_1:before{
        height: 1800px;
    }
}
@media screen and (max-width:1200px){
    .bg_w_1{
        display: none;
    }
}
@media screen and (max-width:910px){
    .bg_w_1{
        display: none;
    }
}
@media print{
    .bg_w_1{
        display: none;
    }
}


.com02{
    position: relative;
    z-index: 3;
}
.com02 .ttl01{
    border-bottom: solid 1px #ccc;
    padding-bottom: 20px;
}
.com02_box{
    width: 100%;
    padding-left: 40px;
    display: flex;
    flex-flow: row-reverse;
    justify-content: space-between;
}
.com02_box .txt{
    width: 60%;
}
.gaiyou{
    width: 100%;
}
.gaiyou th{
    width: 130px;
    color: #0096fa;
    vertical-align: top;
    padding-bottom: 30px;
}
.gaiyou td{
    vertical-align: top;
    padding-bottom: 30px;
    font-family: "Noto Serif JP", serif;
    font-weight:500;
}
.com02_box .img{
    width: 34%;
}
.com02_box .img li:first-child{
    margin-bottom: 40px;
}
.com02_box .img img{
    border-radius: 10px;
}

@media screen and (max-width:1300px){
    .com02_box{
        padding-left: 0;
    }
    .gaiyou th{
        padding-bottom: 20px;
    }
    .gaiyou td{
        padding-bottom: 20px;
    }
    
}
@media screen and (max-width:1200px){
    .com02_box{
        display: block;
    }
    .com02_box .txt{
        width: 100%;
    }
    .gaiyou{
        width: 100%;
    }
    .gaiyou th{
        padding-bottom: 30px;
    }
    .gaiyou td{
        padding-bottom: 30px;
    }
    .com02_box .img{
        width: 100%;
    }
    .com02_box .img ul{
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .com02_box .img li{
        width: 48%;
    }
    .com02_box .img li:first-child{
        margin-bottom: 0;
    }
}
@media screen and (max-width:640px){

    .gaiyou tr{
        border-bottom: dashed 1px #ccc;
    }
    .gaiyou th{
        display: inline-block;
        width: 100%;
        padding-top: 10px;
        padding-bottom: 0;
    }
    .gaiyou td{
        display: inline-block;
        width: 100%;
        padding-bottom: 10px;
    }
    .com02_box .img{
        margin-top: 30px;
    }

}
@media screen and (max-width:420px){
    
    .com02_box .img li{
        width: 100%;
        text-align: center;
    }
    .com02_box .img li:first-child{
        margin-bottom: 20px;
    }
    
}






/* 会社沿革 */
.com03{
    position: relative;
    z-index: 3;
}
.com03 .ttl01{
    border-bottom: solid 1px #ccc;
    padding-bottom: 20px;
}
.enkaku{
    width: 100%;
}
.enkaku th{
    width: 150px;
    font-family: "Inter", sans-serif;
    font-style: normal;
    font-weight: 700;
    color: rgba(0,136,241,0.5);
    font-size: 40px;
    line-height: 1.2em;
    vertical-align: middle;
    padding-left: 20px;
    padding-top: 10px;
    padding-bottom: 10px;
}
.enkaku th span{
    display: inline-block;
    text-align: center;
    width: 0.65em;
}
.enkaku td.ym{
    width: 170px;
    padding-left: 30px;
    background: url(../img/company/maru.png) left center no-repeat;
    vertical-align: middle;
}
.enkaku td.cap{
    font-family: "Noto Serif JP", serif;
    font-weight:500;
}

@media screen and (max-width:910px){

    .enkaku th{
        width: 120px;
        font-size: 40px;
        line-height: 1.2em;
        padding-left: 0;
    }
    .enkaku td.ym{
        width: 140px;
        padding-left: 20px;

    }
}
@media screen and (max-width:640px){
    .enkaku tr{
        border-bottom: solid 1px #ccc;
    }
    .enkaku th{
        display: inline-block;
        width: 100px;
        font-size: 30px;
        line-height: 1.2em;
        padding-left: 0;
        padding-bottom: 5px;
    }
    .enkaku td.ym{
        display: inline-block;
        width: auto;
        padding-left: 30px;
        padding-bottom: 5px;

    }
    .enkaku td.cap{
        display: inline-block;
        width: 100%;
        padding-bottom: 20px;

    }




}









/* 品質方針 */
.com04 .ttl01{
    border-bottom: solid 1px #ccc;
    padding-bottom: 20px;
}
.com04 ._in{
    width: 100%;
    max-width: 1120px;
    padding-left: 40px;
}

.com04_box{
    margin-top: 50px;
    margin-bottom: 50px;
    background-color: #fff;
    border-radius: 20px;
    padding: 30px 50px;
}
.com04_box li{
    font-size: 20px;
    line-height: 1.4em;
    font-weight: 500;
    padding-left: 0;
    padding-top: 15px;
    padding-bottom: 15px;
    text-indent: -1em;
    margin-left: 1em;
}
/*
.com04_box li.num1{
    background-image: url(../img/company/maru1.png);
}
.com04_box li.num2{
    background-image: url(../img/company/maru2.png);
}
.com04_box li.num3{
    background-image: url(../img/company/maru3.png);
}
.com04_box li.num4{
    background-image: url(../img/company/maru4.png);
}
.com04_box li.num5{
    background-image: url(../img/company/maru5.png);
}
*/
@media screen and (max-width:1450px){
    .com04 ._in br.sp{
        display: none;
    }
}
@media screen and (max-width:1300px){
    .com04 ._in{
        padding-left: 0;
    }
}
@media screen and (max-width:910px){
    .com04_box{
        margin-top: 30px;
        margin-bottom: 30px;
        padding: 20px 30px;
    }
    .com04_box li{
        font-size: 18px;
        line-height: 1.4em;
        padding-top: 10px;
        padding-bottom: 10px;
    }

}
@media screen and (max-width:640px){

    .com04_box{
        margin-top: 20px;
        margin-bottom: 20px;
        padding: 20px;
    }
    .com04_box li{
        font-size: 15px;
        line-height: 1.4em;
    }

    
    
}





/* SDGsへの取り組み */
.com05 .ttl01{
    border-bottom: solid 1px #ccc;
    padding-bottom: 20px;
    margin-bottom: 0;
}
.com05_box{
    width: 100%;
    max-width: 1080px;
    padding-left: 40px;
    display: flex;
    justify-content: space-between;
    flex-flow: row-reverse;
    align-items: center;
    margin-top: 50px;
}
.com05_box .txt{
    width: 47%;
}
.com05_box .txt dt{
    font-size: 28px;
    line-height: 1.3em;
    font-weight: 500;
    margin-bottom: 20px;
}
.com05_box .txt dd{
    font-family: "Noto Serif JP", serif;
    font-weight:500;
}
.com05_box .img{
    width: 48%;
    max-width: 450px;
    background-color: #fff;
    border-radius: 20px;
    padding: 40px 35px;
    text-align: center;
}
.com05_sub_ttl{
    margin-top: 80px;
    width: 100%;
    padding-left: 40px;
    font-size: 32px;
    line-height: 1.3em;
    font-weight: 500;
    display: flex;
    align-items: center;
}
.com05_sub_ttl span{
    display: inline-block;
    width: auto;
    height: 1px;
    border-bottom: solid 1px #0096fa;
    margin-left: 10px;
    flex-grow: 1;
}

@media screen and (max-width:1300px){
    .com05_box{
        padding-left: 0;
    }
    .com05_sub_ttl{
        padding-left: 0;
        font-size: 32px;
    }
}

@media screen and (max-width:910px){
    .com05_box{
        margin-top: 40px;
    }
    .com05_box .txt dt{
        font-size: 20px;
        line-height: 1.3em;
    }
    .com05_sub_ttl{
        margin-top: 50px;
        font-size: 20px;
        line-height: 1.3em;
    }

}
@media screen and (max-width:640px){

    .com05_box{
        display: block;
        margin-top: 30px;
    }
    .com05_box .txt{
        width: 100%;
        margin-bottom: 10px;
    }
    .com05_box .txt dt{
        font-size: 18px;
        line-height: 1.3em;
        margin-bottom: 10px;
    }
    .com05_box .img{
        width: 100%;
        border-radius: 10px;
        padding: 30px 30px;
    }

}




/* アクセス */

.com06 .ttl01{
    border-bottom: solid 1px #ccc;
    padding-bottom: 20px;
    margin-bottom: 0;
}

.base_box{
    width: 100%;
    max-width: 1080px;
    align-items: flex-end;
    padding-top: 80px;
    padding-bottom: 80px;
    border-bottom: solid 1px #ccc;
}

.base_box .txt{
    width: 48%;
}
.base_box .txt dl{
    width: 100%;
    min-height: 250px;
}
.base_box .txt dt{
    padding-left: 20px;
    font-size: 32px;
    line-height: 1.2em;
    font-weight: 500;
    color: #0096fa;
    border-bottom: solid 1px #ccc;
    padding-bottom: 10px;
    margin-bottom: 20px;
}
.base_box .txt dd{
    font-family: "Noto Serif JP", serif;
    font-weight:500;
    margin-left: 20px;
}
.base_box .txt .gaikan img{
    border-radius: 20px;
}
.base_box .g-map{
    width: 48%;
    position: relative;
    height: 0;
    padding-top: 610px;/* 高さ */
}
.base_box .g-map iframe{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.article .content:last-child {
    margin-bottom: 10px;
}

@media (min-width:911px) and (max-width:1300px){
    .base_box .txt dl{
        min-height: 19vw;
    }
    .base_box .txt dt{
        font-size: 2.4vw;
        line-height: 1.2em;
    }
    .base_box .g-map{
        padding-top: 46vw;/* 高さ */
    }

}
@media screen and (max-width:910px){
    .base_box{
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .base_box .txt dt{
        font-size: 26px;
        line-height: 1.2em;
    }
    .base_box .g-map{
        padding-top: 67vw;/* 高さ */
    }
}
@media screen and (max-width:640px){
    .base_box{
        padding-top: 30px;
        padding-bottom: 30px;
    }

    .base_box .txt{
        width: 100%;
    }
    .base_box .txt dl{
        min-height: initial;
        min-height: auto;
        margin-bottom: 20px;
    }
    .base_box .txt dt{
        font-size: 20px;
        line-height: 1.2em;
        padding-left: 0;
        border-bottom: none;
        padding-bottom: 0;
    }
    .base_box .txt dd{
        margin-left: 0;
    }
    .base_box .txt .gaikan img{
        border-radius: 10px;
    }
    .base_box .g-map{
        margin-top: 20px;
        width: 100%;
        padding-top: 60vw;/* 高さ */
    }
    
    
}


