

@media screen and (max-width: 640px){

/* 
======================

spheader

======================
 */






 /* 
======================

common

====================== 
*/

.box{
    padding: 15% 0;
}
    

 body{
    line-height: 1.4rem;
 }
    
 .pc{
    display: none;
 }

 .sp{
    display: block!important;
 }

 .spbr{
    display: block;
 }


.box-sub{
    padding: 10% 0;
}




/* ===========cta固定表示=============== */
.cta-fixed {
    position: fixed;
    bottom: 0;
    left: 0;
    background: rgba(255,255,255,1);
    z-index: 100000;
    padding: 3%;
}

.cta-fixed img {
    width: 100%;
}

.cta-fixed li:first-child {
    margin-right: 2%;
}

.foot-list {
    display: flex;
    width: 100%;
}


 /* ===========pagetopへ戻る=============== */


.pagetop {
    bottom: 18%;
}





/* 
======================

header

======================
 */


 header{
    position: fixed;
    width: 100%;
    z-index: 10000;
}



 .header-top{
    background-color: var(--accent-color);
    color: #fff;
    text-align: center;
    font-size: var(--font-d);
    line-height: 1rem;
    padding: 1%;
}


.spnav {
    width: 100%;
}


.navwrap__sp {
    display: block;
}

.pcnav {
    display: none;
}


/* 
======================

main

======================
 */



/* 
======================

head

======================
 */


 .head{
    background: #d4ebf2 url(../img/hero_back.png) no-repeat 10% 0% / 230%;
    padding-top: 120px;
 }

 .wrap {
    width: 95%;
 }


 .head-bottom-list{
    align-items: stretch;
 }

 .head-bottom-list-item > div {
    padding: 20% 0 10% 0;
    font-size: var(--font-bs);
 }

 .head-bottom-list-item:before {
    height: 35px;
    top: -20px;
    left: -1px;
}

.head-bottom-list-item {
    padding: 1%;
}

.head-bottom{
    padding: 10% 0 6% 0;
}

.head-bottom-list-item p {
    font-size: 70%;
    letter-spacing: 0.5px;
    line-height: 150%;
}


/* 
======================

problem

======================
 */

 .problem-title-h2{
    width: 100%;
    min-width: 100%;
 }
 

 .problem-title-ex{
    padding: 2%;
    margin-bottom: 8%;
    width: 80%;
 }

 .problem-box-list{
    background: #fff;
    border-radius: 10px;
    width: 100%;
    padding: 8%;
 }

 .problem-box-list > li {
    background-color: transparent;
    border-radius: 0;
    padding: 5% 0;
    border-bottom: 1px dotted var(--back-sub-color);
    font-size: var(--font-bs);;
 }

 .problem-box-list > li:nth-child(2n){
    margin: 0;
 }

 .problem-box-img{
    background: url(../img/problem_.img_sp.png) no-repeat center/ contain;
    width: 100%;
    height: clamp(9.375rem, 6.648rem + 13.64vw, 16.875rem);
    margin-top: 10px;
}

.problem-etc {
padding: 3% 5% 5%!important;
border-bottom: none!important;
}


/* 
======================

merit

======================
 */

 .merit-box::before{
    height:clamp(3.125rem, 1.989rem + 5.68vw, 6.25rem);
    top: clamp(-3.125rem, -3.693rem + 2.84vw, -1.563rem);
}

.merit-box-list >li{
    text-align: center;
    background: #FFF url(../img/check.png) no-repeat 50% 10% / 8%;
    padding: 13% 5% 8% 5%;
    padding-top: 13%;
    font-size: var(--font-bs);
}

.merit-box-list >li:nth-child(2n) {
    margin: 5% 0;
}

/* 
======================

cost

======================
 */

.costtable {
    overflow: hidden;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
 }

 .costtable::-webkit-scrollbar-thumb {
    background: #7a7a7a;
    border-radius: 20px;
 }

 .costtable::-webkit-scrollbar {
    width: 20px;
    height: 20px;
 }

 .costtable::-webkit-scrollbar-track {
    background: #cecece;
    border-radius: 20px;
 }

 .cost img {
    width: 550px;
 }



/* 
======================

reason

======================
 */


 .ri1::before{
    left: -10px;
 }

 .reason-title-ex{
    font-size: var(--font-bs);
 }

.reason-list{
    flex-direction: column;
}

.reason-list-items {
    width: 100%;
    margin: 15% auto;
}

.reason-list-items::before{
    height: 100px;
}


/* 
======================

cta

======================
 */
 
.cta {
    background: var(--accent-sub-color) url(../img/cta_back.jpg) no-repeat bottom/ 450%;
}

.cta-top {
    padding: 5% 16% 5% 8%;
    border-radius: 30px;
    font-size: var(--font-bs);
    text-align: left;
    width: 100%;
    margin-right: 0;
    margin-bottom: 40px;
    display: block;
}

.cta-center{
    background: transparent;
    height: auto;
}

.cta-center-text{
    display: block;
    background:url(../img/cta_img_sp.png) no-repeat center/ contain;
    width: 100%;
    height: clamp(5.625rem, 4.375rem + 6.25vw, 6.875rem); 
}

.cta-center-white{
    width: 100%;
    position: relative;
    margin: 0 auto 6%;
    padding: clamp(0.625rem, 3.13vw, 1.25rem);
}


.cta-center-white::before{
    content:"";
    position: absolute;
    background: url(../img/cta_img2.png) no-repeat center/ contain;
    width:100px;
    height: 120px;
    top: -118px;
    right:0;
}

.cta-sp {
    display: block;
}

.cta-sp img {
    display: block;
    width: 100%;
    text-align: center;
    margin: 0 auto;
}

.cta-list2 {
    width: 95%;
}

.cta-box {
    flex-direction: column;
    margin: 4% auto 0 auto;
}

.cta-box a:first-child {
    margin: 0 auto 2% auto;
}


/* 
======================

solution

======================
 */



 .solution-title-h2{
    background: var(--accent-color) url(../img/way_title.png) no-repeat 7% center / 30px;
    width: 100%;
    margin-bottom: 10%;
    padding-left: 50px;
 }

 .solution-item {
    font-size: var(--font-bs);
 }

 .solution-item-text {
    background: #fff;
    padding: 6%;
    font-size: var(--font-bs);
    font-weight: bold;
    line-height: 2rem;
}

.solution-items-top{
    font-size: clamp(1.375rem, 1rem + 1.88vw, 1.75rem);
    padding: 5% 5% 5% 20%;
    flex-direction: column;
    align-items: center;
    /* background-position: 8% center; */
    background-size: 10%;
}

.price{
    margin-top: 10px;
}


/* 
======================

voice

======================


 */

 .voice-box {
    margin-bottom: 15%;
}

.voice-box-top{
    flex-direction: column;
}


.voice-box-bottom{
    font-size: var(--font-bs);
    line-height: 2rem;
}

.client {
    width: 100%;
}

.client > p {
    font-size: var(--font-bs);
    padding: clamp(0.625rem, 3.13vw, 1.25rem) 0;
}


.client-img {
    height:clamp(9.375rem, 6.25rem + 15.63vw, 12.5rem);
}



.client-detail {
    height: clamp(9.375rem, 3.125rem + 31.25vw, 15.625rem);
}

.voice-box::before {
    width: 20%;
    height: 20%;
    top: -50px;
}


.vbc{
    margin-bottom: 0;
}






/* 
======================

flow

======================
 */



 .flow-box{
    flex-direction: column;
 }

 .flow-img,
 .flow-content{
    width: 100%;
 }

 .flow-img{
    margin-bottom: 6px;
 }

 .flow-content{
    text-align: center;
    padding: 5%;
 }

 .flow-content-top{
    flex-direction: column;
    margin: 0;
 }


 .flow-top-step {
    margin-right: 0;
    width: 100%;
    text-align: center;
 }

 .flow-top-title{
 margin: 20px 0;
}


.arrow {
    border-right: 50px solid transparent;
    border-left: 50px solid transparent;
    border-top: 30px solid #e5b908;
    margin: 8% auto;

}


/* 
======================

faq

======================
 */


.accordion-title:before,
.accordion-title:after{
    right: 5px;
}


  
/* 
======================

form

====================== 
*/


.form-tr {
    flex-direction: column;
    margin-bottom: 8%;
}

.form-tr > th {
 margin-bottom: 10px;
}

 .submit-btn {
    padding: 6% 3%;
    width: 100%;
    font-size: 1.2rem;
}

.privacy{
    font-size: .8rem;
    line-height: 1.2rem;
}


/* 
======================

footer

====================== 
*/


footer {
    margin-bottom: 26%;
}

.footer-box{
    text-align: center;
}
.footer-top{
    font-size: var(--font-d);
    line-height: 1.4rem;
    margin: 8% 0;
}

.footer-middle{
    font-size: var(--font-d);
    line-height: 1.4rem;
    margin-bottom: 8%;
}

.footer-bottom{
    font-size: .7rem;
    line-height: 1rem;
}

}



@media screen and (max-width: 476px){

    .hamburger{
        top: 50%;
    }

}
