@charset "UTF-8";

@media only screen and (min-width: 1800px) {

    .home_fadein_zukei {
        max-width: none;
    }

    .home_fadein_zukei > div > img {
        margin: 0;
    }

}

@media only screen and (max-width: 1000px) {

    /* common /////////////////////////////////////////////////////////////////////////////////////////// */

    /* .spNone {
        display: none;
    }

    .pcNone {
        display: block;
    } */


    .cmn_maxbox {
        padding-left: 2%;
        padding-right: 2%;
    }

    /* aタグ(電話番号) */
    a[href^="tel"] {
        pointer-events: all;
    }

    body {
        font-size: 1.5rem;
    }








    /* header */
    .header_top {
        position: relative;
        z-index: 99;
        height: 60px;
        padding-left: 2%;
        padding-right: 2%;
        transition: background-color .25s;
    }

    #header_modalmenu_check:checked ~ .header_top {
        background-color: transparent;
    }

    .header_logo {
        width: 150px;
        max-width: none;
        min-width: 0;
    }

    .header_gnav {
        display: none;
    }

    .header_contact {
        display: none;
    }

    .header_modalmenu_open {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 60px;
        height: 100%;
        margin: 5px 0 0 auto;
        cursor: pointer;
    }

    .header_modalmenu_open .box {
        position: relative;
        display: inline-block;
        width: 28px;
        height: 28px;
    }

    .header_modalmenu_open .top {
        transform: translateY(-13px);
    }

    .header_modalmenu_open .bottom {
        transform: translateY(13px);
    }


    .header_modalmenu_open .box span {
        position: absolute;
        left: 0;
        top: calc((100% - 2px)/2);
        display: block;
        width: 100%;
        height: 2px;
        transition: transform .25s,
                    opacity .25s,
                    background-color .25s;
        background-color: #000000;
    }

    #header_modalmenu_check:checked ~ .header_top .header_modalmenu_open .box span {
        background-color: #ffffff;
    }

    #header_modalmenu_check:checked ~ .header_top .header_modalmenu_open .top,
    #header_modalmenu_check:checked ~ #header_modalmenu_conts .header_modalmenu_open .top {
        transform: rotate(45deg);
    }

    #header_modalmenu_check:checked ~ .header_top .header_modalmenu_open .center,
    #header_modalmenu_check:checked ~ #header_modalmenu_conts .header_modalmenu_open .center {
        opacity: 0;
    }

    #header_modalmenu_check:checked ~ .header_top .header_modalmenu_open .bottom,
    #header_modalmenu_check:checked ~ #header_modalmenu_conts .header_modalmenu_open .bottom {
        transform: rotate(-45deg);
    }

    #header_modalmenu_conts {
        position: fixed;
        top: 0;
        left: 0;
        display: block;
        width: 100%;
        height: 100vh;
        padding: 70px 0 100px;
        background-color: #00A199;
        background-image: url(../img/header_modalmenu_bg.svg);
        background-repeat: repeat-y;
        background-position: left -40px top -40px;
        background-size: auto;
        text-align: right;

        opacity: 0;
        pointer-events: none;
        transition: opacity .25s;
        overflow: auto;
    }

    #header_modalmenu_check:checked ~ #header_modalmenu_conts {
        top: 0;
        /* transform: none; */
        opacity: 1;
        pointer-events: all;
    }

    #header_modalmenu_conts ul {
        padding: 5px 35px 0 0;
    }

    #header_modalmenu_conts li {
        margin: 20px 0 0 0;
    }

    #header_modalmenu_conts li a {
        color: #FFFFFF;
        letter-spacing: 0.2rem;
        font-size: 2.4rem;
    }

    #header_modalmenu_conts > a {
        display: inline-block;
        min-width: 230px;
        padding-left: 0;
        padding-right: 35px;
        padding-top: 5px;
        padding-bottom: 5px;
        margin: 40px 0 0 0;
        background-image: url(../img/header_modalmenu_contact_bg.svg);
        background-repeat: no-repeat;
        background-position: left top;
        background-size: 100% auto;
        font-size: 2.4rem;
        color: #00A199;
    }








    /* home /////////////////////////////////////////////////////////////////////////////////////////// */

    .home_mainimg > p {
        /* top: 220px; */
        top: 270px;
        align-items: normal;
        font-size: calc(24px + (46 - 24)*(100vw - 320px)/(1000 - 320));
        line-height: 2;
    }




    /* feature /////////////////////////////////////////////////////////////////////////////////////////// */





    /* business /////////////////////////////////////////////////////////////////////////////////////////// */





    /* works /////////////////////////////////////////////////////////////////////////////////////////// */





    /* recruit /////////////////////////////////////////////////////////////////////////////////////////// */





    /* company /////////////////////////////////////////////////////////////////////////////////////////// */





    /* contact /////////////////////////////////////////////////////////////////////////////////////////// */





    /* link /////////////////////////////////////////////////////////////////////////////////////////// */





    /* news /////////////////////////////////////////////////////////////////////////////////////////// */







}













@media only screen and (max-width: 780px) {








    /* common /////////////////////////////////////////////////////////////////////////////////////////// */




    /* 共通 ラッパー */
    .cmn_wrapper::before {
        height: 90px;
    }

    /* 共通 見出し（英語＋日本語） */
    .cmn_heading + * {
        margin-top: 30px;
    }

    .cmn_heading .en {
        font-size: 4.2rem;
    }

    .cmn_heading .ja {
        font-size: 1.6rem;
    }


    /* 共通 dlリスト */
    .cmn_dl > div {
        display: block;
    }

    .cmn_dl > div > dt {
        display: block;
        width: 100%;
        min-width: 0;
        padding: 9px 20px;
        text-align: left;
    }

    .cmn_dl > div > dd {
        padding: 15px 20px;
        border-width: 0;
    }

    .cmn_dl > div:last-of-type > dd {
        border-width: 0 0 2px 0;
    }


    /* CMSエディタ装飾 */
    .cmn_cms_editor h3 {
        font-size: 2.2rem;
    }

    .cmn_cms_editor h4 {
        font-size: 2.0rem;
    }

    .cmn_cms_editor h5 {
        font-size: 1.8rem;
    }

    .cmn_cms_editor h6 {
        font-size: 1.6rem;
    }




    /* footer */
    footer > nav ul {
        display: block;
        padding-top: 23px;
        padding-bottom: 23px;
        padding-left: 2%;
        padding-right: 2%;
        font-size: 1.5rem;
    }

    footer > nav a {
        padding: 7px 0;
        text-align: center;
    }

    footer > div {
        padding: 30px 0 20px;
    }

    footer > div img {
        width: 120px;
    }

    footer > small {
        padding: 10px 0;
        font-size: 1.3rem;
    }






    /* home /////////////////////////////////////////////////////////////////////////////////////////// */

    .home_mainimg {
        height: 100vh;
        max-height: 900px;
    }

    .home_mainimg .swiper-container {
        height: 100vh;
        max-height: 900px;
    }

    .home_mainimg .slide02 {
        background-position: right -400px bottom;
    }

    .home_fadein_zukei > div > img {
        margin: 0 0 0 -310px;
        margin: -40px 0 0 -350px;
    }

    .home_biz {
        position: relative;
        z-index: 99;
        padding: 90px 0;
    }

    .home_biz_list {
        flex-wrap: wrap;
        padding: 0 5%;
    }

    .home_biz_list li {
        width: 49%;
        margin: 10px 0 0 0;
    }

    .home_biz_list figure {
        padding: 90% 0 0 0;
    }

    .home_biz_list div {
        position: relative;
        bottom: 0;
        transform: none;
        height: 80px;
        border-bottom: 0;
    }

    .home_biz_list div::before {
        display: none;
    }

    .home_biz_list div::after {
        transform: none;
        transition: none;
        width: 101%;
    }

    .home_biz_list div p {
        font-size: 1.9rem;
    }

    .home_works {
        padding: 90px 0 0 0;
    }


    .home_works_slider [class*="home_works_slider_prev"],
    .home_works_slider [class*="home_works_slider_next"] {
        display: none;
    }

    .home_works_link {
        height: 0;
        padding: 78% 0 0 0;
    }

    .home_works_titbox {
        padding: 10px 5%;
    }

    .home_works_titbox p {
        font-size: 1.7rem;
    }

    .home_works_detail {
        border-bottom: 10px solid #F29600;
    }

    .home_works_cat span {
        font-size: 1.6rem;
        /* white-space: nowrap; */
    }

    .home_works_detail > div {
        display: none;
    }

    .home_works_btn a {
        max-width: 200px;
        height: 40px;
    }



    .home_news {
        padding: 110px 0 90px;
        background-size:
            130px,
            130px;
    }

    .home_news > div {
        display: block;
    }

    .home_news_heading {
        margin: 0;
    }

    .home_news_list {
        padding: 0 15px;
        margin: 35px 0 0 0;
    }

    .home_news_list > li {
        display: block;
        margin: 17px 0 0 0;
    }

    .home_news_list > li > span {
        margin: 0;
    }

    .home_news_list > li > div {
        margin: 7px 0 0 0;
    }



    /* feature /////////////////////////////////////////////////////////////////////////////////////////// */

    .feature_list > li {
        padding-bottom: 70px;
    }

    .feature_list > li + li {
        margin-top: 180px;
    }

    .feature_list > li:last-of-type {
        margin-bottom: 180px;
    }

    .feature_list_sankaku {
        top: 30px;
        height: calc(100% - 30px);
    }

    .feature_list li:nth-of-type(2n-1) .feature_list_sankaku::after {
        left: 70px;
        background-position: center top -1.5px;
    }

    .feature_list li:nth-of-type(2n) .feature_list_sankaku::after {
        right: 70px;
        background-position: center bottom -1.5px;
    }


    .feature_list li:nth-of-type(2n-1) .feature_list_sankaku::before {
        transform: translate(calc(-100% - 159px), 0) skew(-27deg);
    }

    .feature_list li:nth-of-type(2n) .feature_list_sankaku::before {
        transform: translate(calc(100% - 79px), 0) skew(-27deg);
    }

    .feature_list_imgbox {
        top: auto;
        bottom: 0;
        transform: translate(0, 70%);
        height: 200px;
    }

    .feature_list_imgbox > div {
        width: 100%;
        max-width: 300px;
    }

    .feature_list_txtbox > div {
        width: 100%;
    }

    .feature_list_txtbox dt span {
        font-size: 8.4rem;
    }

    .feature_list li:nth-of-type(2n-1) .feature_list_txtbox dt span {
        margin-right: 20px;
    }

    .feature_list li:nth-of-type(2n) .feature_list_txtbox dt span {
        margin-left: 20px;
    }

    .feature_list_txtbox dt div {
        font-size: 2.2rem;
    }

    .feature_list_txtbox dd {
        display: block;
        min-height: 0;
        padding: 25px 30px;
        font-size: 1.5rem;
    }




    /* business /////////////////////////////////////////////////////////////////////////////////////////// */

    .biz_list {
        margin: 100px 0 0 0;
    }

    .biz_list_txtbox_inner > h2 {
        margin: 0 4% 0 -20px;
        font-size: 3.6rem;
        line-height: 1.3;
    }


    .biz_list_txtbox_inner > p {
        width: 65%;
        font-size: 1.6rem;
        letter-spacing: 0.1rem;
        line-height: 1.8;
    }

    .biz_list_txtbox_inner > div {
        max-width: 186px;
        padding: 10px 20px;
    }

    .biz_list_imgbox {
        transform: translate(-20px, -50%);
    }




    /* works /////////////////////////////////////////////////////////////////////////////////////////// */

    .works_schbox {
        display: block;
    }

    .works_schbox_cat {
        width: 100%;
    }

    .works_schbox_cat li {
        margin: 0 0 0 3px;
    }


    .works_schbox_cat a {
        height: 38px;
    }

    .works_schbox_cat span {
        /* font-size: 1.4rem; */
    }

    .works_schbox_free {
        width: 100%;
        margin: 10px 0 0 0;
    }

    .works_schbox_free form {
        width: 100%;
        height: 42px;
    }

    .works_schbox_free input[type="text"] {
        width: calc(100% - 60px);
        font-size: 1.6rem;
    }

    .works_schbox_free button {
        width: 60px;
        height: 100%;
        background-size: 20px;
    }

    .works_note {
        display: block;
        margin: 30px 0 -20px;
        font-size: 1.3rem;
        letter-spacing: 0.05rem;
    }

    .works_list {
        display: block;
        padding: 0;
    }

    .works_list > li {
        width: 100%;
        margin: 10px 0 0 0;
    }

    .works_list_link {
        /* padding: 80% 0 0 0; */
    }

    .works_list_titbox {
        padding: 10px 5%;
    }

    .works_list_titbox p {
        font-size: 1.7rem;
    }

    .works_list_detail {
        border-bottom: 10px solid #F29600;
    }

    .works_list_cat span {
        font-size: 1.6rem;
        /* white-space: nowrap; */
    }

    .works_list_detail > div {
        display: none;
    }







    .works_single_titbox {
        display: block;
        margin-top: 50px;
    }

    .works_single_titbox > p {
        width: 100%;
        font-size: 1.9rem;
    }

    .works_single_cat {
        width: 100%;
        margin: 20px 0 0 0;
    }

    .works_single_cat li {
        margin: 0 0 0 3px;
    }

    .works_single_cat span {
        padding: 5px 4px 5px 0;
        font-size: 1.5rem;
    }

    .works_single_photos .swiper-wrapper {
        /* height: 320px; */
        height: 75vw;
    }

    .works_single_photos .swiper-container-initialized .swiper-slide::after {
        display: block;
    }

    .works_single_photos figure {
        width: 100%;
        justify-content: center;
    }

    .works_single_photos [class*="works_single_photos_prev"],
    .works_single_photos [class*="works_single_photos_next"] {
        width: 36px;
        height: 50px;
        background-size: 45%;
    }

    .works_single_photos .swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
        width: 70px;
        height: 50px;
        margin: 10px 3.5px 0;
    }




    /* recruit /////////////////////////////////////////////////////////////////////////////////////////// */
    .recruit_topmsg .feature_list_txtbox dt div {
        min-height: 36px;
        padding: 30px 0 0 0;
        font-size: 2.9rem;
    }

    .recruit_topmsg .feature_list_txtbox dd {
        padding-left: 25px;
        padding-right: 25px;
    }

    .recruit_topmsg_detail > strong {
        display: block;
        font-size: 1.7rem;
    }

    .recruit_topmsg_detail > strong ~ strong {
        margin: 30px 0 0 0;
    }

    .recruit_topmsg_detail > p {
        line-height: 1.8;
    }

    .recruit_cond {
        margin-top: 200px;
    }





    /* company /////////////////////////////////////////////////////////////////////////////////////////// */
    .company_map {
        height: 300px;
    }




    /* contact /////////////////////////////////////////////////////////////////////////////////////////// */

    .contact_info::before {
        width: 100%;
    }

    .contact_info_inner {
        padding: 20px 0 25px 24%;
    }

    .contact_info_inner .name {
        font-size: 2.2rem;
    }

    .contact_info_inner .tel {
        margin: 15px 0 0 0;
    }

    .contact_info_inner .tel a {
        margin: 0;
        font-size: 1.9rem;
    }

    .contact_info_inner .tel small {
        display: block;
        font-size: 1.4rem;
        letter-spacing: 0.05rem;
    }

    .contact_info_inner .fax {
        margin: 10px 0 0 0;
    }

    .contact_info_inner .fax span {
        margin: 0 15px 0 0;
        font-size: 1.9rem;
    }

    .contact_info_inner .fax small {
        font-size: 1.4rem;
    }

    .contact_info_inner address {
        letter-spacing: 0;
        font-size: 1.4rem;
    }

    .contact_note {
        margin-top: 50px;
        font-size: 1.4rem;
    }

    .contact_form {
        margin-top: 30px;
    }

    .contact_form_list > div dt span {
        margin: 0 0 0 10px;
    }

    .contact_form_list input,
    .contact_form_list select,
    .contact_form_list textarea {
        font-size: 1.6rem;
    }

    .contact_form_list #zip {
        width: 100%;
        max-width: 150px;
    }

    .contact_form_list #mail1 ~ span {
        font-size: 1.4rem;
    }





    /* link /////////////////////////////////////////////////////////////////////////////////////////// */

    .link_list a {
        font-size: 1.5rem;
    }




    /* news /////////////////////////////////////////////////////////////////////////////////////////// */










}












@media only screen and (max-width: 560px) {









    /* common /////////////////////////////////////////////////////////////////////////////////////////// */









    /* home /////////////////////////////////////////////////////////////////////////////////////////// */





    /* feature /////////////////////////////////////////////////////////////////////////////////////////// */





    /* business /////////////////////////////////////////////////////////////////////////////////////////// */



    /* works /////////////////////////////////////////////////////////////////////////////////////////// */





    /* recruit /////////////////////////////////////////////////////////////////////////////////////////// */





    /* company /////////////////////////////////////////////////////////////////////////////////////////// */





    /* contact /////////////////////////////////////////////////////////////////////////////////////////// */





    /* link /////////////////////////////////////////////////////////////////////////////////////////// */





    /* news /////////////////////////////////////////////////////////////////////////////////////////// */











}



/* @media only screen and (max-width: 400px) { */
@media only screen and (max-width: 560px) {

    .biz_list li + li {
        margin: 100px 0 0 0;
    }

    .biz_list_txtbox_inner {
        height: 200px;
        padding-bottom: 30px;
        background-image: url(../img/biz_list_bg_green_sp.svg);
        background-repeat: no-repeat;
        background-position: right bottom;
        /* background-size: 100% 100%; */
        /* background-size: auto 100%; */
        background-size: 100%;
    }

    .biz_list li:nth-of-type(2n) .biz_list_txtbox_inner {
        background-image: url(../img/biz_list_bg_orange_sp.svg);
    }

    .biz_list_txtbox_inner h2 .pcNone {
        display: inline;
    }

    .biz_list_txtbox_inner p .pcNone {
        display: inline;
    }



}