@charset "utf-8";

.cont_img {
    background-image: url(../images/cont_img.jpg);
}

/*============================
電気工事とは？
============================*/
#recruit_message {
    background: #fff;
}

#recruit_message .inner {
    position: relative;
    overflow: visible;
}

#recruit_message .flex {
    flex-direction: row-reverse;
    align-items: stretch;
}

#recruit_message h2 {
    font-size: 30px;
    padding-left: 36px;
    margin-bottom: 20px;
    position: relative;
    font-weight: 900;
    line-height: 1.5;
}

#recruit_message h2::before {
    content: "\f0e7";
    font-size: 30px;
    font-weight: 900;
	font-family: 'Font Awesome 6 Free';
    position: absolute;
    left: 0;
    top: 3px;
    color: #ffe94a;
}

#recruit_message .photo {
    width: 500px;
    border-radius: 30px;
    overflow: hidden;
}

#recruit_message .photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

#recruit_message .text {
    width: 500px;
    margin-top: -9px;
}

@media only screen and (max-width: 768px) {
    #recruit_message .photo {
        width: 100%;
        height: 0;
        padding-top: 70%;
        position: relative;
        margin-bottom: 20px;
    }

    #recruit_message .photo img {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    #recruit_message .text {
        width: 100%;
        margin-top: 0;
    }

    #recruit_message h2 {
        font-size: 20px;
        padding-left: 27px;
    }

    #recruit_message h2::before {
        font-size: 22px;
        top: 0;
    }
}

/*============================
おすすめポイント
============================*/
#point {
    background: linear-gradient(180deg, #ffffff 50px, #ffffff 50px, #00bcff 50px, #00bcff 100%);
    position: relative;
}

#point::before {
    content: "";
    background: url(../images/point/wave_sky.png)repeat-x top center;
    background-size: auto 100%;
    display: block;
    height: 55px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
/*
    animation: yurayura 4s ease-in-out infinite alternate;
    width: 120%;
*/
}

#point .inner {
    position: relative;
    overflow: visible;
}

#point .inner::before {
    content: "";
    background: url(../images/point/illust.png)no-repeat center center;
    background-size: 100%;
    width: 170px;
    height: 260px;
    position: absolute;
    top: -305px;
    right: -30px;
}

#point .inner.flex {
    flex-direction: row-reverse;
}

#point .text {
    width: 450px;
    color: #fff;
    margin-top: -9px;
}

#point h2 {
    margin-bottom: 20px;
}

#point ul {
    width: 550px;
    counter-reset: num 0;
}

#point ul li {
    width: 160px;
    border-radius: 30px;
    overflow: hidden;
    position: relative;
    background: #fff;
}

#point ul li::before {
    content: counter(num);
    counter-increment: num 1;
    background: #93c81f;
    font-size: 24px;
    font-family: "Outfit", sans-serif;
    font-weight: 600;
    letter-spacing: 0.05em;
    width: 50px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    color: #fff;
    position: absolute;
    top: 0;
    left: 0;
    border-bottom-right-radius: 30px;
}

#point ul li img {
    width: 100%;
}

#point ul li p {
    color: #fff;
    background: #93c81f;
    text-align: center;
    padding: 15px 0;
    font-size: 18px;
    font-weight: 600;
}

@media only screen and (max-width: 768px) {
    #point {
        background: linear-gradient(180deg, #ffffff 40px, #ffffff 40px, #00bcff 40px, #00bcff 100%);
    }

    #point::before {
        height: 40px;
    }

    #point .inner::before {
        width: 85px;
        height: 130px;
        top: -80px;
		right: 0;
    }

    #point .text {
        width: 100%;
        margin-top: -0;
        margin-bottom: 20px;
    }

    #point h2 {
        width: calc(100% - 100px);
    }

    #point ul {
        grid-row-gap: 20px;
    }

    #point ul li {
        width: 100%;
    }

    #point ul li img {
        width: 120px;
        margin: auto;
    }

    #point ul li p {
        padding: 8px 0;
        font-size: 16px;
    }
}

/*============================
募集要項
============================*/
#recruit_info {
    background: url(../images/recruit_info/bg.jpg)no-repeat top center;
    background-size: cover;
    padding-bottom: 0;
}

#recruit_info h2 {
    color: #fff;
}

#recruit_info .bg {
    background: #fff;
    border-radius: 30px;
    padding: 60px;
}

#recruit_info table.info tbody {
    width: 440px;
}

#recruit_info table.info .detail {
    margin-top: 20px;
}

#recruit_info table.info .detail dt {
    background: #009944;
    text-align: center;
    color: #fff;
    line-height: 30px;
    border-radius: 15px;
    width: 100px;
    margin-bottom: 10px;
    font-size: 12px;
}

#recruit_info table.info .detail dd {
    padding-left: 20px;
    position: relative;
}

#recruit_info table.info .detail dd::before {
    content: "";
    width: 8px;
    height: 8px;
    background: #009944;
    display: block;
    border-radius: 4px;
    position: absolute;
    left: 0;
    top: calc(50% - 4px);
}

@media only screen and (max-width: 768px) {
    #recruit_info .bg {
        padding: 30px;
    }

    #recruit_info table.info tbody {
        width: 100%;
    }
}

/*============================
採用の流れ
============================*/
#flow {
    background: #096fca;
}

#flow h2 {
    color: #fff;
}

#flow ul.step {
    counter-reset: number 0;
}

#flow ul.step li {
    background: #fff;
    padding: 20px 0;
    padding-left: 230px;
    font-size: 18px;
    border-radius: 36px;
    position: relative;
}

#flow ul.step li:not(:last-child) {
    margin-bottom: 40px;
}

#flow ul.step li:before {
    content: "STEP"counter(number) " ";
    counter-increment: number 1;
    background: #93c81f;
    color: #fff;
    font-size: 30px;
    font-family: "Outfit", sans-serif;
    font-weight: 600;
    letter-spacing: 0.05em;
    width: 200px;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    line-height: 72px;
    text-align: center;
    border-top-left-radius: 36px;
    border-bottom-left-radius: 36px;
}

#flow ul.step li span {
    display: inline-block;
    padding-right: 30px;
}

#flow ul.step li:not(:last-child)::after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-top: 14px solid #93c81f;
    border-bottom: 0;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -27px;
    margin: auto;
}

.recruit_btn::before {
    background-color: #096fca;
}

@media only screen and (max-width: 768px) {
    #flow ul.step li {
        padding: 71px 30px 30px;
        font-size: 15px;
    }

    #flow ul.step li span {
        display: block;
        padding-right: 0;
        font-size: 18px;
        border-bottom: 1px solid #096fca;
        padding-bottom: 8px;
        margin-bottom: 8px;
        text-align: center;
    }

    #flow ul.step li:before {
        width: 100%;
        height: auto;
        line-height: 51px;
        border-radius: 30px 30px 0 0;
            font-size: 24px;
    }
}

/*============================
フッターボタン
============================*/

#footer_contact {
    background: linear-gradient(180deg, #1b7cd3 0%, #1b7cd3 50%, #ffffff 50%, #ffffff 100%);
}