*{
    font-family: "Noto Sans JP", sans-serif;
    text-align: center;
}
body{
    -webkit-text-size-adjust: 100%;
}
li{
    list-style: none;
}
a{
    text-decoration: none;
}
img{
    max-width: 100%;
    height: 100%;
    vertical-align: bottom;
}
.bold{
    font-weight: bold;
}
.line{
    position: relative;
}
.line::after{
    background: #FFF034;
    bottom: 0;
    content: "";
    height: 80%;
    left: 0;
    position: absolute;
    width: 100%;
    z-index: -1;
}
.red{
    color: red;
}
.sp{
    display: none;
}

/* header-------------------------------------------- */
header{
    display: flex;
    margin-bottom: 100px;
}
.main-text{
    background-color: #55C3F1;
    padding-top: 100px;
    width: 50%;
}
.text-wrapper{
    background-color: #ffffff;
    color: #0096FF;
    padding: 40px 10px;
    position: relative;
}
.text-wrapper::before,
.text-wrapper::after{
    background: #ffffff;
    content: "";
    height: 5px;
    left: 0;
    position: absolute;
    width: 100%;
    z-index: 10;
}
.text-wrapper::before{
    top: -16px;
}
.text-wrapper::after{
    bottom: -18px;
}
.text-wrapper h2{
    font-size: 24px;
}
.main-visual{
    width: 50%;
    
}
.main-visual img{
    object-fit: cover;
    object-position: center;
}
.btn{
    background-color: #FA7AB5;
    border-radius: 30px;
    box-shadow: 0 8px 0 #8B4264;
    color: #ffffff;
    display: inline-block;
    font-weight: bold;
    font-size: 28px;
    height: 65px;
    line-height: 65px;
    margin: 40px 10px;
    width: 300px;

}

/* banner-------------------------------------------- */
.banner{
    align-items: center;
    background-color: #ffffff;
    display: flex;
    justify-content: center;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100vw;
    z-index: 100;
}
.banner-contents{
    color: #0096FF;
    font-weight: bold;
    padding-right: 15px;
}
.tel-icon{
    width: 60px;
    height: 60px;
    margin-right: 10px;
}
.banner-tel{
font-size: 40px;
}
.banner-reception{
    font-size: 20x;
}
.campaign-btn{
    background-color: #F29600;
}

/* target--------------------------------------------  */
#target h2{
    background-color: #0096FF;
    color: #ffffff;
    font-size: 32px;
    padding-block: 8px;
    position: relative;
}
#target h2::after{
    border-style: solid;
    border-right: 70px solid transparent;
    border-left: 70px solid transparent;
    border-top: 40px solid #0096ff;
    border-bottom: 0;
    content: "";
    bottom: -40px;
    left: calc(50% - 35px);
    position: absolute;
    width: 0;
    height: 0;
}
.target-image{
    align-items: center;
    display: flex;
    gap: 30px;
    justify-content: center;
    margin-top: 100px;
}
.target-image img{
    width: 250px;
}
.target-text p{
    border-radius: 50px;
    background-color: #F1ECEC;
    font-size: 20px;
    margin-block: 30px;
    padding: 15px;
    position: relative;
    z-index: 5;
}
.target-text p::before{
    bottom: -8px;
    border-style: solid;
    border-right: 35px solid transparent;
    border-left: 35px solid transparent;
    border-bottom: 25px solid #F1ECEC;
    border-top: 0; 
    content: "";
    height: 0;
    position: absolute;
    transform: rotate(338deg);
    width: 0;
    z-index: -5;
}
.target-text p:nth-child(2){
    margin-left: 120px;
}
.target-text p:nth-child(1),
.target-text p:nth-child(3){
    margin-right: 120px;
}
.target-text span{
    font-size: 24px;
}
.target-contents{
    font-size: 24px;
    line-height: 35px;
    margin-top: 50px;
}
.target-contents span{
    font-size: 28px;
}

/* complex--------------------------------------------  */
.sec-title{
    align-items: center;
    background-color: #0096FF;
    color: #ffffff;
    display: flex;
    justify-content: center;
    margin-block: 60px;
    position: relative;
    z-index: -2;
}
.sec-title::before,
.sec-title::after{
    background: #ffffff;
    content: "";
    height: 10px;
    left: 0;
    position: absolute;
    width: 100%;
    z-index: -1;
}
.sec-title::before{
    top: -3px;
}
.sec-title::after{
    bottom: -3px;
}
.sec-title h2{
    font-size: 32px;
}
.sec-title img{
    height: 75px;
    width: 75px;
    margin-right: 20px;
}
.complex-reasons{
    display: flex;
    gap: 20px;
    justify-content: center;
    margin-bottom: 30px;
}
.complex-reason{
    background-color: #F5F5F5;
    border: 3px solid #55C3F1;
    border-radius: 10px;
    height: 200px;
    padding: 0 0 20px;
    width: 230px;
}
.reason-number{
    background-color: #55C3F1;
    border-top-left-radius: 5px;
    color: #ffffff;
    font-size: 16px;
    padding: 5px;
    width: 100px;
}
.complex-reason h3{
    display: inline-block;
    font-size: 24px;
    margin-block: 15px;
    position: relative;
    z-index: 10;
}
.complex-reason h3::before{
    background: #FFF034;
    bottom: 0;
    content: "";
    height: 30%;
    left: 0;
    position: absolute;
    width: 100%;
    z-index: -1;
}
.complex-reason p{
    font-size: 16px;
}
/* solution--------------------------------------------  */
#solution{
    font-size: 24px;
    padding-bottom: 80px;
}
#solution span{
    font-size: 28px;
}

/* about--------------------------------------------  */
#about{
    background-color: #FFF7B1;
    position: relative;
    padding-top: 145px;
}
.garland{
    height: 160px;
    overflow: hidden;
    object-fit: cover;
    object-position: center;
    position: absolute;
    top: 0;
    width: 350px;
    z-index: 0;
}
.garland:nth-of-type(1){
    left: 0;
    /* transform: rotate(-30deg); */
}
.garland:nth-of-type(2){
    right: 0;
    /* transform: rotate(30deg); */
}
#about h2{
    margin-inline: auto;
    max-width: 850px;
    z-index: 5;
}
.about-content{
    align-items: center;
    display: flex;
    font-size: 24px;
    gap: 30px;
    justify-content: center;
    padding-bottom: 80px;
    padding-top: 50px;
}
.about-content img{
    width: 200px;
}
/* reason--------------------------------------------  */
#reason{
    background-color: #FFE1EF;
    padding-bottom: 80px;
    padding-top: 120px;
}
#reason h2{
    margin-inline: auto;
    max-width: 600px;
}
.reason-content{
    align-items: center;
    background-color: #ffffff;
    display: flex;
    justify-content: space-between;
    margin: 100px auto;
    position: relative;
    max-width: 880px;
}
.content-number{
    background-color: #0096FF;
    border-radius: 50%;
    color: #ffffff;
    font-size: 28px;
    font-weight: bold;
    height: 60px;
    left: -10px;
    line-height: 60px;
    position: absolute;
    top: -20px;
    width: 60px;
}
.reason-content img{
    height: 350px;
    object-fit: cover;
    width: 380px;
}
.reason-text{
    padding-inline: 30px;
    text-align: left;
    width: 550px;
}
.reason-text h3{
    color: #0096FF;
    font-size: 28px;
    padding-bottom: 40px;
    text-align: left;
}

.reason-text p{
    font-size: 16px;
    text-align: left;
}

/* prise--------------------------------------------  */
.sub-title{
    background-color: #55C3F1;
    border-radius: 20px;
    box-shadow: 5px  5px 3px #a8a8a8;
    color: #ffffff;
    font-size: 32px;
    margin: 50px auto;
    padding-block: 10px;
    position: relative;
    width: 290px;
}
.sub-title::before{
    background: #ffffff;
    border-radius: 50%;
    content: "";
    height: 20px;
    left: 20px;
    position: absolute;
    top: calc(50% - 10px);
    width: 20px;
}
.prise-table{
    display: flex;
    justify-content: center;
    gap: 30px;
    margin:50px auto;
}
#prise dt{
    border-bottom: 3px solid #0096FF;
    border-top: 3px solid #0096FF;
    font-size: 24px;
    font-weight: bold;
    padding: 8px;
}
#prise dd{
    border-bottom: 1px solid #0096FF;
    font-size: 24px;
    padding: 8px;
}
.prise dd span{
    font-size: 16px;
}
.enter{
    box-shadow: 3px 3px 3px #a8a8a8;
    margin-inline: auto;
    max-width: 650px;
    padding:40px;
    text-align: left;
}
.enter h3{
    display: inline-block;
    font-size: 24px;
    margin-block: 15px;
    position: relative;
    z-index: 10;
}
.enter h3::before{
    background: #0096FF;
    bottom: 0;
    content: "";
    height: 20%;
    left: 0;
    position: absolute;
    width: 100%;
    z-index: -1;
}
.enter p{
    font-size: 16px;
    text-align: left;
}
.prise-attention{
    margin: 20px auto 80px;
    max-width: 600px;
}
.prise-attention p{
    font-size: 12px;
    text-align: left;
}

/* flow--------------------------------------------  */
#flow{
    background-color: #FFE1EF;
    padding-block: 70px;
}
#flow h2{
    max-width: 600px;
    margin-inline: auto;
}
.flow-contents{
    max-width: 900px;
    margin: 80px auto;
}

.flow-content{
    align-items: center;
    background-color: #ffffff;
    border: 5px solid #55C3F1;
    border-radius: 10px;
    display: flex;
    margin-bottom:80px;
    padding: 25px 40px;
    position: relative;
}
.flow-content::after{
    border-style: solid;
    border-right: 100px solid transparent;
    border-left: 100px solid transparent;
    border-top: 50px solid #55c3f1;
    border-bottom: 0;
    bottom: -70px;
    content: "";
    height: 50px;
    left: calc(50% - 100px);
    position: absolute;
    width: 200px;
}
.flow-content:nth-of-type(3)::after{
    display: none;
}
.flow-content img{
    height: 220px;
    object-fit: contain;
    object-position: center;
    width: 280px;
}
.flow-text{
    padding-right: 40px;
}
.flow-text h3{
    font-size: 28px;
    padding-bottom: 20px;
    text-align: left;
}
.flow-text p{
    font-size: 16px;
    text-align: left;
}

/* voice--------------------------------------------  */
#voice h2{
    margin-top: 80px;
}
.voice-contents{
    max-width: 900px;
    margin-inline: auto;
    padding-block: 80px;
}
.voice-content{
    align-items: center;
    border: 5px solid #FA7AB5;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    padding: 30px;
    margin-bottom: 40px;
}
.voice-content img{
    border-radius: 10px;
    height: 230px;
    object-fit: contain;
    object-position: center;
    width: 280px;
}
.voice-text{
    padding-left: 35px;
}
.voice-text h3{
    text-align: left;
    padding-bottom: 20px;
}
.voice-text p{
    text-align: left;
}

/* Q&A--------------------------------------------  */
.qa-contents{
    max-width: 900px;
    margin-inline: auto;
    font-size: 18px;
}
.qa-content{
    border-radius: 10px;
    box-shadow: 2px 2px 5px #a8a8a8;
    margin-bottom: 20px;
}
.q-text{
    background-color: #55C3F1;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    color: #ffffff;
    padding: 15px 60px 15px;
    position: relative;
    text-align: left;
    width: 100%;
}
.q-text::before{
    content: "Q.";
    color: #ffffff;
    left: 25px;
    position: absolute;
    top: 15px;
}
.a-text{
    background-color: #F5F5F5;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    padding: 15px 60px 15px;
    position: relative;
    text-align: left;
    width: 100%;
}
.a-text::before{
    content: "A.";
    left: 25px;
    position: absolute;
    top: 15px;
}

.ex-title{
    background-color: #FFF034;
    border-radius: 30px;
    color: #0096FF;
    font-size: 32px;
    margin: 100px auto;
    padding: 25px 30px;
    max-width: 520px;
}
.attention{
    position: relative;
}
.attention::after{
    bottom: 10px;
    right: -60px;
    content: "※予約制";
    color: #000000;
    font-size: 12px;
    font-weight: normal;
    position: absolute;

}
.ex-text p{
    padding-bottom: 15px;
    font-size: 16px;
}
.ex-text p:nth-of-type(1){
    font-size: 20px;
    font-weight: bold;
}
.ex-text p span{
    color: red;
    font-size: 24px;
}
.ex-img{
    display: flex;
    gap: 20px;
    justify-content: center;
    max-width: 900px;
    margin: 30px auto 80px;
}
.ex-img img{
    width: 30%;
}

/* campaign--------------------------------------------  */
.campaign-contents{
    margin-bottom: 80px;
}
.campaign-content{
    background-color: #F29600;
    color: #FFFFFF;
    max-width: 900px;
    margin: 0 auto 50px;
    position: relative;
}
.campaign-content::before{
    border-style: solid;
    border-right: 94.5px solid transparent;
    border-left: 94.5px solid transparent;
    border-bottom: 93.7px solid #F3DC05;
    border-top: 0;
    content: "";
    height: 0;
    left: -61px;
    position: absolute;
    top: -13.5px;
    transform: rotate(315deg);
    width: 0;
}
.campaign-content::after{
    content: "campaign";
    color: #F29600;
    font-size: 26px;
    font-weight: bold;
    left: -10px;
    position: absolute;
    top: 35px;
    transform: rotate(315deg);
}
.campaign-content h2{
    font-size: 22px;
    padding: 15px 0 10px;
    border-bottom: 3px solid #ffffff;
}
.campaign-content h3{
    font-size: 25px;
    padding-top: 8px;
}
.content-description{
    padding-block: 20px;
    display: flex;
    gap: 20px;
    justify-content: center;
}
.content-description p{
    background-color: #FFFFFF;
    color: #F29600;
    font-size: 20px;
    font-weight: bold;
    height: 80px;
    width: 220px;
}
.number{
    font-size: 48px;
    font-weight: 800;
}
.campaign-text p{
    font-size: 16px;
    padding-bottom: 20px;
}

/* company--------------------------------------------  */
.info-contents{
    align-items: center;
    box-shadow: 3px 3px 3px #a8a8a8;
    display: flex;
    justify-content: space-between;
    max-width: 760px;
    margin: 0 auto 60px;
}
.info-contents h2{
    background-color: #55C3F1;
    color: #FFFFFF;
    font-size: 32px;
    padding: 30px;
}
.info-content{
    align-items: center;
    display: flex;
    font-weight: bold;
    padding-inline: 30px;
}
.info-text{
    padding-left: 15px;
}
.company-contents h2{
    font-size: 32px;
}
.company-info{
    display: flex;
    max-width: 800px;
    margin: 30px auto;
}

.lesson-area{
    border-right: 1px solid #000000;
    display: grid;
    grid-template-columns: repeat(3,1fr);
    padding-block: 20px;
}
.company-text p{
    padding-bottom: 8px;
    padding-left: 20px;
    text-align: left;
}

/* reserve--------------------------------------------  */
#reserve{
    padding-bottom: 200px;
}
form{
    margin-top: 80px;
}
form dl{
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    margin-inline: auto;
    max-width: 600px;
    font-size: 14px;
}
form dl dt{
    height: 20px;
    margin-block: 10px;
    width: 35%;
}
form dl dd{
    border: 1px solid #000000;
    border-radius: 5px;
    margin-block: 10px;
    padding: 5px;
    width: 65%;
}
dl dd dl{
    height: 30px;
}
dl dd dl dt{
    width: 15%;
    margin-block: 0px;
}
dl dd dl dd{
    width: 85%;
    border: none;
    padding: 0px;
}
dl dd dl dd p{
    text-align: left;
}

input{
    height: 20px;
    text-align: left;
    width: 100%;
}
textarea{
    width: 100%;
    text-align: left;
}
.submit{
    margin-inline: auto;
    text-align: center;
}
form p{
    width: 100%;
}


@media (max-width:980px){
    /* header---------------------------------- */
    .text-wrapper h2{
        font-size: 18px;
    }
    .btn{
        font-size: 22px;
        width: 210px;
    }

    /* banner-------------------------------------------- */
    .banner-contents{
        padding-right: 10px;
    }
    .tel-icon{
        width: 45px;
        height: 45px;
        margin-right: 10px;
    }
    .banner-tel{
    font-size: 24px;
    }
    .banner-reception{
        font-size: 14x;
    }

    /* target--------------------------------------------  */
    #target h2{
        font-size: 24px;
    }
    #target h2::after{
        border-right: 50px solid transparent;
        border-left: 50px solid transparent;
        border-top: 30px solid #0096ff;
        bottom: -30px;
        left: calc(50% - 25px);
    }
    .target-text p{
        font-size: 16px;
    }

    .target-text span{
        font-size: 18px;
    }
    .target-contents{
        font-size: 20px;
        line-height: 24px;
    }
    .target-contents span{
        font-size: 24px;
    }

    /* complex--------------------------------------------  */
    .complex-reason{
        width: 200px;
    }
    .sec-title h2{
        font-size: 24px;
    }
    .sec-title img{
        height: 60px;
        width: 60px;
    }
    .complex-reason h3{
        font-size: 20px;
    }
    .complex-reason p{
        font-size: 14px;
    }
    /* solution--------------------------------------------  */
    #solution{
        font-size: 18px;
    }
    #solution span{
        font-size: 20px;
    }

    /* about--------------------------------------------  */
    .garland{
        height: 100px;
        width: 200px;
    }
    #about h2{
        max-width: 600px;
    }
    .about-content{
        font-size: 16px;
    }
    .about-content img{
        max-width: 120px;
    }
    /* reason--------------------------------------------  */
    #reason h2{
        max-width: 400px;
    }
    .reason-content{
        max-width: 620px;
    }
    .reason-content img{
        height: 250px;
        width: 300px;
    }
    .reason-text{
        padding-inline: 20px;
        max-width: 450px;
    }
    .reason-text h3{
        font-size: 18px;
    }
    .reason-text p{
        font-size: 12px;
    }

    /* prise--------------------------------------------  */
    .sub-title{
        font-size: 24px;
        width: 240px;
    }
    .enter{
        max-width: 500px;
    }
    .enter h3{
        font-size: 18px;
    }
    .enter p{
        font-size: 12px;
    }
    .prise-attention{
        max-width: 380px;
    }
    .prise-attention p{
        font-size: 10px;
    }

    /* flow--------------------------------------------  */
    #flow h2{
        max-width: 500px;
    }
    .flow-contents{
        max-width: 600px;
    }
    .flow-content{
        padding: 25px;
    }
    .flow-text{
        padding-right: 30px;
    }
    .flow-text h3{
        font-size: 20px;
    }
    .flow-text p{
        font-size: 12px;
    }

    /* voice--------------------------------------------  */
    .voice-contents{
        max-width: 600px;
        padding-block: 80px;
    }
    .voice-content{
        padding: 20px;
    }
    .voice-content img{
        height: 220px;
        width: 240px;
    }
    .voice-text{
        padding-left: 20px;
    }

    /* Q&A--------------------------------------------  */
    .qa-contents{
        max-width: 600px;
        font-size: 14px;
    }
    .ex-text p{
        font-size: 14px;
    }
    .ex-text p:nth-of-type(1){
        font-size: 16px;
    }
    .ex-text p span{
        font-size: 18px;
    }
    /* campaign--------------------------------------------  */

    .campaign-content{
        max-width: 650px;
    }
    .campaign-content h2{
        font-size: 28px;
    }
    .campaign-content h3{
        font-size: 18px;
    }
    .content-description{
        gap: 12px;
    }
    .content-description p{
        font-size: 16px;
        height: 70px;
        width: 200px;
    }

    /* company--------------------------------------------  */
    .info-contents{
        max-width: 600px;
    }
    .info-contents h2{
        font-size: 24px;
    }
    .company-contents h2{
        font-size: 28px;
    }
    .company-info{
        max-width: 600px;
    }

    .lesson-area{
        font-size: 12px;
    }
    .company-text p{
        font-size: 12px;
    }

}



/* responsive---------------------------------------------------- */
@media(max-width:428px){
    /* header---------- */
    header{
        flex-direction: column-reverse;
        margin-bottom: 50px;
    }
    .main-text{
        padding-top: 50px;
        width: 100%;
    }
    .text-wrapper{
        padding: 10px 20px;
    }
    .text-wrapper::before,
    .text-wrapper::after{
        height: 3px;
    }
    .text-wrapper::before{
        top: -8px;
    }
    .text-wrapper::after{
        bottom: -8px;
    }
    .text-wrapper h1 img{
        max-width: calc(100vw - 40px);
        max-height: 115px;
    }
    .text-wrapper h2{
        font-size: 20px;
    }
    .main-visual{
        width: 100vw;
        max-height: 350px;
    }
    .main-visual img{
        max-height: 350px;
    }
    .btn{
        border-radius: 20px;
        box-shadow: 0 3px 0 #8B4264;
        font-size: 20px;
        height: 45px;
        line-height: 45px;
        margin: 25px auto;
        width: 200px;
    }

    /* banner---------- */
    .banner{
        padding-block: 8px;
    }
    .banner-contents{
        padding-right: 8px;
    }
    .tel-icon{
        width:20px;
        height: 20px;
        margin-right: 8px;
    }
    .banner-tel{
    font-size: 18px;
    }
    .banner-reception{
        font-size: 9px;
    }

    .banner-btn{
        align-items: center;
        display: flex;
        flex-direction: column;
        gap: 8px;
    }

    .banner .btn{
        box-shadow: 0 5px 0 #8B4264;
        font-size: 14px;
        height: 30px;
        line-height: 30px;
        margin: 0 5px;
        width: 130px;
    }

    /* target------------------ */
    #target h2{
        font-size: 20px;
    }
    #target h2::after{
        border-right: 30px solid transparent;
        border-left: 30px solid transparent;
        border-top: 12px solid #0096ff;
        bottom: -10px;
    }
    .target-image{
        flex-direction: column-reverse;
        gap: 10px;
        margin-top: 30px;
    }
    .target-image img{
        width: 120px;
    }
    .target-text p{
        border-radius: 50px;
        font-size: 12px;
        margin-block: 10px;
        padding: 8px;
    }
    .target-text p:nth-child(1):before,
    .target-text p:nth-child(3):before{
        bottom: -5px;
        border-right: 20px solid transparent;
        border-left: 20px solid transparent;
        border-bottom: 12px solid #F1ECEC;
        transform: rotate(248deg);
    }
    .target-text p:nth-child(2):before{
        bottom: -5px;
        border-right: 20px solid transparent;
        border-left: 20px solid transparent;
        border-bottom: 12px solid #F1ECEC;
        right: 25px;
    }
    .target-text span{
        font-size: 14px;
    }
    .target-contents{
        font-size: 12px;
        line-height: 16px;
        margin-top: 30px;
    }
    .target-contents span{
        font-size: 16px;
    }

    /* complex--------------------- */
    .sec-title{
        margin-block: 50px;
    }
    .sec-title::before,
    .sec-title::after{
        height: 8px;
    }
    .sec-title h2{
        font-size: 20px;
    }
    .sec-title img{
        height: 33px;
        width: 33px;
        margin-right: 15px;
    }
    .complex-reasons{
        align-items: center;
        flex-direction: column;
        margin-bottom: 20px;
    }
    .complex-reason{
        height: 160px;
    }
    .reason-number{
        font-size: 12px;
    }
    .complex-reason h3{
        font-size: 20px;
        margin-block: 15px;
    }

    .complex-reason p{
        font-size: 12px;
    }
    /* solution----------------------------  */
    #solution{
        font-size: 12px;
        padding-bottom: 60px;
    }
    #solution span{
        font-size: 16px;
    }

    /* about------------------------------ */
    #about{
        padding-top: 80px;
    }
    .garland{
        height: 80px;
        width: 150px;
    }
    #about h2 img{
        max-height: 32px;
        max-width: 280px;
    }
    .about-content{
        font-size: 12px;
        gap: 10px;
        padding-bottom: 50px;
        padding-top: 30px;
    }
    .about-content img{
        width: 75px;
    }
    /* reason--------------------------------------------  */
    #reason{
        padding-bottom: 10px;
        padding-top: 80px;
    }
    #reason h2{
        max-width: 250px;
    }
    #reason h2 img{
        max-height: 55px;
        max-width: 250px;
    }
    .reason-content{
        flex-direction: column;
        margin: 50px auto;
        width: 300px;
    }
    .reason-content:nth-of-type(2),
    .reason-content:nth-of-type(4){
        flex-direction: column-reverse;
    }
    .reason-content:nth-of-type(4) img{
        object-fit: contain;
    }
    .content-number{
        font-size: 14px;
        height: 30px;
        left: -5px;
        line-height: 30px;
        top: -10px;
        width: 30px;
    }
    .reason-content img{
        height: 180px;
        width: 300px;
    }
    .reason-text{
        padding-inline: 15px;
        padding-block: 20px;
        width: 300px;
    }
    .reason-text h3{
        font-size: 16px;
        padding-bottom: 20px;
    }
    .reason-text p{
        font-size: 11px;
    }

    /* praise */
    .sub-title{
        box-shadow: 3px  3px 3px #a8a8a8;
        border-radius: 10px;
        font-size: 18px;
        margin: 40px auto;
        padding-block: 5px;
        width: 140px;
    }
    .sub-title::before{
        height: 7px;
        left: 7px;
        top: calc(50% - 3.5px);
        width: 7px;
    }


    .prise-table{
        flex-direction: column;
        gap: 20px;
        margin:40px auto;
        max-width: 200px;
    }
    #prise dt{
        font-size: 16px;
        padding: 5px;
    }
    #prise dd{
        font-size: 16px;
        padding: 5px;
    }
    #prise dd span{
        font-size: 10px;
    }
    .enter{
        text-align: center;
        max-width: 280px;
        padding:15px;
    }
    .enter h3{
        font-size: 16px;
    }
    .enter p{
        font-size: 12px;
    }
    .prise-attention{
        margin: 20px auto 80px;
        max-width: 280px;
    }
    .prise-attention p{
        font-size: 10px;
    }
    
    /* flow--------------------------------  */
    #flow{
        padding-top: 50px;
        padding-bottom: 10px;
    }
    #flow h2 img{
        max-height: 80px;
        max-width: 300px;
    }
    .flow-contents{
        max-width: 300px;
        margin: 50px auto;
    }
    .flow-content{
        border: 3px solid #55C3F1;
        flex-direction: column;
        margin-bottom:40px;
        padding: 15px;
    }
    .flow-content::after{
        border-right: 40px solid transparent;
        border-left: 40px solid transparent;
        border-top: 20px solid #55c3f1;
        bottom: -35px;
        height: 20px;
        left: calc(50% - 40px);
        width: 80px;
    }
    .flow-content img{
        height: 150px;
        width: 240px;
    }
    .flow-text{
        padding-right: 0;
    }
    .flow-text h3{
        font-size: 16px;
        text-align: center;
    }
    .flow-text p{
        font-size: 12px;
        margin-bottom: 15px;
    }
    
    /* voice--------------------------------------------  */
    .pc{
        display: none;
    }
    .sp{
        display: block;
    }
    #voice h2{
        margin-top: 40px;
    }
    #voice h2 img{
        max-height: 150px;
        width: 100vw;
    }
    .voice-contents{
        max-width: 300px;
        padding-block: 30px;
    }
    .voice-content{
        border: 3px solid #FA7AB5;
        flex-direction: column;
        padding: 15px 20px;
        margin-bottom: 30px;
    }
    .voice-content img{
        height: 180px;
        width: 280px;
    }
    .voice-text{
        padding-left: 0;
    }
    .voice-text h3{
        font-size: 14px;
        text-align: center;
        padding-bottom: 15px;
    }
    .voice-text p{
        font-size: 10px;
    }
    
    /* Q&A--------------------------------------------  */
    .qa-contents{
        max-width: 310px;
        font-size: 12px;
    }
    .qa-content{
        margin-bottom: 10px;
    }
    .q-text{
        padding: 8px 8px 8px 24px;
    }
    .q-text::before{
        left: 8px;
        top: 8px;
    }
    .a-text{
        padding: 8px 8px 8px 24px;
    }
    .a-text::before{
        content: "A.";
        left: 8px;
        top: 8px;
    }
    
    /* experience----------------- */
    .ex-title{
        font-size: 20px;
        margin: 50px auto;
        padding: 20px 20px;
        width: 280px;
    }
    .attention::after{
        bottom: 0px;
        right: -45px;
        font-size: 10px;
    }
    .ex-text{
        padding-inline: 8px;
    }
    .ex-text p{
        padding-bottom: 8px;
        font-size: 11px;
    }
    .ex-text p:nth-of-type(1){
        font-size: 12px;
    }
    .ex-text p span{
        font-size: 14px;
    }
    .ex-img{
        max-width: 300px;
        margin: 30px auto 60px;
    }
    .ex-img img{
        width: 100%;
    }
    .ex-img img:nth-of-type(2),
    .ex-img img:nth-of-type(3){
        display: none;
    }
    
    /* campaign---------------------------------  */
    .campaign-contents{
        margin-bottom: 50px;
    }
    .campaign-content{
        max-width: 300px;
        margin: 0 auto 30px;
    }
    .campaign-content::before{
        border-style: solid;
        border-right: 47.2px solid transparent;
        border-left: 47.2px solid transparent;
        border-bottom: 46.8px solid #F3DC05;
        left: -31px;
        top: -8px;
    }
    .campaign-content::after{
        font-size: 13px;
        left: -8px;
        top: 18px;
    }
    .campaign-content h2{
        font-size: 20px;
        padding: 5px 0;
        border-bottom: 2px solid #ffffff;
    }
    .campaign-content h3{
        font-size: 14px;
        padding-top: 0px;
    }
    .content-description{
        align-items: center;
        padding-block: 10px;
        flex-direction: column;
        gap: 15px;
    }
    .content-description p{
        font-size: 12px;
        height: 50px;
    }
    .number{
        font-size: 36px;
        font-weight: 800;
    }
    .campaign-text p{
        font-size: 11px;
        padding-bottom: 10px;
    }
    
    /* company--------------------------------------------  */
    .info-contents{
        max-width: 300px;
        margin: 0 auto 40px;
    }
    .info-contents h2{
        font-size: 12px;
        padding: 10px 5px;
    }
    .info-content{
        padding-inline: 10px;
    }
    .info-text{
        padding-left: 8px;
    }
    .company-contents h2{
        font-size: 21px;
    }
    .company-info{
        flex-direction: column-reverse;
        font-size: 11px;
        max-width: 300px;
        margin: 20px auto;
    }
    .lesson-area{
        border-right: none;
        padding-block: 10px;
    }
    .company-text p{
        padding-bottom: 8px;
        padding-left: 0;
        text-align: center;
    }
    
    /* reserve--------------------------------  */
    #reserve{
        padding-bottom: 200px;
    }
    #reserve p{
        font-size: 11px;
    }
    form dl{
        max-width: 400px;
        font-size: 12px;
    }
	
	/* 追加ここから
----------------------------------------------- */
	
	.top {
	  background-color: #0096FF;
    color: #ffffff;
    font-size: 32px;
    padding-block: 8px;
    position: relative;
}
}
