/*===========================================================================

タブレット用レスポンシブ対応　ここから

===========================================================================*/
@media screen and (max-width:1050px) {
    .container{
        max-width: 708px;
    }
    .fv_txt{
        padding-left: 20px;
    }
    .fv_left{
        width: 55%;
    }
    .fv_rightImg {
        padding-right: 0;
        width: 45%;
    }
    .beforeAfter .container{
        max-width: 1080px;
    }
    .beforeAfter_head::before {
        width: 150px;
        left: -10px;
        bottom: 127px;
    }
    .beforeAfter_head::after{
        width: 80px;
        bottom: 135px;
    }
    .achievements_img {
        width: calc(100% / 3);
        box-sizing: border-box;
    }
    .achievements_txt{
        font-size: 20px;
    }
    .achievements_txt span {
        font-size: 26px;
    }
    .achievements_txt::before, .achievements_txt::after{
        width: 90px;
        height: 3px;
    }

    .userVoice{
        justify-content: space-around;
    }
    .userVoice_left{
        width: auto;
    }
    .userVoice_right{
        width: 48%;
    }
    .userVoice_ttl{
        font-size: 22px;
        padding-bottom: 100px;
    }
    .userVoice_txt{
        font-size: 14px;
    }
    .userVoice_txt .orange{
        font-size: 16px;
    }
    .userVoice_person {
        max-width: 250px;
    }
    .userVoice_chart_wrapper{
        max-width: 290px;
    }
    .userVoice_chart_wrapper::after {
        width: 100px;
        height: 100px;
        top: -91px;
        right: -50px;
    }
    .userVoice_chart{
        max-width: 100%;
    }
    .benefit_case:nth-of-type(1){
        padding-top: 100px;
    }
    .benefit_case:nth-of-type(2), .benefit_case:nth-of-type(3), .benefit_case:nth-of-type(4){
        padding-top: 70px;
    }
    .benefit_case:nth-of-type(2) .benefit_case_img {
        width: 45%;
    }
    .benefit_case_ttl{
        font-size: 22px;
        padding-bottom: 15px;
    }
    .benefit_case_ttl span{
        font-size: 32px;
    }
    .benefit_case_inner{
        padding-bottom: 0;
        padding-right: 20px;
    }
    .benefit_case_num{
        width: 160px;
        padding-bottom: 0;
    }
    .benefit_case:nth-of-type(1) .benefit_case_head:after{
        width: 50%;
        bottom: -20px;
        right: -70px;
    }
    .benefit_case:nth-of-type(2) .benefit_case_head:after {
        width: 50%;
        bottom: 0;
        right: 0;
    }
    .benefit_case:nth-of-type(2) .benefit_case_inner{
        padding-bottom: 0;
    }
    .benefit_case:nth-of-type(3) .benefit_case_head:after {
        width: 50%;
        bottom: 0;
        right: -5px;
    }
    .benefit_case:nth-of-type(3) .benefit_case_inner {
        padding-right: 0px;
        padding-bottom: 20px;
    }
    .benefit_case:nth-of-type(4) .benefit_case_head:after {
        width: 50%;
        bottom: -15px;
        right: -40px;
    }
    .line_illust.pc{
        width: 45%;
    }
    .annoy_txt{
        font-size: 25px;
    }
    .annoy_txt::after{
        top: -30px;
        left: 50px;
    }
    .annoy_txt span{
        font-size: 40px;
    }
    .annoy_img{
        max-width: 100%;
    }
    .solve_catchcopy::before{
        left: 0;
    }
    .solve_catchcopy::after{
        right: 0;
    }
    .solve_txt .emphasis{
        font-size: 50px;
    }
    .solve_banner{
        padding-bottom: 120px;
    }
    .solve_banner::before{
        width: 20%;
    }
    .solve_banner::after{
        width: 25%;
        bottom: -3px;
    }
    .solve_person01, .solve_person02{
        width: 30%;
    }
    .solve_medals{
        width: 400px;
        bottom: -120px;
    }
    .reasons_ttl{
        font-size: 26px;
        padding-left: 110px;
    }
    .reasons_content{
        margin-bottom: 125px;
        box-shadow: 15px 10px 0 #FFED00, 15px 10px 0 4px #333, 11px 12px 0 #333;
    }
    .reasons_content::after{
        width: 140px;
        height: 140px;
        top: -80px;
    }
    .reasons_content_inner{
        padding-top: 55px;
    }
    .reasons_txt{
        font-size: 16px;
        max-width: 370px;
    }
    .reasons_txt .emphasis{
        font-size: 20px;
        margin-top: 10px;
    }
    .reasons_img{
        max-width: 220px;
    }
    .examples{
        padding-top: 60px;
    }
    .examples_headTxt::after{
        right: -100px;
        width: 100px;
    }
    .examples_ttl{
        font-size: 16px;
    }
    .examples_txt {
        font-size: 16px;
        padding-top: 45px;
    }
    .flow_contents_wrapper::before {
        width: 180px;
        top: -90px;
    }
    .flow_img {
        width: 30%;
    }
    .flow_ttl{
        font-size: 26px;
    }
    .flow_ttl_large{
        font-size: 34px;
    }
    .caution .container::before{
        width: 180px;
    }
    .caution .container::after{
        width: 200px;
    }
    .caution_warning span{
        font-size: 40px;
    }
    .caution_txt{
        font-size: 20px;
    }
    .caution_txt .large, .caution_txt .blue{
        font-size: 26px;
    }
    .caution::after{
        height: 35px;
    }
    .faq_inner::before, .faq_inner::after {
        width: 160px;
        top: -90px;
    }
    .faq_inner dt{
        font-size: 22px;
    }
    .faq_inner dd{
        font-size: 20px;
    }
}
/*===========================================================================

スマートフォン用レスポンシブ対応　ここから

===========================================================================*/
@media screen and (max-width:767px) {
    .pc{
        display: none;
    }
    .sp{
        display: block;
    }
    .container{
        max-width: 375px;
        padding-left: 15px;
        padding-right: 15px;
    }
    .header {
        position: static;
    }
    .header_logo{
        width: 150px;
    }
    .header_line{
        width: 130px;
    }
    .cta_bottom_sp {
        position: fixed;
        bottom: 0;
        z-index: 10;
        transition: .3s;
        width: 100%;
    }
    .cta_bottom_sp img{
        width: 100%;
    }
    /* .animation{
        opacity: 0;
        transition: .3s;
        transform: translate(0, 50px);
    }
    .animation.show{
        opacity: 1;
        transform: none;
    } */
    .fv{
        padding-top: 20px;
        background-image: url(../images/fv_bg_sp.jpg);
        padding-bottom: 50px;
    }
    .fv_container{
        display: block;
    }
    .fv_catchcopy{
        width: 100%;
    }
    .fv_txt {
        padding-left: 0;
        text-align: center;
        font-size: 13px;
    }
    .fv_txt span{
        font-size: 18px;
    }
    .fv_txt_cta {
        padding-bottom: 0;
        max-width: 180px;
    }
    .fv_cta {
        width: 95%;
        padding-top: 20px;
        padding-left: 0;
        margin-left: auto;
        margin-right: auto;
    }
    .fv_left {
        padding-bottom: 35px;
        padding-right: 0;
        width: 100%;
    }
    .fv_rightImg {
        max-width: 330px;
        margin-left: auto;
        margin-right: auto;
        display: block;
        width: 100%;
    }
    .achievements {
        padding-top: 20px;
        padding-bottom: 30px;
    }
    .achievements_txt span{
        font-size: 20px;
        letter-spacing: -1px;
    }
    .achievements_txt{
        font-size: 14px;
        line-height: 1.5;
    }
    .achievements_txt::before, .achievements_txt::after{
        width: 62px;
    }
    .achievements_imgarea{
        padding-top: 10px;
    }
    .achievements_img{
        width: 110px;
        padding: 0 5px;
    }
    .beforeAfter{
        border-top: 5px solid #F28315;
        padding-top: 25px;
        padding-bottom: 0;
    }
    .beforeAfter_head {
        max-width: 375px;
        margin-left: auto;
        margin-right: auto;
    }
    .beforeAfter_headTxt{
        font-size: 16px;
    }
    .beforeAfter_headTxt .large{
        font-size: 30px;
    }
    .beforeAfter_headTxt .large::after{
        width: 80px;
        height: 5px;
    }
    .beforeAfter_attractive{
        padding-right: 0;
        padding-top: 15px;
    }
    .beforeAfter_attractive figure{
        padding: 0;
        margin-right: 15px;
    }
    .beforeAfter_attractive figure:last-of-type{
        margin-right: 0;
    }
    .beforeAfter_attractive figure::after{
        width: 12px;
        height: 12px;
        bottom: 22px;
        right: -12px;
    }
    .beforeAfter_headTxt .small{
        font-size: 20px;
    }
    .beforeAfter_head::before, .beforeAfter_head::after{
        content: none;
    }
    .beforeAfter_attractive{
        padding-bottom: 10px;
    }
    .beforeAfter_contents{
        padding-top: 30px;
    }
    .uservoice_stripeBack, .userVoice_wrapper:nth-of-type(2n) .uservoice_stripeBack{
        width: 100%;
        background: none;
        padding: 0;
        margin: 0;
    }
    .uservoice_whiteBack, .userVoice_wrapper:nth-of-type(2n) .uservoice_whiteBack{
        border: none;
        border-radius: 0;
        width: calc(100% + 30px);
        margin: 0;
        margin-left: -15px;
    }
    .userVoice {
        display: block;
        padding-left: 25px;
        padding-right: 25px;
        padding-top: 105px;
        padding-bottom: 50px;
        position: relative;
        max-width: 375px;
        margin-left: auto;
        margin-right: auto;
    }
    .userVoice::after{
        position: absolute;
        content: '';
        background-image : linear-gradient(to right, #FF6400 7px, transparent 7px);
        background-size: 10px 2px;
        background-repeat: repeat-x; 
        background-position: left bottom;
        width: calc(100% - 30px);
        height: 2px;
        bottom: 0;
        left: 15px;
    }
    .userVoice_wrapper:last-of-type .userVoice::after{
        content: none;
    }
    .userVoice_right{
        display: block;
        width: 100%;
    }
    .userVoice_ttl::before{
        width: 125px;
        height: 50px;
        top: -50px;
    }
    .userVoice_left{
        width: 100%;
    }
    .userVoice_ttl{
        font-size: 20px;
        padding-bottom: 25px;
        line-height: 1.5;
    }
    .userVoice_wrapper {
        padding-top: 0;
        padding-bottom: 0;
    }
    .userVoice_person_sp{
        padding-bottom: 35px;
        margin-left: auto;
        margin-right: auto;
        width: calc(100% - 40px);
    }
    .userVoice_chart {
        max-width: 225px;
    }
    .userVoice_chart_wrapper::after{
        width: 100px;
        height: 100px;
        top: -5px;
        right: -35px;
    }
    .userVoice_txt{
        font-size: 13px;
        padding-top: 35px;
        line-height: 1.5;
    }
    .userVoice_txt .orange{
        font-size: 15px;
    }
    .userVoice_caution{
        font-size: 10px;
    }
    .benefit{
        background-image: url(../images/benefit_bg_sp.png);
        background-size: cover;
        margin-top: -30px;
        padding-top: 70px;
        padding-bottom: 30px;
    }
    .benefit_head{
        font-size: 15px;
        max-width: 320px;
        width: 100%;
        padding-top: 10px;
        padding-bottom: 15px;
        border: 2px solid #FFF9E2;
        border-bottom: none;
        top: -25px;
    }
    .benefit_head .emphasis{
        font-size: 16px;
    }
    .benefit_ttl{
        font-size: 14px;
    }
    .benefit_ttl img{
        width: 145px;
    }
    .benefit_ttl span{
        font-size: 24px;
    }
    .benefit_ttl::after{
        width: 25px;
        height: 20px;
        bottom: -30px;
    }
    
    .benefit_case,
    .benefit_case:nth-of-type(1),
    .benefit_case:nth-of-type(2),
    .benefit_case:nth-of-type(3),
    .benefit_case:nth-of-type(4){
        display: block;
        padding-top: 50px;
    }
    
    .benefit_inner{
        border: 2px solid #C60000;
        box-shadow: 3px 3px #F8EEC8;
        border-radius: 5px;
        margin-top: 0;
        padding-top: 50px;
        padding-left: 10px;
        padding-right: 10px;
        padding-bottom: 25px;
    }
    .benefit_case:nth-of-type(1) .benefit_case_head:after {
        width: 40%;
        bottom: -35px;
        right: -15px;
    }
    .benefit_case:nth-of-type(2) .benefit_case_inner{
        padding-right: 15px;
    }
    .benefit_case:nth-of-type(3) .benefit_case_inner{
        padding-left: 0;
    }
    .benefit_case:nth-of-type(1) .benefit_case_head{
        margin-bottom: -25px;
    }
    .benefit_case:nth-of-type(2) .benefit_case_head:after{
        width: 30%;
    }
    .benefit_case:nth-of-type(3) .benefit_case_head:after {
        width: 30%;
        right: 20px;
    }
    .benefit_case:nth-of-type(4) .benefit_case_head:after {
        right: -10px;
        width: 40%;
    }
    .benefit_case_num{
        width: 105px;
    }
    .benefit_case_img{
        width: 100%;
    }
    .benefit_case_illust {
        width: 110px;
    }
    .benefit_case_img, .benefit_case:nth-of-type(2) .benefit_case_img{
        width: 70%;
        margin-left: auto;
        margin-right: auto;
    }
    .benefit_case_ttl span{
        font-size: 28px;
        line-height: 1;
    }
    .benefit_case_ttl{
        font-size: 16px;
        padding-bottom: 5px;
        line-height: 1.5;
        padding-top: 10px;
    }
    .benefit_case_body {
        padding-top: 10px;
    }
    .benefit_case_txt {
        font-size: 13px;
        line-height: 1.5;
    }
    .benefit_case_inner{
        padding-left: 15px;
        padding-right: 15px;
    }
    .line{
        padding-top: 20px;
        padding-bottom: 30px;
    }
    .line_txt {
        width: 180px;
    }
    .line_container{
        display: block;
    }
    .line_link {
        margin-top: 0;
        width: 330px;
        max-width: 100%;
    }
    .annoy{
        padding-top: 60px;
        padding-bottom: 50px;
    }
    .annoy .container{
        padding-left: 10px;
        padding-right: 10px;
    }
    .annoy_txt{
        font-size: 16px;
    }
    .annoy_txt span{
        font-size: 20px;
    }
    .annoy_txt::after {
        width: 30px;
        height: 36px;
        top: -40px;
        left: 30px;
    }
    .annoy_img{
        width: 100%;
    }
    .annoy::after{
        width: 80px;
        height: 16px;
        bottom: -15px;
    }
    .solve{
        padding-top: 150px;
        padding-bottom: 80px;
    }
    .solve::after{
        height: 5%;
    }
    .solve_head{
        font-size: 16px;
        padding-right: 0;
        border: 1px solid #333;
        max-width:320px;
        padding-top: 5px;
        padding-bottom: 5px;
    }
    .solve_head img{
        width: 125px;
        padding-bottom: 5px;
    }
    .solve_head::before{
        background-image: url(../images/red_triangle_sp.png);
        width: 17px;
        height: 7px;
        bottom: -7px;
    }
    .solve_head::after{
        width: 50px;
        height: 85px;
        bottom: 60px;
        left: 0;
        right: 0;
        margin: auto;
    }
    .solve_catchcopy{
        font-size: 24px;
        padding-top: 35px;
    }
    .solve_catchcopy .orange{
        font-size: 15px;
    }
    .solve_catchcopy::before, .solve_catchcopy::after{
        width: 28px;
        height: 58px;
    }
    .solve_catchcopy::before{
        left: 0;
    }
    .solve_catchcopy::after{
        right: 0;
    }
    .solve_subtxt{
        padding-top: 35px;
        font-size: 16px;
        padding-bottom: 0;
        line-height: 2;
    }
    .solve_subtxt span{
        font-size: 19px;
    }
    .solve_txt{
        font-size: 16px;
    }
    .solve_txt .emphasis{
        font-size: 24px;
        letter-spacing: 0;
    }
    .solve_txt .orange{
        font-size: 16px;
    }
    .solve_txt .emphasis:first-of-type::before{
        width: 15px;
        height: 15px;
        top: -10px;
        left: -15px;
    }
    .solve_banner{
        margin-top: 40px;
        border: 2px solid #333;
        border-radius: 5px;
        padding-bottom: 85px;
        max-width: 350px;
    }
    .solve_banner::before{
        left: -5px;
        bottom: -2px;
    }
    .solve_banner::after{
        right: -7px;
        bottom: -2px;
    }
    .solve_baner_txt::before, .solve_baner_txt::after{
        content: none;
    }
    .solve_baner_txt{
        font-size: 16px;
        padding-top: 5px;
    }
    .solve_person01{
        width: 110px;
    }
    .solve_person02{
        width: 100px;
    }
    .solve_baner_txt img {
        width: 250px;
    }
    .solve_medals{
        width: 200px;
        bottom: -40px;
    }
    .reasons{
        background-image: none;
    }
    .reasons .container{
        padding-left: 30px;
        padding-right: 30px;
    }
    .reasons_headImg {
        width: calc(100% + 30px);
        margin-left: -15px;
    }
    .reasons_content_inner{
        flex-direction: column-reverse;
        padding-top: 25px;
    }
    .reasons_content::after {    
        width: 57px;
        height: 57px;
        top: -32px;
        left: -20px;
    }
    .reasons_ttl{
        font-size: 16px;
        padding-left: 50px;
        padding-right: 0;
        letter-spacing: 0;
        border: 1px solid #333;
        padding-top: 3px;
        padding-bottom: 3px;
        top: -25px;
        width: calc(100% + 15px);
        margin-left: -15px;
    }
    .reasons_contents_wrapper{
        padding-top: 55px;
        padding-bottom: 55px;
        padding-left: 0;
        padding-right: 0;
    }
    .reasons_content{
        border: 2px solid #333;
        border-radius: 5px;
        margin-bottom: 85px;
        box-shadow: 10px 10px 0 #FFED00, 8px 11px 0 1px #333, 12px 12px 0 #333;
    }
    .reasons_txt{
        padding-right: 0;
        padding-top: 20px;
        font-size: 13px;
    }
    .reasons_img{
        margin-bottom: 0;
        max-width: 100%;
        width: 100%;
    }
    .reasons_txt .emphasis {
        font-size: 16px;
        margin-right: 0;
        text-align: center;
        display: block;
    }
    .line_txt02{
        width: 290px;
    }
    .examples{
        padding-top: 40px;
        padding-bottom: 45px;
    }
    .examples_headTxt{
        font-size: 16px;
    }
    .examples_headTxt .small{
        font-size: 16px;
    }
    .examples_headTxt .emphasis::after{
        width: 100px;
    }
    .examples_headTxt .emphasis{
        font-size: 20px;
    }
    .examples_headTxt .emphasis::after{
        width: 174px;
        height: 9px;
    }
    .examples_contents_wrapper{
        display: block;
        padding-top: 50px;
    }
    .examples_content{
        max-width: 250px;
        margin-right: auto;
        margin-left: auto;
        margin-bottom: 45px;
    }
    .examples_content:nth-of-type(3n){
        margin-right: auto;
        margin-bottom: 0;
    }
    .examples_headTxt::after {
        right: 20px;
        width: 50px;
        top: -40px;
    }
    .examples_ttl{
        font-size: 16px;
    }
    .examples_txtarea {
        padding-right: 20px;
        padding-left: 20px;
    
    }
    .examples_income{
        max-width: 130px;
    }
    .examples_company{
        font-size: 13px;
        padding-top: 0;
    }
    .examples_txt {
        font-size: 13px;
        padding-top: 40px;
        line-height: 1.5;
    }
    .flow{
        padding-top: 170px;
        padding-bottom: 70px;
    }
    .flow_headTxt{
        font-size: 30px;
        letter-spacing: 0;
    }
    .flow_content{
        flex-direction: column-reverse;
        border: 1px solid #333;
        border-radius:4px;
        max-width: 325px;
        margin-top: 80px;
        padding-top: 40px;
        padding-right: 10px;
        padding-left: 10px;
        padding-bottom: 20px;
    }
    .flow_contents_wrapper{
        padding-top: 0;
    }
    .flow_contents_wrapper::before{
        left: 0;
        right: 0;
        margin:auto;
        width: 177px;
        height: 106px;
        top: -280px;
    }
    .flow_headTxt::before {
        width: 190px;
    }
    .flow_headTxt::after {
        width: 325px;
        height: 95px;
        top: -10px;
    }
    .flow_content::after{
        width: 70px;
        height: 70px;
        top: -35px;
    }
    .flow_img {
        width: 120px;
    }
    .flow_ttl{
        font-size: 18px;
        display: inline-block;
    }
    .flow_ttl_large{
        font-size: 24px;
    }
    .flow_txtarea{
        padding-right: 0;
        padding-top: 20px;
        text-align: center;
        padding-bottom: 0;
    }
    .flow_content:nth-of-type(3) .flow_txtarea{
        padding-right: 0;
    }
    .flow_txt {
        padding-top: 5px;
        font-size: 13px;
        letter-spacing: 0;
    }
    .flow_ttl .green::before, .flow_ttl .orange_accessory::before{
        width: 15px;
        height: 15px;
        top: -5px;
        left: -15px;
    }
    .flow_delight{
        padding-top: 30px;
    }
    .caution{
        padding-bottom: 40px;
    }
    .caution::after {
        background: repeating-linear-gradient(147deg, #333, #333 10px, transparent 10px, transparent 20px);
        height: 10px;
    }
    .caution_icon {
        width: 55px;
    }
    .caution .container::before {
        width: 99px;
        height: 71px;
        top: 35px;
        left: -10px;
    }
    .caution .container::after {
        width: 100px;
        height: 60px;
        right: 13px;
        top: 150px;
    }
    .caution_headTxt{
        font-size: 20px;
        padding-bottom: 20px;
    }
    .caution_warning span{
        font-size: 24px;
    }
    .caution_txt{
        font-size: 16px;
        line-height: 1.5;
    }
    .caution_txt .blue, .caution_txt .large{
        font-size: 16px;
    }
    .caution_txt img{
        width: 150px;
    }
    .caution_warning{
        padding-bottom: 0;
    }
    .faq{
        padding-top: 100px;
        padding-bottom: 45px;
    }
    .faq_headTxt{
        font-size: 30px;
    }
    .faq_inner::before, .faq_inner::after{
        width: 100px;
        height: 60px;
    }
    .faq_inner::before {
        left: 0px;
        top: -140px;
    }
    .faq_inner::after {
        right: 0px;
        top: 20px;
    }
    .faq_headTxt::after{
        width: 248px;
        height: 100px;
        top: -25px;
    }
    .faq_inner dl{
        border: 1px solid #333;
        border-radius: 5px;
        margin-top: 30px;
    }
    .faq_inner dt{
        font-size: 16px;
        padding-top: 5px;
        padding-bottom: 6px;
        padding-right: 10px;
        padding-left: 65px;
        border-radius: 4px 4px 0 0;
    }
    .faq_inner dd{
        font-size: 13px;
        height: 70px;
        padding-left: 65px;
        border-radius: 0 0 4px 4px;
    }
    .faq_inner dt::before, .faq_inner dd::before{
        width: 23px;
        height: 23px;
        left: 27px;
    }
    .faq_inner{
        padding-top: 75px;
        max-width: 330px;
    }
    .footer{
        padding-top: 30px;
        padding-bottom: 25%;
    }
    .footer_logo {
        width: 200px;
    }
    .footer_btnarea{
        padding-top: 20px;
    }
    .footer_btnarea a{
        font-size: 13px;
        padding: 3px 0;
    }
}