.show__sp {
    display: none;
}

@media (max-width: 1440px) {
    * {
        box-sizing: border-box;
    }

    .box_top_lead {
        padding-top: 17.3611vw;
        max-height: 76.3889vw;
        max-width: 1100px;
        width: calc(100% - 30px);
    }

    .box_top_lead img {
        width: 75vw;
        height: auto;
    }

    .top_arrow {
        margin-top: 13.8889vw;
    }

    .contents {
        padding: 4.1667vw 0;
    }

    #header .inner,
    .contents .inner {
        width: calc(100% - 30px);
        max-width: 1100px;
    }

    .waku_top_r .inner {
        width: calc(100% - 30px);
        max-width: 1280px;
        display: flex;
        justify-content: space-between;

    }

    .bg_top_r {
        background-size: contain;
    }

    .top_r_img {
        float: initial;
        order: 1;
        box-shadow: -2.7778vw 2.7778vw #fff;
        width: 44.3056vw;
        display: flex;
        align-items: flex-end;
    }

    .top_r_img img {
        width: 100%;
        height: auto;
    }

    .contents iframe {
        height: 40.6944vw;
    }

    .top_r_txt {
        width: calc(100% - 44.3056vw);
        padding-top: 8vw;
        margin-left: 6.25vw;
        padding-right: 5vw;
    }

    .top_bana {
        margin: 4.7222vw auto 0;
        width: calc(100% - 30px);
    }

    .top_bana img {
        width: 100%;
        height: auto;
    }

    #footer .inner {
        width: calc(100% - 30px);
        max-width: 1100px;
    }

    .ttl_greet {
        width: calc(100% - 30px);
        max-width: 1100px;
        margin: 4.1667vw auto 2.7778vw;
    }

    .title01 {
        width: calc(100% - 30px);
        max-width: 1100px;
    }

    .title02 {
        margin-bottom: 2vw;
    }

    .mb50 {
        margin-bottom: 3.4722vw;
    }

    .waku_top_r {
        padding-bottom: 5.5556vw;
    }

    .works__gp-01 {
        display: flex;
        flex-wrap: wrap;
    }

    .works__gp-01 .title02 {
        width: 100%;
    }

    .works__gp-01 .fl {
        width: 38.5417vw;
    }

    .works__gp-01 .fl img {
        width: 100%;
        height: auto;
    }

    .works__gp-01>img {
        width: 100%;
        height: auto;
        margin-top: 30px;
    }

    .works__gp-01 .box_txt_r {
        width: calc(100% - 38.5417vw);
    }

    .works__gp-01 .fr {
        width: 38.9583vw;
    }

    .works__gp-01 .fr img {
        width: 100%;
        height: auto;
    }

    .works__gp-01 .box_txt_l {
        width: calc(100% - 38.9583vw);
        padding-left: 30px;
    }

    .works__list-01 {
        display: flex;
        flex-wrap: wrap;
    }

    .works__list-01 li {
        width: calc((100% - 9.3757vw) / 4);
        margin-right: 3.125vw;
        position: relative;
    }

    .works__list-01 li:nth-child(4n) {
        margin-right: 0;
    }

    .works__list-01 li .box_oem {
        width: 100%;
    }

    .works__list-01 li .arrow_next {
        width: 3.125vw;
        position: absolute;
        top: 50%;
        right: -3.125vw;
        transform: translateY(-50%);
        padding-top: 0;
    }

    .hotto_mv__img {
        margin-top: 2.0833vw;
    }

    .hotto_mv__img.vs_100 img {
        width: 100%;
    }

    .box_title {
        padding-top: 7.9861vw;
        height: 20.8333vw;
    }

    .box_title img {
        width: 15.2778vw;
        height: auto;
    }

    .box_title div {
        width: calc(100% - 30px);
        max-width: 1100px;
    }

    .waku_greet .inner {
        width: calc(100% - 30px);
        max-width: 1280px;
    }

    .faci_img img {
        width: 100%;
        height: auto;
    }

    .box_faci_gp {
        display: flex;
    }

    .box_faci_gp li {
        width: calc((100% - 15.01px) / 2);
        margin-right: 15px;
    }

    .box_faci_gp li:nth-child(2n) {
        margin-right: 0;
    }

    .box_faci_gp li .box_faci_l,
    .box_faci_gp li .box_faci_r {
        width: 100%;
    }

    .geet_img {
        width: 41.1111vw;
        box-shadow: -2.7778vw 2.7778vw #fff;
    }

    .geet_img img {
        width: 100%;
        height: auto;
    }

    .greet_txt {
        margin-left: 0;
        padding-top: 8.3333vw;
        width: calc(100% - 41.1111vw);
        padding-right: 4vw;
    }

    .waku_greet .img img {
        width: 100%;
        height: auto;
    }

    .contents .inner .img img {
        width: 100%;
        height: auto;
    }

    .bg_illust {
        background-size: contain;
    }

    .box_voice {
        width: calc(100% - 30px);
        max-width: 1040px;
    }

    .box_voice img {
        width: 100%;
        height: auto;
    }

    .iframe {
        max-width: 100%;
        height: auto;
    }
}

@media (max-width: 960px) {
    #header {
        padding: 8px 0 25px;
    }

    #header .inner:after {
        content: none;
    }

    #navi {
        display: none;
        height: auto;
        padding-top: 0;
        width: 100%;
        position: relative;
        top: 24px;
        padding-bottom: 24px;
    }

    #navi li {
        display: block;
        margin-left: 0;
    }

    #navi li a {
        display: block;
        text-align: center;
        border-top: 1px #ccc dashed;
        padding: 9px;
    }

    .h_logo {
        float: initial;
        display: flex;
        justify-content: space-between;
    }

    #menu span {
        width: 50px;
        height: 5px;
        background-color: #FFF;
        display: block;
        margin: 8px auto;
        -webkit-transition: all 0.3s ease-in-out;
        -o-transition: all 0.3s ease-in-out;
        transition: all 0.3s ease-in-out;
    }

    #menu.change span:nth-child(1) {
        -webkit-transform: translateY(13px) rotate(45deg);
        -ms-transform: translateY(13px) rotate(45deg);
        -o-transform: translateY(13px) rotate(45deg);
        transform: translateY(13px) rotate(45deg);
    }

    #menu.change span:nth-child(2) {
        opacity: 0;
    }

    #menu.change span:nth-child(3) {
        -webkit-transform: translateY(-13px) rotate(-45deg);
        -ms-transform: translateY(-13px) rotate(-45deg);
        -o-transform: translateY(-13px) rotate(-45deg);
        transform: translateY(-13px) rotate(-45deg);
    }

    .contents .inner img {
        max-width: 100%;
        height: auto;
    }

    .bg_top_w {
        background-size: contain;
    }

    .top_r_txt {
        margin-left: 0;
        width: 100%;
        padding-right: 0;
    }

    .waku_top_r .inner {
        flex-wrap: wrap;
    }

    .top_r_img {
        order: 0;
        width: 100%;
        margin-left: 30px;
    }

    ul.btnx2 li {
        width: 100%;
        margin-bottom: 30px;
    }

    ul.btnx2 li:last-child {
        margin-bottom: 0;
    }

    #pageTop {
        bottom: 50px;
    }

    .top_arrow {
        margin-top: 6vw;
    }

    .box_top_lead img {
        width: 87vw;
    }

    .works__list-gp {
        overflow: hidden;
        overflow-x: scroll;
    }

    .works__list-01 {
        width: max-content;
        margin-bottom: 10px;
    }

    .works__list-01 li {
        width: 240px;
    }

    .title01 img {
        width: 100%;
        height: auto;
    }

    .box_title {
        height: 250px;
        padding-top: 0;
        display: flex;
    }

    .box_title img {
        width: 150px;
    }

    .geet_img {
        width: calc(100% - 25px);
        margin-left: 25px;
        float: initial;
    }

    .greet_txt {
        width: 100%;
        padding-right: 0;
    }

    .mailform th {
        padding: 10px 0 10px 40px;
    }

    .box_voice dt {
        font-size: 18px;
    }

    .qa_l {
        width: 49%;
    }
}

@media (max-width: 767px) {
    .show__sp {
        display: block;
    }

    .show__pc {
        display: none;
    }

    body {
        font-size: 15px;
    }

    h1 {
        font-size: 11px;
    }

    #header {
        padding: 8px 0 15px;
    }

    .box_top_lead {
        padding-top: 30vw
    }

    .box_top_lead img {
        width: 100%;
    }

    .top_arrow .scroll {
        width: 60px;
        height: 60px;
        background-size: 30px;
    }

    .top_bana {
        margin-bottom: 3px;
    }

    .ttl_greet {
        padding-top: 26px;
        padding-bottom: 17px;
    }

    .top_r_txt {
        padding-top: 0;
        margin-top: -18px;
        padding-bottom: 15px;
    }

    .ttl_greet img {
        height: 50px;
        width: auto;
    }

    .contents {
        padding: 30px 0;
    }

    .contents .title02 img {
        width: auto;
        height: 50px;
    }

    .contents .inner img.vs-02{
        margin-bottom: 28px;
    }

    .works__list-01{
        margin-bottom: 15px;
    }

    .contents.bg_gray,.contents.vs-02{
        padding-top: 40px;
        padding-bottom: 35px;
    }

    .contents.vs-03{
        padding-top: 50px;
    }

    .contents.vs-04{
        padding-top: 30px;
    }

    .contents .p.vs-02{
        margin-bottom: 7px;
    }

    .title02.vs-02{
        margin-bottom: 15px;
    }

    .mb30 {
        margin-bottom: 15px;
    }

    .works__gp-01 .title02{
        margin-bottom: 15px;
    }

    .top_r_img {
        margin-left: 10px;
    }

    .top_r_txt .mb30 img {
        width: 100%;
        height: auto;
    }

    .title01__sp{
        margin-top: 43px;
        margin-bottom: 40px;
    }

    .wp_descr .sp__shows{display: block !important;}

    .contents iframe {
        height: 65vw;
        margin-bottom: -19px;
    }

    ul.btnx2 li {
        margin-bottom: 13px;
    }

    ul.btnx2+p.mt60 {
        margin-top: 29px;
        line-height: 190%;
        text-align: left;
        padding-bottom: 10px;
    }

    .waku_top_r {
        padding-bottom: 30px;
        margin-bottom: 11px;
    }

    ul.f_navi li {
        width: calc(100% / 3);
        margin-bottom: 20px;
    }

    ul.f_navi {
        display: flex;
        flex-wrap: wrap;
    }

    #footer .logo_f img {
        width: 230px;
        height: auto;
    }

    #pageTop {
        right: 15px;
    }

    .works__gp-01 .fl,
    .works__gp-01 .box_txt_r {
        width: 100%;
        margin-bottom: 15px;
    }

    .works__gp-01 .box_txt_r {
        margin-bottom: 20px;
    }

    .works__gp-01 .fr,
    .works__gp-01 .box_txt_l {
        width: 100%;
    }

    .works__gp-01 .box_txt_l {
        padding-left: 0;
    }

    .contents .inner img {
        margin-bottom: 15px;
    }

    .hotto_mv__img {
        margin-left: auto;
        margin-right: auto;
    }

    .works__gp-01 .box_txt_l .mb30 {
        margin-bottom: 0;
    }

    .box_title {
        height: 200px;
    }

    .geet_img {
        width: calc(100% - 2vw);
        margin-left: 2vw;
    }

    table.gaiyou {
        border-top: 0;
    }

    table.gaiyou tr {
        border-bottom: 0;
    }

    table.gaiyou td,
    table.gaiyou th {
        float: left;
        width: 100%;
        padding: 15px 0;
    }

    table.gaiyou th {
        background: #CCC;
        text-align: left;
        padding-left: 15px;
        padding-right: 15px;
    }

    .greet_txt{
        padding-top: 40px;
    }

    ul.voice li {
        width: 100%;
    }

    table.bosyu {
        border-top: 0;
    }

    table.bosyu tr {
        border-bottom: 0;
    }

    table.bosyu thead td {
        background: #5b5b5b;
        color: #FFF;
    }

    table.bosyu td,
    table.bosyu th {
        width: 100%;
        padding: 15px 0;
        float: left;
    }

    table.bosyu th {
        background: #f2f2f2;
        text-align: left;
        padding-left: 15px;
        padding-right: 15px;
    }

    .mailform th,
    .mailform td {
        width: 100%;
        float: left;
        padding: 15px 0;
    }

    .mailform td {
        padding-top: 0;
    }

    .mailform {
        margin-bottom: 0;
        border-top: 0;
    }

    .mailform th {
        height: auto;
    }

    .mailform tr {
        border-bottom: 0;
    }

    .length_m {
        width: 100%;
    }

    .naiyou {
        width: 100%;
        height: 180px;
    }

    .mt40 {
        margin-top: 30px;
    }

    .mb50 {
        margin-bottom: 30px;
    }

    p.mb50 {
        text-align: left;
    }

    p.mb50 .pc_show {
        display: none;
    }

    .thanks .clear {
        margin-bottom: 0px !important;
    }

    .thanks .contents {
        padding: 80px 0;
    }

    .qa_l,
    .qa_r {
        width: 100%;
    }

    .greet_txt img {
        width: 100%;
        height: auto;
        margin-bottom: 10px;
    }

    .bg_illust{
        padding-bottom: 40px;
    }

    .bg_illust p{
        text-align: left;
        line-height: 175%;
    }
}