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

    .container,
    .container_800 {
        padding: 0 20px;
        max-width: 1200px;
        margin: 0 auto;
    }

    .container_680 {
        padding: 0;
        max-width: 1200px;
        margin: 0 auto;
    }

    .container02 {
        padding: 0;
        max-width: 1200px;
        margin: 0 auto;
    }

    .row {
        padding: 0 20px;
        max-width: 1200px;
        margin: 0 auto;
        position: relative;
    }

}

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

    .sp {
        display: none;
    }

    .br_sp {
        display: none;
    }

    a[href^="tel:"] {
        pointer-events: none;
    }

}

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

    .pc {
        display: none;
    }

    .container,
    .container_header,
    .container_800 {
        padding: 0 20px;
        max-width: 767px;
        margin: 0 auto;
    }

    .container_680 {
        padding: 0;
        max-width: 767px;
        margin: 0 auto;
    }

    .container02 {
        padding: 0;
        max-width: 767px;
        margin: 0 auto;
    }

    .row {
        padding: 0 20px;
        max-width: 767px;
        margin: 0 auto;
        position: relative;
    }

    .slider img {
        width: auto;
        height: 100%;
        display: block;
        position: absolute;
        top: 0;
        bottom: 0;
        left: -300%;
        right: -300%;
        margin: auto;
    }

    .main_copy {
        color: #fff;
        font-size: 3.2rem;
        font-weight: 700;
        opacity: 0.5;
        text-align: center;
        position: absolute;
        top: 52%;
        left: 0;
        right: 0;
        margin: auto;
        -webkit-transform: translateY(-48%);
        transform: translateY(-48%);
    }

    .main_copy_sm {
        display: block;
        color: #fff;
        font-size: 1.2rem;
        font-weight: 700;
        margin-top: 20px;
    }

    .heading2 {
        font-size: 2.2rem;
    }

    .top_service {
        padding: 70px 0 70px;
    }

    .top_performance {
        padding: 70px 0;
        background: #f9f9f9;
    }

    .top_company {
        padding: 70px 0;
    }

    .top_recruit {
        padding: 70px 0;
        background-image: url(../img/top_bg001.jpg);
        background-repeat: no-repeat;
        background-position: center right 20%;
        background-size: cover;
    }

    .top_service_flex {
        margin-top: 40px;
        display: -ms-flex;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        position: relative;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .top_service_flex_img {
        width: 100%;
        height: auto;
        text-align: center;
    }

    .top_service_flex_content_wrap {
        max-width: 100%;
        width: 100%;
        padding: 40px 20px;
        background: #0961a4;
        z-index: 10;
        position: static;
        top: auto;
        right: auto;
    }

    .heading3_top_service {
        color: #fff;
        font-size: 2.2rem;
        font-weight: 400;
        letter-spacing: 0.2rem;
        margin-bottom: 20px;
        text-align: center;
    }

    .heading3_top_service_sm {
        display: block;
        color: #73b8ec;
        font-size: 1.4rem;
        font-weight: 600;
        letter-spacing: 0.1rem;
        margin-top: 10px;
        -webkit-font-feature-settings: "palt";
        font-feature-settings: "palt";
    }

    .btn,
    .btn_wh {
        width: 100%;
    }

    .top_performance_companies {
        display: -ms-flex;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        margin: 40px -5px 0;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .top_performance_companies:not(:first-child) {
        margin-top: 10px;
    }

    .top_performance_companies_item {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        padding: 0 5px;
    }

    .top_company_flex {
        display: -ms-flex;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        margin-top: 40px;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .top_company_flex_box {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        height: auto;
        padding-top: 50%;
        text-decoration: none;
        -webkit-transition: all .5s;
        transition: all .5s;
        display: -ms-flex;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -ms-align-items: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        position: relative;
        border-left: none;
    }

    .top_company_flex_box:last-child {
        border-right: none;
    }

    .top_company_flex_box01 {
        border-right: solid 1px #d2d2d2;
        border-bottom: solid 1px #d2d2d2;
    }

    .top_company_flex_box02 {
        border-bottom: solid 1px #d2d2d2;
    }

    .top_company_flex_box03 {
        border-right: solid 1px #d2d2d2;
    }

    .top_company_flex_inner {
        position: absolute;
        top: 50%;
        left: 0;
        right: 0;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        padding: 10px;
    }

    .top_company_flex_img {
        text-align: center;
        margin-bottom: 5px;
    }

    .top_company_flex_img img {
        max-width: 100%;
        height: auto;
    }

    .heading3_top_company {
        font-size: 1.6rem;
        font-weight: 600;
        color: #313131;
        text-align: center;
        letter-spacing: 0.1rem;
        -webkit-font-feature-settings: "palt";
        font-feature-settings: "palt";
    }

    .footer_link_list {
        display: block;
        line-height: 40px;
    }

    .footer_link_menu {
        margin-right: 0;
    }

    #page-top {
        position: fixed;
        bottom: 20px;
        right: 20px;
    }

    #page-top a {
        line-height: 55px;
        text-align: center;
        font-size: 1.2rem;
        font-weight: 700;
        letter-spacing: 0.1rem;
        color: #fff;
        display: block;
        width: 50px;
        height: 50px;
        text-decoration: none;
        border-radius: 50%;
        border: solid 2px #fff;
        background: rgba(9, 97, 164, 0.9);
    }

    #page-top a::before {
        content: "";
        width: 4px;
        height: 4px;
        border-top: solid 2px #fff;
        border-right: solid 2px #fff;
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        position: absolute;
        top: 8px;
        left: 0;
        right: 0;
        margin: 0 auto;
    }

    .lawer_sec {
        padding: 70px 0;
    }

    .lawer_content_flex01 {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .lawer_content_flex01_left,
    .lawer_content_flex01_right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        padding: 0 20px;
    }

    .lawer_content_flex01_left {
        margin-bottom: 20px;
    }

    .lawer_content_flex02 {
        display: -ms-flex;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        flex-wrap: nowrap;
        margin: 20px -5px 0;
    }
	 .lawer_content_flex02 iframe{
        display: -ms-flex;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        flex-wrap: nowrap;
        margin: 10px -5px 0;
    }

    .lawer_content_flex02_child {
        flex: 0 0 33.3%;
        padding: 0 5px;
    }

    .table_item_left {
        font-size: 1.4rem;
        line-height: 2.2rem;
        color: #313131;
        font-weight: 400;
        -webkit-box-flex: 0;
        -ms-flex: 0 0 60%;
        flex: 0 0 60%;
    }

    .table_item_right {
        font-size: 1.8rem;
        color: #313131;
        font-weight: 400;
        -webkit-box-flex: 0;
        -ms-flex: 0 0 35%;
        flex: 0 0 35%;
        text-align: right;
    }

    .gallery_content_box {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
    }

    .gallery_content_sec_item {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 100%;
        position: relative;
        overflow: hidden;
        padding-top: 50%;
    }

    .ta_center_pc {
        text-align: left;
    }

    .ta_center_sp {
        text-align: center;
    }

    .order1 {
        order: 2;
    }

    .order2 {
        order: 1;
    }

    .sp_order1 {
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
    }

    .sp_order2 {
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
    }

    .txt12 {
        font-size: 1.1rem;
        line-height: 1.8rem;
    }


}

@media screen and (min-width: 414px) and (max-width: 767px) {

    .slider img {
        width: 100%;
        height: auto;
        /* display: block; */
        position: absolute;
        top: 0;
        bottom: 0;
        left: -300%;
        right: -300%;
        margin: auto;
    }





}

@media screen and (min-width: 300px) and (max-width: 767px) {
    .footer_link_list2 {
        text-decoration: none;
        font-size: 1.4rem;
        color: #0961a4;
        -webkit-transition: all .5s;
        transition: all .5s;
        font-weight: 800;
        position: relative;
        display: inline-block;
        text-decoration: none;
        line-height: 29px;

    }

    .banner {
        margin: auto;
    }

    .banner img {
        margin: auto;
        width: 100%;
    }

}


/* 例：br.sp_brはタブレット以上のサイズでは非表示にする */

@media screen and (min-width: 650px) {
    .br-pc {
        display: block;
    }

    .br-sp {
        display: none;
    }
}

@media screen and (max-width: 650px) {
    .br-pc {
        display: none;
    }

    .br-sp {
        display: block;
    }

    .footer_link_list2 a {
        text-align: left;
    }

}
