@charset "utf-8";

@media screen and (max-width:1200px){
    .tool-item-fo.last{
        padding-left: 50px;
    }
    .tool-menu-fo li a{
        letter-spacing: 0;
        background-position: right center;
    }
}

@media screen and (max-width: 1100px){
    .tool-item-fo.last{
        padding-right: 20px;
    }

    .humbager{
        display: block;
        position: absolute;
        left: 40px;
        top: 40px;
        z-index: 99;
    }

    .add-header{
        display: none;
    }

    .logo-header{
        padding-top: 20px;
        left: 50%;
        transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        -o-transform: translateX(-50%);
    }

    .tool-slide-header{
        padding-top: 95px;
    }

    .nav-menu {
        display: none;
        width: 100%;
        height: 100vh;
        position: fixed;
        left: 0;
        top: 0;
        z-index: 9999;
        background-color: rgba(41, 171, 226, 0.81);
    }

    .nav-menu .menu {
        margin-top: 0;
        width: 100%;
        max-width: 580px;
        margin: 0 auto;
        margin-top: 155px;
        height: 80%;
        overflow-y: scroll;
    }

    .nav-menu .menu li{
        width: 50%;
        display: none;
    }

    .nav-menu .menu li.sp{
        display: inline-block;
    }


}

@media screen and (max-width:1055px){
    .tool-list-fo{
        display: flex;
        flex-direction: column;
    }

    .tool-item-fo.fisrt{
        width: 100%;
        order: 1;
    }

    .tool-item-fo.last{
        width: 100%;
        order: 0;
        padding-top: 70px;
        padding-right: 11.429vw;
        padding-left: 11.429vw;
    }

    .tool-menu-fo li{
        margin-bottom: 20px;
    }

    .logo{
        text-align: center;
        margin-top: 50px;
    }

    .tool-info{
        margin: 0 auto;
    }

    .tool-hana{
        top: -60px;
    }

    .tool-menu-fo li a{
        border-bottom: 1px solid #ffffff;
        background-position: right 10px center;
    }

    .nav-menu .menu li.sp img{
        width: 230px;
    }
    
    .logo{
        padding-left: 0;
    }


}

@media screen and (max-width:900px){
    .humbager img{
        width: 60px;
        height: 50px;
    }
}


@media screen and (max-width:790px){
    .tool-item-fo.last{
        padding-right: 3.797vw;
        padding-left: 3.797vw;
    }    
}


@media screen and (max-width:750px){
    .nav-menu .menu li.sp{
        margin-bottom: 5.333vw;
    }

    .tool-wrap-head{
        /* background-image: url(../img/bg-top-sp.png); */
        background-image: inherit;
        position: relative;
    }

    .bg-body{
        background-image: url(../img/bg-top-sp.png);
        background-position: center top;
        background-repeat: no-repeat;
    }

    /* .tool-wrap-head::before{
        content: "";
        width: 100%;
        height: 100vh;
        position: absolute;
        left: 0;
        top: 0;
        z-index: 0;
        background-image: url(../img/bg-top-sp.png);
        background-position: center top;
        background-repeat: no-repeat;
    } */


    .tool-slide-header .owl-carousel .owl-stage-outer::before{
        background-image: url(../img/slie-sp.png);
    }

    .tool-slide-header .owl-theme .owl-nav{
        top: 33%;
    }

    .tool-slide-header .owl-carousel .item{
        max-width: 78vw;
        padding-top: 5px;
    }

    .tool-slide-header{
        padding-top: 120px;
    }

    .tool-coppy br{
        display: block;
    }

    .tool-coppy{
        font-size: 3.733vw;
        font-weight: normal;
    }

    .tool-item-fo.last{
        padding-left: 7.333vw;
        padding-right: 7.333vw;
    }

    .contact-tel{
        display: block;
    }

    .tool-menu-fo li {
        margin-bottom: 4vw;
        margin-right: 5%;
        width: 47.5%;
    }

    .tool-menu-fo li a{
        font-size: 3.467vw;
        padding-bottom: 2.400vw;
        background-position: right 3.067vw top 0.933vw;
        background-size: 3.467vw;
    }

    .logo a img.pc{
        display: none;
    }

    .logo a img.sp{
        display: inline-block;
    }

    .tool-address{
        display: none;
    }


    .tool-info{
        display: none;
        border: 0px solid #000;
    }

    /* .tool-menu-fo li:last-child a{
        border-bottom: 0;
    } */

    .tool-coppy span{
        display: none;
    }
   
    .fo-sp{
        display: block;
        width: 100%;
        max-width: 600px;
        margin: 0 auto;
        color: #ffffff;
        font-weight: bold;
        padding-bottom: 8.800vw;
    }

    .tt-fz36{
        font-size: 4.267vw;
        line-height: 130%;
        letter-spacing: 5px;
        padding-top: 18px;
    }

    .tt-fz52{
        font-size: 6.933vw;
        line-height: 120%;
        letter-spacing: -2px;
        padding-bottom: 4px;
    }

    .tt-fz28{
        font-size: 3.733vw;
        line-height: 160%;
        color: #ffffff;
        display: block;
        text-decoration: none;
      
    }

    a.tt-fz28:hover{
        text-decoration: none;
        color: #ffffff;
    }

    .info-item-fo-sp{
        display: inline-block;
        vertical-align: top;
    }

    .info-item-fo-sp:last-child{
        padding-left: 25px;
    }

    .tool-hana img.pc{
        display: none;
    }

    .tool-hana img.sp{
        display: block;
        margin: 0 auto;
    }

    .page-top{
        z-index: 999999999;
    }

    .page-top img{
        width: 50px;
    }
    
    .tool-item-fo.last{
        padding-top: 10px;
    }

    .tool-hana {
        top: -11.333vw;
    }

    .humbager{
        left: 5.333vw;
        top: 5.333vw;
    }

    .contact-tel{
        font-size: 3.733vw;
    }
}

@media screen and (max-width:740px){
    .tool-slide-header .owl-carousel .item {
        max-width: 78.462vw;
    }

    .tool-wrap-head{
        background-position: top right -50px;
    }

    .logo-header{
        padding-top: 2.667vw;
    }
}

@media screen and (max-width:700px){
    .tool-slide-header .owl-carousel .item {
        max-width: 83vw;
    }

}

@media screen and (max-width:680px){
    .tool-slide-header .owl-carousel .item {
        max-width: 88vw;
    }

}

@media screen and (max-width:650px){
    .tool-slide-header .owl-carousel .item {
        max-width: 78.462vw;
    }

    .tool-slide-header .owl-carousel .owl-stage-outer::before{
        background-size: contain;
    }

    .tool-wrap-head{
        min-height: auto;
    }
}


@media screen and (max-width:600px){
    .tool-slide-header .owl-carousel .owl-stage-outer::before{
        background-size: contain;
    }

    .tool-slide-header .owl-theme .owl-nav{
        display: none;
    }

    .tool-menu-fo li a{

    }


}

@media screen and (max-width:480px){
    .tool-slide-header .owl-carousel .item {
        max-width: 77.083vw;
    }

    .tool-hana {
        top: -9.375vw;
    }

    .contact-tel a{
        margin-top: 6.250vw;
        margin-bottom: 6.250vw;
    }

    .contact-tel{
        font-size: 20px;
    }

    .tool-menu-fo li a{
        background-position-x: right;
    }

    .logo{
        padding-left: 15px;
        padding-right: 15px;
        padding-bottom: 10px;
    }

    .info-item-fo-sp{
        display: block;
        width: 100%;
    }

    .info-item-fo-sp:last-child{
        padding-left: 0;
    }

    .fo-sp{
        text-align: center;
    }

    .tt-fz36{
        font-size: 20px;
    }

    .tt-fz52{
        font-size: 31px;
        padding-top: 5px;
        letter-spacing: 3.5px;
    }

    .tt-fz28{
        font-size: 16px;
        letter-spacing: 1.5px;
    }

    .page-top{
        right: 10px;
    }

    .humbager img{
        width: 40px;
        height: 35px;
    }

    .tool-slide-header{
        padding-top: 25vw;
    }

    .nav-menu .menu{
        margin-top: 20.167vw;
        padding-left: 15px;
        padding-right: 15px;
    }

    .nav-menu .menu li.sp{
        margin-bottom: 6px;
        width: 48%;
        margin-right: 4%;
    }
    .nav-menu .menu li.sp:nth-child(2n){
        margin-right: 0;
    }

    .nav-menu .menu li.sp img {
        width: 190px;
        display: block;
        margin: 0 auto;
    }

    .bg-body{
        background-size: contain;
    }
}

@media screen and (max-width:360px){
    .tool-slide-header .owl-carousel .item {
        max-width: 77.778vw;
    }

    .tool-slide-header .owl-carousel .owl-stage-outer{
        padding-bottom: 3px;
    }

    .tool-item-fo.last{
        padding-left: 15px;
        padding-right: 15px;
    }

    .nav-menu .menu{
        margin-top: 20vw;
   
    }

  
}