body {
    width: 100%;
    font-family: "Noto Sans JP", serif;
    font-optical-sizing: auto;
}
/* hidden  */

@media (width > 981px )  {
    .hidden-pc{
        display: none;
    }
    .hidden-sp{
        display: block;
    }
    }
@media (width < 980px){
    .hidden-pc{
        display: block;
    }
    .hidden-sp{
        display: none;
    }
}
/* header mainvisual*/
.header-content{
    width: 100%;
    background-color: var(--shikin-0290);
}
header{
    max-width: 1440px;
    height: 770px;
    margin-inline:auto ;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-image: url(../img/mainvisual.png);
    padding-top: 32px;
    box-sizing: border-box;
}
    header.thanks{
        background-image: none;
        height: 96px;
        margin-bottom: 80px;
    }
    @media (width < 1440px){
    }
    .header-inner {
        max-width: 1280px;
        width: 88%;
        margin-inline: auto;
    }
    h1 {
        color: var(--shikin-0140);
        font-size: 28px;
        font-weight: 900;
    }
        .head-br{
            display: none;
        }
        @media (width < 980px){
            .head-br{
                display: block;
            }
        }
        header .catch {
            max-width: 990px;
            width: 88%;
            margin-inline: auto;
            margin-top: 96px;
        }
        header .catch p.txt{
            font-weight: 700;
            color: var(--shikin-bk20);
            font-size: 24px;
            margin-bottom: 8px;
        }
            header .catch p.txt span{
                background: linear-gradient(transparent 70%, var(--shikin-0390) 70%);
            }
        header .catch h2{
            font-weight: 900;
            font-size: 48px;
            color: var(--shikin-0140);
            margin-bottom: 16px;
        }
        header .catch h2 span.small{
            font-size: 38px;
            color: var(--shikin-bk20);
        }
        header .appeal{
            width: 327px;
            height: 148px;
            background-color: #ffffff;
            border-radius: 8px;
            border: 2px solid;
            padding: 12px;
            box-sizing: border-box;
            border-color: var(--shikin-0140);
            position: relative;
            z-index: 9998;
        }
        header .appeal .head{
            width: 100%;
            font-weight: 900;
            color: var(--shikin-0570);
            font-size: 32px;
            text-align:justify;
            text-align-last:justify;
            white-space: nowrap;
            border-bottom: 2px solid var(--shikin-0180);
            padding-bottom: 8px;
        }
        header .appeal .txt{
            font-weight: 900;
            color: var(--shikin-bk20);
            font-size: 28px;
            letter-spacing: 0;
            white-space: nowrap;
            text-align:justify;
            text-align-last:justify;
            margin-top: 8px;
            line-height: 140%;
        }
        header .appeal .txt span.num{
            font-size: 50px;
            white-space: nowrap;
            font-weight: 900;
            color: var(--shikin-red);
            letter-spacing: 0;
            vertical-align: sub;
            
        }
        header .appeal .txt span.strong{
            font-weight: 900;
            color: var(--shikin-red);
            font-size: 40px;
            white-space: nowrap;
            display: inline-block;
            padding: 5px 5px 8px 5px;
            background:var(--shikin-0390);
        }
        /* 点滅 */
        .blinking{
            -webkit-animation:blink 0.6s ease-in-out infinite alternate;
            -moz-animation:blink 0.6s ease-in-out infinite alternate;
            animation:blink 0.6s ease-in-out infinite alternate;
        }
        @-webkit-keyframes blink{
            0% {opacity:0.4;}
            20% {opacity:0.4;}
            100% {opacity:1;}
        }
        @-moz-keyframes blink{
            0% {opacity:0.4;}
            20% {opacity:0.4;}
            100% {opacity:1;}
        }
        @keyframes blink{
            0% {opacity:0.4;}
            20% {opacity:0.4;}
            100% {opacity:1;}
        }
        

        
        
.onayami {
    width: 100%;
    background-color: var(--shikin-0290);
    margin: 0px auto;
    position: relative;
    padding-bottom: 80px;
    padding-top: 114px;
    margin-bottom: 80px;
}
    .onayami::after {
        content: '';
        position: absolute;
        bottom: -20px; /* 三角形の突き出し位置 */
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        border-left: 20px solid transparent;
        border-right: 20px solid transparent;
        border-top: 30px solid #d9e6e0; /* 同じ背景色 */
    }
    .onayami-inner{
        width: 88%;
        max-width: 1280px;
        margin-inline: auto;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
        @media (width < 1100px){ 
            .onayami-inner{
                margin-top: 40px;
            }
        }
    .onayami-header{
        display: block;
        width: 33%;
        }
        .onayami-header h3{
            font-size: clamp(3rem, 1.845rem + 1.88vw, 4.2rem);
            color: var(--shikin-0120);
            font-weight: 700;
            line-height: 140%;
        }
        .onayami-header h3 span.title{
            font-size: clamp(2rem, 1.23rem + 1.26vw, 2.8rem);
            border-bottom: 2px dashed var(--shikin-bk50);
        }
        .onayami-header h3 span.basetxt{
            font-size: 18px;
        }
    .onayami-ill{
        display: block;
        width: 24%;
        text-align: center;
    }
        @media (width < 1100px){ 
            .onayami-ill{
                width: 30%;
            }
        }
    .onayami-list{
        display: block;
        width: 33%;
        box-sizing: border-box;
        padding-left: 2%;
    }
        .onayami-list p {
            font-size: 20px;
            font-weight: 700;
            margin-bottom: 8px;
        }
        .onayami-list li {
            position: relative;
            font-size: clamp(1.8rem, 1.607rem + 0.31vw, 2rem);
            font-weight: 700;
            line-height: 180%;
            padding-left: 33px;
            margin-bottom: 8px;
        }
            @media (width < 1100px){ 
                .onayami-list li {
                    line-height: 160%;
                }
            }
            .onayami-list li::before {
                content: '';
                position: absolute;
                left: 0;
                top: 50%;
                transform: translateY(-50%);
                width: 24px;
                height: 28px;
                background-image: url('../img/icon-good.svg'); 
                background-size: cover; 
                background-repeat: no-repeat;
        }
        @media (width < 980px){ 
            .onayami-inner{
                flex-wrap: wrap;
                }
                .onayami-header{
                    width: 100%;
                    margin-bottom: 32px;
                    text-align: center;
                    }
                    .onayami-ill{
                        width: 46%;
                        box-sizing: border-box;
                        padding-left: 4%;
                        padding-right: 4%;
                    }
                    .onayami-list{
                        width: 54%;
                        padding-left: 8%;
                    }
                    .onayami-list li {
                        line-height: 180%;
                    }
        }
        
.about-us{
    max-width: 1126px;
    width: 88%;
    margin-inline: auto;
    margin-bottom: 80px;
}
    .about-us h3 {
        font-size: 32px;
        color: var(--shikin-bk20);
        font-weight: 900;
        text-align: center;
        margin-bottom: 80px;
    }
        .about-us h3 span.first{
        }
        .about-us h3 span.title{
            color: var(--shikin-0120);
            border-bottom: 2px dashed var(--shikin-bk50);
            font-size: 42px;
        }
        .about-us h3 span.basetxt{
            font-size: 32px;
        }
    .about-us-content{
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        margin-bottom: 80px;
    }
        .about-us-content .txt{
            width: 50%;
            padding-right: 40px;
        }
        .about-us-content .txt p.title{
            font-size: 20px;
            color: var(--shikin-0160);
            font-weight: 700;
        }
        .about-us-content .txt h4{
            font-size: clamp(2.8rem, 2.519rem + 0.86vw, 3.6rem);
            color: var(--shikin-0140);
            font-weight: 700;
            margin-bottom: 24px;
        }
        .about-us-content .txt ul {
            margin-bottom: 8px;
            }
            .about-us-content .txt ul li{
                font-size: 18px;
                font-weight: 700;
                line-height: 180%;
            }

        .about-us-content .txt p{
            font-size: 18px;
            line-height: 180%;
        }
        .about-us-content .img{
            width: 50%;
        }
    .about-ill{
        margin-inline:auto;
    }        
    @media (width < 980px){ 
        .about-us h3{
            margin-bottom: 40px;
        }
        .about-us-content{
            display: block;
        }
        .about-us-content .txt{
            width: 100%;
            padding-right: 0px;
            margin-bottom: 40px;
        }
        .about-us-content .txt ul li{
            font-size: clamp(1.6rem, 1.374rem + 0.7vw, 1.8rem);
        }
        .about-us-content .img{
            width: 100%;
        }
    }    

    .case{
        width: 100%;
        background-color: #FFF9EC;
        padding-top: 80px;
        padding-bottom: 80px;
        margin-bottom: 80px;
    }
        .case .head{
            text-align: center;
            margin-bottom: 32px;
        }
            .case .head h3{
                color: var(--shikin-0440);
                font-size: 42px;
                font-weight: 900;
            }
            .case .head p{
                color: var(--shikin-bk10);
                font-size: 16px;
            }
        .case-container{
            display: flex;
            align-items:flex-start;
            justify-content: space-between;
            max-width: 1126px;
            width: 100%;
            margin-inline:auto;
            }
            .case-container .case-box{
                width: 32%;
                box-sizing: border-box;
                padding: 26px;
                background-color: #FFF;
            }
            .case-container .case-box .img{
                margin-bottom: 8px;
            }
                .case-container .case-box .txt h4{
                    color: var(--shikin-0440);
                    font-size: 20px;
                    font-weight: 700;
                    margin-bottom: 12px;
                }
                .case-container .case-box .txt p{
                    font-size: clamp(1.4rem, 1.33rem + 0.22vw, 1.6rem);
                    color: var(--shikin-bk20);
                }
                .swiper{
                    width: 88%;
                    max-width: 1126px;
                    margin-inline: auto;
                }
                .swiper:not(.swiper-initialized) .swiper-button-prev,
                .swiper:not(.swiper-initialized) .swiper-button-next {
                  display: none;
                }
                @media (width < 980px) {
                    .case .head{
                        width: 88%;
                        margin-inline:auto;
                    }
                    
                }

    .company {
        width: 88%;
        max-width: 766px;
        margin-inline:auto;
        margin-bottom: 80px;
    }
        .company h3{
            font-size: 32px;
            color: var(--shikin-0120);
            text-align: center;
            font-weight: 900;
            margin-bottom: 32px;
        }
            .company .company-content dl{
                display: flex;
                align-items: center;
                justify-content: flex-start;
                border-bottom: 1px solid #999;
                padding-top: 32px;
                padding-bottom: 32px;
            }
                .company .company-content dt{
                    width: 38%;
                    color: var(--shikin-0150);
                    box-sizing: border-box;
                    padding-left: 16px;
                    font-weight: 700;
                }
                .company .company-content dd{
                    width: 62%;
                }

    footer {
        width: 100%;
        background-color: var(--shikin-0120);
        color: #FFF;
        text-align: center;
        padding-top: 64px;
        padding-bottom: 64px;
    }
       footer h5{
            font-size: 18px;
            margin-bottom: 8px;
            font-weight: 700;
       }
       footer p{
        font-size: 12px;
       }


    .goto-CTA{
        position: absolute;
        max-width: 880px;
        width: 88%;
        height: 260px;
        top: 600px;
        left: 50%;
        margin-inline:auto;
        transform: translateX(-50%);
        background-color: #ffffff;
        border-radius: 12px;
        border: 4px solid;
        border-color: var(--shikin-0570);
        box-shadow: 2px 2px 20px  rgba(0, 0, 0, 0.35);
        text-align: center;
        box-sizing: border-box;
        padding: 20px;
        z-index: 9999;
    }
        .goto-CTA .head{
            margin-bottom: 8px;

        }
            .goto-CTA .head h3{
                font-size: 28px;
                font-weight: 900;
            }
            .goto-CTA .head h3 span.num{
                color: var(--shikin-red);
                font-size: clamp(4.6rem, 3.696rem + 2.78vw, 5.4rem);
            }
            .goto-CTA .head h3 span.kanryo{
                font-size: 32px;
                color: var(--shikin-0570);
            }
            .goto-CTA .head p{
                font-size: clamp(1.6rem, 1.374rem + 0.7vw, 1.8rem);
                font-weight: 700;
                color: var(--shikin-bk20);
                line-height: 140%;
            }
        a.btn-gotocta{
            background-color: var(--shikin-0140);
            display: block;
            width: 90%;
            max-width: 554px;
            height: 96px;
            border-radius: 48px;
            margin-inline: auto;
            display: flex;
            align-items: center;
            justify-content: center;
            box-shadow: 2px 2px 10px  rgba(0, 0, 0, 0.35);
        }
        a.btn-gotocta img{
            padding-right: 8px;
            width: 48px;
        }
        a.btn-gotocta div{
            font-size: 32px;
            color: #FFF;
            font-weight: 700;
        }
        @media (width < 980px){
            a.btn-gotocta{
                height: 80px;
                
            }
            a.btn-gotocta div{
                font-size: 28px;
            }
        }

@media (width < 520px){
/* header mainvisual*/
body{
    padding-bottom: 188px;
}
header{
    width: 100%;
    max-width: 100%;
    height: 700px;
    margin-inline:auto ;
    background-size: cover;
    background-position: top center;
    background-image: url(../img/mainvisual-sp.png);
    padding-top: 16px;
}
    h1 {
        font-size: 24px;
    }
    .header-inner {
        width: 88%;
    }
        header .catch {
            width: 88%;
            margin-top: 320px;
        }
        header .catch p.txt{
            font-size: 20px;
            margin-bottom: 0px;
        }
            header .catch p.txt span{
            }
            header .catch h2{
                font-weight: 900;
                font-size: 40px;
                margin-bottom: 28px;
            }
            header .catch h2 span.small{
                font-size: 26px;
            }
            header .appeal{
                width: 84%;
                margin-inline:auto;
                height: auto;
                padding: 16px;
            }
                header .appeal .head{
                }
                header .appeal .txt{
                    font-weight: 900;
                    color: var(--shikin-bk20);
                    font-size: 28px;
                    letter-spacing: 0;
                    white-space: nowrap;
                    text-align:justify;
                    text-align-last:justify;
                    margin-top: 8px;
                    line-height: 140%;
                }
                header .appeal .txt span.num{
                    font-size: 50px;
                    white-space: nowrap;
                    font-weight: 900;
                    color: var(--shikin-red);
                    letter-spacing: 0;
                    vertical-align: sub;
                    
                }
                header .appeal .txt span.strong{
                    font-weight: 900;
                    color: var(--shikin-red);
                    font-size: 40px;
                    white-space: nowrap;
                    display: inline-block;
                    padding: 5px;
                    background:var(--shikin-0390);
                }

.onayami {
    width: 100%;
    margin-inline: auto;
    position: relative;
    padding-top: 80px;
    padding-bottom: 32px;
    margin-bottom: 32px;
}
    .onayami-inner{
        width: 88%;
        display: block;
    }
    .onayami-header{
        display: block;
        width: 100%;
        }
        .onayami-header h3{
            font-size: 28px;
        }
        .onayami-header h3 span.title{
            font-size: 20px;
        }
        .onayami-header h3 span.basetxt{
            font-size: 20px;
        }
    .onayami-ill{
        display: block;
        width: 70%;
        margin-inline: auto;
        text-align: center;
        margin-bottom: 16px;
    }
    .onayami-list{
        display: block;
        width: 100%;
        box-sizing: border-box;
        padding-left: 2%;
    }
    .onayami-list li {
        position: relative;
        font-size: 20px;
        font-weight: 700;
        line-height: 180%;
    }
    .onayami-list li::before {
        width: 22px;
        height: 26px;
    }

    .about-us{
        width: 88%;
        margin-inline: auto;
        margin-bottom: 40px;
    }
        .about-us h3 {
            font-size: 20px;
            line-height: 160%;
            margin-bottom: 16px
        }
            .about-us h3 span.title{
                font-size: 28px;
            }
            .about-us h3 span.basetxt{
                font-size: 20px;
            }
        .about-us-content{
            display: block;
            margin-bottom: 80px;
        }
            .about-us-content .txt{
                width: 100%;
                padding-right: 0px;
                margin-bottom: 16px;
            }
            .about-us-content .txt ul li{
                font-size: 18px;
                line-height: 160%;
            }
            .about-us-content .txt p{
                font-size: 18px;
                line-height: 160%;
            }
            .about-us-content .txt p.title {
                font-size: 18px;
            }
            .about-us-content .txt h4 {
                font-size: 28px;
                margin-bottom: 16px;
            }
            .about-us-content .img{
                width: 100%;
            }
            .about-us-content .txt ul li{
                font-size: 16px;
            }
            .about-us-content .txt p{
                font-size: 16px;
            }
        .about-ill{
            margin-inline:auto;
        }          

    .case{
        padding-top: 40px;
        padding-bottom: 40px;
        margin-bottom: 40px;
        }
        .case .head{
            width: 88%;
            margin-inline:auto;
        }
            .case .head h3{
                font-size: 32px;
            }
            .case .head p{
                font-size: 16px;
            }
        .case-container{
            display: flex;
            align-items:flex-start;
            justify-content: space-between;
            width: 100%;
            margin-inline:auto;
            }
            .case-container .case-box{
                box-sizing: border-box;
                padding: 26px;
                background-color: #FFF;
            }
            .case-container .case-box .img{
                margin-bottom: 12px;
            }
                .case-container .case-box .txt h4{
                    font-size: 20px;
                    margin-bottom: 8px;
                }
                .case-container .case-box .txt p{
                    font-size: 16px;
                    color: var(--shikin-bk20);
                }
                .swiper{
                    width: 100%;
                    margin-inline: auto;
                }
                    .swiper--wrapper {
                        width: 100%;
                        height: auto;
                    }
                    .swiper-slide {
                        width: 100%;
                    }
                    
    .company {
        width: 88%;
        margin-inline:auto;
    }   
        .company h3{
            margin-bottom: 0px;
        }
    footer {
        padding-top: 32px;
        padding-bottom: 32px;
    }
    .goto-CTA{
        position: fixed;
        width: 100%;
        height: 180px;
        bottom: 0px;
        padding: 8px 16px;
        top: inherit;
    }
        .goto-CTA .head{
        }
            .goto-CTA .head h3{
                font-size: 20px;
                font-weight: 900;
            }
            .goto-CTA .head h3 span.num{
                font-size: 32px;
            }
            .goto-CTA .head h3 span.kanryo{
                font-size: 28px;
            }
            .goto-CTA .head p{
                font-size: 14px;
                line-height: 140%;
            }
        a.btn-gotocta{
            display: block;
            width: 94%;
            height: 56px;
            border-radius: 28px;
            margin-inline: auto;
            display: flex;
            align-items: center;
            justify-content: center;
            box-shadow: 2px 2px 10px  rgba(0, 0, 0, 0.35);
        }
        a.btn-gotocta img{
            padding-right: 8px;
            width: 32px;
        }
        a.btn-gotocta div{
            font-size: 24px;
        }
}
    



/* form */
.six-wra{
    max-width: 766px;
    width: 88%;
    margin-inline: auto;
    margin-bottom: 80px;
    background-color: #FFF;
}
.cta-but-anc {
	background-color:var(--shikin-0140);
	box-shadow: 0px 6px 0px 0px var(--shikin-0120);
}
.cta-but-anc:hover {
	box-shadow: 0px 0px 0px 0px var(--shikin-0120);
}
.cta-cap-blo{
    font-size: 3.2rem;
    color: var(--shikin-0120);
}
.cta-sla-bac{
    color: var(--shikin-0140);
}
.cta-sla{
    color: var(--shikin-0140);
    font-size: 3.2rem;
}
h2.sec-tit-sho-bot{
    text-align: center;
    font-size: 3.8rem;
}
.cta-cap-belt{
    font-size: 3.2rem;
}
.dat-lis dt{
    font-size: 2.0rem;
}
input[type="text"], input[type="email"], input[type="tel"], input[type="url"] {
    font-size: 2.0rem;
}
select{
    font-size: 2.0rem;
    border: 1px solid #999;
    padding-right: 8px;
}
.dat-lis{
    border-color: #FFF;
}
.cta-but-anc{
    font-size: 2.0rem;
    padding-top: 14px;
}
form#mailformpro .mfp_buttons .but-inp, .mfp_element_reset, .mfp_element_button, button.mfp_next, button.mfp_prev{
	background-color:var(--shikin-0140);
}
form#mailformpro .mfp_buttons .but-inp:hover, .mfp_element_reset:hover, .mfp_element_button:hover, button.mfp_next:hover, button.mfp_prev:hover {
	background-color:var(--shikin-0180);
	
}
.fon-lar{
    font-size: 2.4rem;
}

.google-recap {
    display: flex;
    align-items: center;
    justify-content: center;
}
@media (width < 520px){
    .dat-lis{
        display: block;
        width: 100%;
    }
    .dat-lis dt{
        width: 100%;
        justify-content: flex-start;
        padding-left: 0px;
    }
    .ico-mus{
        margin-left: 8px;
    }
    .dat-lis dd{
        width: 100%;
        padding-left: 0px;
    }
    .cta-but-anc{
        min-width: 100%;
        max-width: 100%;
    }
    form#mailformpro label{
        padding-right: 42px;
    }
    .cta-ban{
        max-width: 88%;
        padding-left: 0px;
        padding-right: 0px;
        display: block;
    }
}

/* privacy */
.pp-blo > h3{
    font-size: 2.0rem;
}
.pp-blo > ul > li{
    font-size: 1.6rem;
}

/* swiper　*/
.swiper-button-prev,
.swiper-button-next {
    height: 50px;
    width: 50px;
}
    .swiper-button-prev::after,
    .swiper-button-next::after {
        background-repeat: no-repeat;
        background-size: contain;
        content: "";
        height: 50px;
        margin: auto;
        width: 50px;
    }
    .swiper-button-prev::after {
        background-image: url(img/arrow-left.png);
    }
    .swiper-button-next::after {
        background-image: url(img/arrow-right.png);
    }
    .swiper-slide img {
    height: auto;
    width: 100%;
    }

