@charset "utf-8";
/* basic
----------------------------------------------------------- */
/* color
----------------------------------------------------------- */
/* name
----------------------------------------------------------- */
.name {
    font-size: 1.8rem;
}
@media print, screen and (min-width: 768px) {
    .name {
        font-size: 2.2rem;
    }
}
/* box
----------------------------------------------------------- */
.areaBox {
    padding: 1em 4%;
    background-color: #fff;
}
@media print, screen and (min-width: 768px) {
    .areaBox {
        padding: 1.5em 50px;
    }
}
/* table
----------------------------------------------------------- */
/* factory --------------- */
.areaFigFactory {
    background-color: rgba(255, 255, 255, 0.1);
    padding: 25px 15px 15px;
    text-align: center;
}
.imgFlow {
    margin-bottom: 1em;
}
.ttlFlowSub { /* h3 factory */
    position: relative;
    font-size: 1.7rem;
    margin-bottom: 0.8em;
    padding-left: 20px;
    letter-spacing: 0.1em;
}
.ttlFlowSub:before { /* h3 factory */
    position: absolute;
    top: 6px;
    left: 0;
    width: 13px;
    height: 13px;
    background-color: #E15D71;
    content: "";
}
@media print, screen and (min-width: 768px) {
    .areaFigFactory {
        width: 500px;
        margin-right: auto;
        margin-left: auto;
    }
    .areaFlowInner {
        margin-left: 38px;
    }
    .areaFlow {
        position: relative;
    }
    .areaFlow::before {
        position: absolute;
        top: 20px;
        left: 6px;
        width: 1px;
        height: 100%;
        background-color: #545454;
        content: "";
    }
    .areaImgFlow {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        -webkit-flex-wrap: wrap;
        -moz-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        -o-flex-wrap: wrap;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .ttlFlowSub { /* h3 factory */
        font-size: 2.4rem;
        margin-bottom: 1em;
        padding-left: 38px;
    }
    .ttlFlowSub:before { /* h3 factory */
        top: 12px;
    }
    .imgFlow {
        width: calc((100% - 30px) / 2);
        margin-bottom: 30px;
    }
}
/* Greeting --------------- */
.ttlGreeting {
    margin-bottom: 1em;
    font-size: 2.0rem;
}
.presidentName {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: flex-end;
    -ms-align-items: center;
    align-items: center;
}
.presidentName dt {
    width: 8em;
}
.presidentName dd {
    font-size: 1.9rem;
}
.presidentName dd span {
    letter-spacing: 0.5em;
}
@media print, screen and (min-width: 768px) {
    .areaGreeting {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        justify-content: space-between;
    }
    .ttlGreeting {
        font-size: 2.8rem;
    }
    .presidentName dd {
        font-size: 2.4rem;
    }
}
/* company --------------- */
.mgBTblCompany {
    margin-bottom: 2em;
}
.tblBasic th {
    display: block;
    background-color: #333;
    padding: 0.5em 0.8em;
    text-align: left;
}
.tblBasic td {
    display: block;
    padding: 0.6em 0.8em 1.2em 0.1em;
}
.tblBasic li:not(:last-child) {
    margin-bottom: 0.5em;
}
.listBuilding li {
    margin-bottom: 0.3em;
}
.listBuilding span {
    display: inline-block;
    width: 12em;
}
.img2colCompany li {
    margin-bottom: 1em;
}
.ttlOverview-Plan {
    font-size: clamp(1.70rem, 1.17vw + 1.28rem, 2.40rem);  
}
@media print, screen and (min-width: 768px) {
    .mgBTblCompany {
        margin-bottom: 4em;
    }
    .tblBasic {
        border-bottom: 1px solid #333;
    }
    .tblBasic th {
        display: table-cell;
        width: 30%;
        border-bottom: 1px solid #1a1a1a;
        padding: 1.2em 4em;
    }
    .tblBasic tr:first-of-type th {
        border-top: 1px solid #333;
    }
    .tblBasic tr:last-of-type th {
        border-bottom: 1px solid #333;
    }
    .tblBasic td {
        display: table-cell;
        width: 70%;
        border-top: 1px solid #333;
        padding: 1.2em 4em;
    }
    .listBuilding li {
        margin-bottom: 0.5em;
    }
    .listBuilding span {
        width: 13em;
    }
    .img2colCompany {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        -webkit-flex-wrap: wrap;
        -moz-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        -o-flex-wrap: wrap;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .img2colCompany li {
        width: calc((100% - 16px) / 2);
        /*width: calc(100% / 2);
        margin-bottom: 0;*/
    }
}
/* philosophy --------------- */
.areaPhilosophy {
    position: relative;
    width: 99.5%;
    padding: 2.8em 7% 0.5em;
    z-index: 0;
}
.areaPhilosophy::before, .areaPhilosophy::after {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
}
.areaPhilosophy::before {
    background-color: rgba(255, 255, 255, 0.02);
    border: 1px solid #333;
    bottom: 0;
    right: 0;
    z-index: -2;
}
.areaPhilosophy::after {
    background-color: rgba(255, 255, 255, 0.02);
    border: 1px solid #555; /*右枠線*/
    bottom: -8px;
    right: -8px;
    z-index: -1;
}
.listPhilosophy {
    padding-left: 2.3em;
    text-indent: -2.3em;
}
.listPhilosophy li {
    margin-bottom: 1.5em;
    font-size: 1.7rem;
    line-height: 1.6;
}
@media print, screen and (min-width: 768px) {
    .areaPhilosophy {
        padding: 4em 5.5em 1em;
    }
    .listPhilosophy {
        padding-left: 2.8em;
        text-indent: -2.8em;
    }
    .listPhilosophy li {
        margin-bottom: 2em;
        font-size: 2.2rem;
    }
}
/* accessmap --------------- */
.googlemap {
    width: 100%;
    height: 400px;
    border: 0;
    margin-bottom: 15px;
}
@media print, screen and (min-width: 768px) {
    .googlemap {
        height: 500px;
    }
}
/* recruit ------------------------------ */
.areaRecruitTop {
    text-align: center;
    font-size: 1.6rem;
    line-height: 2.0;
}
.h1Catch {
    margin-bottom: 1em;
    font-size: 2.2rem;
    line-height: 1.5;
    z-index: 100 !important;
}
.txtCatch {
    line-height: 2.0;
}
.areaRecruitTop span {
    display: inline-block;
}
.areaRecruitTopImg {
    position: relative;
    width: 100%;
    background: url("../../recruit/images/img_recruit_top.jpg") no-repeat center center/cover;
    padding-top: 57.8125%;
}
.areaRecruitMenu {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -o-flex-wrap: wrap;
    flex-wrap: wrap;
}
.areaRecruitMenu a {
    display: block;
    width: calc((100% - 7%) / 2);
}
.areaRecruitMenu a:hover {
    opacity: 0.6;
}
a .recruitMenuCard {
    position: relative;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    padding-top: 100%;
}
.areaRecruitMenu a:not(:last-of-type) {
    margin-bottom: 3em;
}
a .recruitMenuCard.menu01 {
    background-image: url("../../recruit/images/bg_menu_01.jpg");
}
a .recruitMenuCard.menu02 {
    background-image: url("../../recruit/images/bg_menu_02.jpg");
}
a .recruitMenuCard.menu03 {
    background-image: url("../../recruit/images/bg_menu_03.jpg");
}
a .recruitMenuCard p {
    position: absolute;
    left: 20px;
    bottom: -20px;
    width: 100%;
    height: 80px;
    background-color: rgba(25, 128, 216, 0.95);
    padding-left: 1em;
    color: #fff;
    font-size: 1.8rem;
    line-height: 80px;
}
@media print, screen and (min-width: 600px) {
    .areaRecruitMenu a {
        width: calc((100% - 12%) / 3);
    }
}
@media print, screen and (min-width: 768px) {
    .areaRecruitTop {
        font-size: 1.7rem;
    }
    .h1Catch {
        font-size: 3.8rem;
    }
    .txtCatch {
        font-size: 1.7rem;
        line-height: 2.35;
    }
    .areaRecruitTopImgWrap {
        background-color: rgba(219, 238, 246, 0.75);
    }
    .areaRecruitTopImg {
        max-width: 1280px;
        height: 740px;
        margin: auto;
        padding-top: 0;
    }
    .areaRecruitMenu a {
        width: 300px;
    }
    a .recruitMenuCard p {
        left: 30px;
        bottom: -30px;
        width: 300px;
        height: 114px;
        padding-left: 1.5em;
        font-size: 2.6rem;
        line-height: 114px;
    }
}
/* recruit work ------------------------------ */
.areaWorkNavi {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    list-style: none;
}
.areaWorkNavi a {
    color: #1A1A1A;
}
.areaWorkNavi a:hover {
    opacity: 0.6;
}
.areaWorkNavi li a {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -ms-align-items: center;
    align-items: center;
}
.workNaviImg {
    width: 50px;
    margin-right: 10px;
}
.areaWorkNavi dt {
    font-size: 1.2rem;
}
.areaWorkNavi dd {
    font-size: 1.5rem;
}
.areaWorkProfile {
    margin-bottom: 4em;
}
.h2Work {
    margin-bottom: 0.2em;
    font-size: 1.9rem;
}
.areaProfile {
    display: inline-block;
    background-color: #F5F5F5;
    margin-top: 1em;
    padding: 1em 4%;
}
.profileName dt {
    font-size: 1.3rem;
}
.profileName dd {
    font-size: 1.8rem;
}
.areaSchedule {
    background-color: #F3F3F3;
    margin-bottom: 5em;
    padding: 1.5em 4% 1em;
}
.ttlSchedule {
    display: inline-block;
    position: relative;
    margin: 0 auto 1em;
    color: #1980D8;
    padding-left: 35px;
    font-size: 1.8rem;
}
.ttlSchedule::before {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    width: 25px;
    height: 25px;
    background: url("../../recruit/images/work/ic_schedule.svg") no-repeat left center;
    -webkit-background-size: 25px;
    background-size: 25px;
    content: "";
}
.txtSchedule {
    font-size: 1.4rem;
}
.txtSchedule dt {
    float: left;
    width: 4em;
    clear: left;
    color: #959595;
    font-weight: 600;
    text-align: right;
}
.txtSchedule dd {
    margin-bottom: 1em;
    margin-left: 5em;
    text-align: left;
}
.areaWorkMessageWrap {
    position: relative;
    background-color: rgba(219, 238, 246, 0.75);
    padding-bottom: 1.5em;
}
.areaWorkMessage {
    position: relative;
    padding-top: 73.39449%;
}
.imgMessage {
    position: absolute;
    top: -30px;
    width: 92%;
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    padding-top: 75.4716%;
}
.imgMessage.imgY {
    background-image: url("../../recruit/images/work/img_mes_y.jpg");
}
.imgMessage.imgS {
    background-image: url("../../recruit/images/work/img_mes_s.jpg");
}
@media print, screen and (min-width: 768px) {
    /* recruit work ------------------------------ */
    .areaWorkNavi {
        justify-content: flex-start;
    }
    .areaWorkNavi li:first-child {
        margin-right: 100px;
    }
    .workNaviImg {
        width: 60px;
        margin-right: 12px;
    }
    .areaWorkProfileWrap {
        background-color: #C4BEB2;
    }
    .areaWorkProfile {
        max-width: 1420px;
        height: 500px;
        background-repeat: no-repeat;
        background-position: center center;
        background-size: cover;
        margin: 0 auto 5em;
    }
    .areaWorkProfile.imgY {
        background-image: url("../../recruit/images/work/img_profile_y.jpg");
    }
    .areaWorkProfile.imgS {
        background-image: url("../../recruit/images/work/img_profile_s.jpg");
    }
    .areaWorkProfileInner {
        position: relative;
    }
    .h2Work {
        position: absolute;
        top: 105px;
        right: 0;
    }
    .h2Work span {
        display: inline-block;
        background-color: #fff;
        margin-bottom: 0.4em;
        padding: 0.2em 0.6em;
        font-size: 3.2rem;
    }
    .areaProfile {
        position: absolute;
        top: 260px;
        right: 0;
        display: inline-block;
        width: 445px;
        background-color: rgba(255, 255, 255, 0.85);
        margin-top: 2em;
        padding: 1em 2em;
    }
    .profileName {
        text-align: left;
    }
    .profileName dt {
        font-size: 1.4rem;
    }
    .profileName dd {
        font-size: 2.0rem;
    }
    .areaWorkTxtWrap, .areaWorkTxtWrap02 {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        justify-content: space-between;
    }
    .areaWorkTxtWrap {
        background-repeat: no-repeat;
        background-position: left top;
        background-size: 550px;
    }
    .areaWorkTxtWrap.imgY {
        background-image: url("../../recruit/images/work/img_work_y.jpg");
    }
    .areaWorkTxtWrap.imgS {
        background-image: url("../../recruit/images/work/img_work_s.jpg");
    }
    .imgWork img {
        display: none;
    }
    .areaWorkTxtR {
        width: 640px;
        background-color: rgba(255, 255, 255, 0.85);
        margin-top: 50px;
        padding-top: 3em;
        padding-left: 3em;
    }
    .areaWorkTxtL {
        flex: 1;
    }
    .areaSchedule {
        width: 386px;
        margin-left: 80px;
        padding-right: 2em;
        padding-left: 2em;
    }
    .ttlSchedule {
        font-size: 2.0rem;
    }
    .areaWorkMessageWrap {
        padding-bottom: 0;
    }
    .areaWorkMessage {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        justify-content: space-between;
        -ms-align-items: center;
        align-items: center;
        height: 340px;
        padding-top: 0;
    }
    .imgMessage {
        width: 530px;
        height: 400px;
        padding-top: 0;
    }
    .txtMessage {
        width: 500px;
        margin-left: 580px;
    }
}
/* recruit environment --------------- */
.areaEnvironment:not(:last-child) {
    margin-bottom: 2.5em;
}
.environmentImg {
    margin-bottom: 1em;
}
@media print, screen and (min-width: 768px) {
    .areaEnvironment {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        justify-content: space-between;
    }
    .environmentImg {
        width: 500px;
        margin-right: 50px;
    }
    .areaEnvironmentTxt {
        flex: 1;
    }
}
/* recruit description --------------- */
.tblDescription th {
    display: block;
    background-color: #EDEDED;
    padding: 0.5em 0.8em;
    text-align: left;
}
.tblDescription td {
    display: block;
    padding: 0.6em 0.8em 1.2em 0.1em;
}
.btnContact a {
    display: inline-block;
    background-color: rgba(25, 128, 216, 0.95);
    border-bottom: 4px solid #D7D7D7;
    border-radius: 100vh;
    padding: 0.9em 2.5em;
}
.btnContact a:hover {
    margin-top: 3px;
    background-color: rgba(25, 128, 216, 0.7);
    border-width: 1px;
    text-decoration: none !important;
}
.img3col li {
    margin-bottom: 1em;
}
.img4col li {
    margin-bottom: 10px;
}
@media print, screen and (min-width: 768px) {
    .tblDescription {
        border-bottom: 1px solid #EDEDED;
    }
    .tblDescription th {
        display: table-cell;
        width: 30%;
        border-bottom: 1px solid #fff;
        padding: 1.2em 4em;
    }
    .tblDescription tr:first-of-type th {
        border-top: 1px solid #EDEDED;
    }
    .tblDescription tr:last-of-type th {
        border-bottom: 1px solid #EDEDED;
    }
    .tblDescription td {
        display: table-cell;
        width: 70%;
        border-top: 1px solid #EDEDED;
        padding: 1.2em 4em;
    }
    .dlSalary dt {
        float: left;
        width: 5.5em;
        clear: both;
    }
    .dlSalary dd {
        margin-left: 5.5em;
    }
    .btnContact a {
        padding-right: 0.9em 3em;
        border-width: 5px;
        font-size: 2.0rem;
    }
    .btnContact a:hover {
        margin-top: 4px;
    }
    .img3col, .img4col {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        -webkit-flex-wrap: wrap;
        -moz-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        -o-flex-wrap: wrap;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .img3col::after {
        content: "";
        display: block;
        width: calc((100% - 60px) / 3);
    }
    .img3col li {
        width: calc((100% - 60px) / 3);
        margin-bottom: 1.5em;
    }
    .img4col li {
        width: calc((100% - 30px) / 4);
    }
}
/* contact
----------------------------------------------------------- */
.spBlock {
    margin-right: 1em;
}
.sizeS {
    width: 120px !important;
}
.sizeM {
    width: 75%;
}
.sizeL {
    width: 100%;
}
.required, .txtError {
    color: #DB4158;
}
.areaMessage {
    width: 100%;
    height: 10em;
}
.areaFormBtn {
    width: 100%;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}
.btnForm, .btnBack, .btnAgree {
    border-bottom: 4px solid #D7D7D7;
    border-radius: 100vh;
    padding-top: 0.9em;
    padding-bottom: 0.9em;
    color: #fff;
    font-family: 'Noto Serif JP', "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.1em;
    cursor: pointer;
}
.btnForm, .btnAgree {
    padding-right: 3em;
    padding-left: 3em;
}
.btnForm {
    background-color: rgba(25, 128, 216, 0.95);
}
.btnAgree {
    background-color: #ccc;
}
.btnBack {
    background-color: #A1A1A1;
    margin-right: 20px;
    padding-right: 2em;
    padding-left: 2em;
}
.btnForm:hover, .btnBack:hover {
    filter: alpha(opacity=70);
    -moz-opacity: 0.7;
    opacity: 0.7;
    -webkit-transition: 0.4s;
    transition: 0.4s;
}
@media print, screen and (min-width: 768px) {
    .sizeM {
        width: 75%;
    }
    .sizeL {
        width: 100%;
    }
    .areaMessage {
        height: 15em;
    }
    .areaFormBtn {}
    .btnForm, .btnBack, .btnAgree {
        padding-top: 1em;
        padding-bottom: 1em;
        font-size: 2.0rem;
    }
    .btnBack {
        margin-right: 200px;
        padding-right: 3em;
        padding-left: 3em;
    }
    .btnForm, .btnAgree {
        width: 350px;
    }
}