/* CSS Document */
/********************
.about,profile
********************/
.about > .inner,
.profile > .inner{
    width: 100%;
}
.about .sectiontitle span{
    display: inline;
}
.about .about_img img,
.profile .profile_img img{
    width: 100%;
}
.about .about_img,
.profile .profile_img{
    width: 90%;
    transform: translateY(2em);
    position: relative;
    z-index: 2!important;
}
.profile .profile_img{
    margin-left: auto;
}
.about .about_caption,
.profile .profile_caption{
    padding: 4em 0 2em;
    background: #F7F7F7;
}
.company_caption {
    width: 90%;
    max-width: 1280px;
    margin: 80px auto 40px;
    display: flex;
    flex-direction: column;
}
.company_caption p:not(:last-of-type){
    margin-bottom: 1em;
}
.company_caption h3{
    margin-top: 2em;
}
.president .president_img{
    width: 100%;
    text-align: center;
    margin-bottom: 1em;
}
.president .president_cap p:not(:last-of-type){
    margin-bottom: 1em;
}
.president .president_cap p.name{
    text-align: right;
}
.president .president_cap p.name span{
    font-size: 170%;
    font-weight: bold;
    margin-left: 1em;
}
.map{
    padding-top: 0;
}
.map .map_box{
    position: relative;
    padding-top: 100%;
}
.map .map_box iframe{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
@media screen and (min-width:768px){
    .about .about_box,
    .profile .profile_box{
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
                flex-wrap: wrap;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
        -webkit-justify-content: space-between;
                justify-content: space-between;
        -webkit-align-items: stretch;
                align-items: stretch;
        -webkit-align-content: center;
                align-content: center;
    }
    .about .about_img,
    .profile .profile_img{
        width: 60%;
        transform: translate(0);
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
                flex-wrap: wrap;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
        -webkit-justify-content: center;
                justify-content: center;
        -webkit-align-items: center;
                align-items: center;
        -webkit-align-content: center;
                align-content: center;
    }
    .about .about_img img,
    .profile .profile_img img{
        height: 80%;
    }
    .about .about_caption,
    .profile .profile_caption{
        width: 50%;
        padding: 10% 0 10% 10%;
        margin-left: -10%;
    }
    .profile .profile_img{
        margin-left: -10%;
    }
    .profile .profile_caption{
        padding: 10% 10% 10% 0%;
        margin-left: 0;
        order: 1;
    }
    .profile .profile_img{
        order: 2;
    }
    .about > .inner,
    .profile > .inner{
        max-width: 100%;
    }
    .president .president_box.flex{
        align-items: stretch;
    }
    .president .president_img{
        width: 40%;
    }
    .president .president_cap{
        width: 58%;
    }
    .map .map_box{
        padding-top: 56.25%;
    }
    .company_caption {
        flex-direction: row;
        align-items: center;
        gap: 40px;
    }
}
@media screen and (min-width:1280px){
/********************
.about,profile
********************/
    .about > .inner,
    .profile > .inner{
        width: 100%;
    }
    .about .sectiontitle span{
        display: inline;
    }
    .profile .profile_img{
    }
    .about .about_caption,
    .profile .profile_caption{
        /*padding: 4em 0 2em;*/
        background: #F7F7F7;
    }
}

.recruit_list {
    width: 100%;
}
.recruit_list div{
    padding: 1em;
    border-bottom: 1px solid #f0f0f0;
}
.recruit_list dt{
    width: 100%;
    font-weight: bold;
}
.recruit_list dd{
    padding-left: 1em;
    text-align: left;
    width: 100%;
}
@media screen and (min-width:1280px){
.recruit_list {
    max-width: 800px;
    width: 100%;
    margin: auto;
}
.recruit_list dt{
    width: 30%;
}
.recruit_list dd{
    width: 70%;
    text-align: left;
}
}
