@charset "UTF-8";

/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Sawarabi+Gothic&display=swap");

body {
    font-family: 'Noto Sans JP', sans-serif !important;
    margin: 0 auto !important;
}

li {
    list-style: none;
}

ul {
    padding: 0px
}

a {
    text-decoration: none;
}
.noblink{
    color: white;
    text-decoration: underline;
}
.box {
    display: flex;
    flex-wrap: wrap;
}

p, h1, h2, h3, h4, li, td {
    letter-spacing: 1px;
    margin: 0px
}

table {
    border-spacing: 0;
}

p {
    margin: 0;
}

@media screen and (min-width: 781px) {
    .sp {
        display: none
    }
}

@media screen and (max-width: 780px) {
    .pc {
        display: none
    }
}

@media screen and (min-width: 781px) {
    p {
        line-height: 24px;
        font-size: 20px
    }
}

@media screen and (max-width: 780px) {
    p {
        line-height: 24px;
        font-size: 16px
    }
}

h1 {
    font-size: 54px
}

.contents {
    max-width: 1200px;
    width: 90%;
    margin: 0px auto;
}


/*ヘッダー*/
header {
    position: absolute;
    margin: 55px auto;
    left: 0;
    right: 0;
    z-index: 100
}

header .logo {
    float: left;
    margin-left: 10%;
}

header .btn {
    float: right;
    margin-right: 10%;
    position: relative;
}

@media screen and (max-width: 1480px) {
    header .logo {
        float: left;
        margin-left: 5%;
    }

    header .btn {
        float: right;
        margin-right: 5%;
        position: relative;
    }
}

header .btn img {
    position: relative
}

header .btn p {
    position: absolute;
    color: #fff;
    left: 35%;
    top: 30%;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 3px;
    margin-top: 5px;

}

@media screen and (max-width: 980px) {
    header {
        margin: 30px auto;
    }

    header .logo {
        width: 250px
    }

    header .btn {
        width: 250px
    }

    header .btn p {
        font-size: 2vw;
        top: 30%;
        margin-top: 0px;
    }
}

@media screen and (max-width: 759px) {
    header .logo {
        width: 150px
    }

    header .btn {
        width: 150px
    }

    header .btn p {
        font-size: 11px;
        left: 30%;
        top: 18%;
        margin-top: 0px;
    }
}


/*MV*/
#mv {
    background: url('img/bg_01.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 900px;
}

#mv .box {
    padding: 210px 0
}

.mv_txt {
    width: 49%;
}

.mv_txt h1 {
    font-size: 52px;
    line-height: 160%;
    font-weight: bold;
}

.mv_txt h1 span {
    font-size: 120px;
    color: #24499a
}

.mv_txt h2 {
    font-size: 52px;
    color: #24499a;
    font-weight: bold;
}

.mv_txt p {
    font-size: 24px;
    font-weight: bold;
    line-height: 150%;
    margin-top: 60px
}

.mv_img {
    width: 51%;
    margin-top: -70px
}

@media screen and (max-width: 1480px) {
    #mv {
        background: url('img/bg_01.png');
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
        height: auto;
    }

    .mv_txt {
        width: 49%;
    }

    .mv_txt h1 {
        font-size: 3.5vw;
        line-height: 160%
    }

    .mv_txt h1 span {
        font-size: 9vw;
        color: #24499a
    }

    .mv_txt h2 {
        font-size: 3.5vw;
        color: #24499a
    }

    .mv_txt p {
        font-size: 1.6vw;
        font-weight: bold;
        line-height: 150%;
        margin-top: 40px
    }

    .mv_img {
        width: 51%;
        margin-top: -40px
    }

    .mv_img img {
        width: 100%
    }
}

@media screen and (max-width: 1280px) {
    .mv_txt {
        width: 45%;
    }

    .mv_img {
        width: 55%;
    }
}

@media screen and (max-width: 980px) {
    #mv .box {
        padding: 180px 0
    }
}

@media screen and (max-width: 759px) {
    #mv .box {
        padding: 120px 0
    }

    .mv_txt {
        width: 100%;
    }

    .mv_txt h1 {
        font-size: 7.7vw;
        line-height: 160%
    }

    .mv_txt h1 span {
        font-size: 20vw;
        color: #24499a
    }

    .mv_txt h2 {
        font-size: 7.7vw;
        color: #24499a
    }

    .mv_txt p {
        font-size: 3.6vw;
        font-weight: bold;
        line-height: 150%;
        margin-top: 20px
    }

    .mv_img {
        width: 100%;
        margin-top: 20px
    }
}


#mv2 {
    margin-top: -150px
}

#mv2 .box {
    max-width: 880px
}

#mv2 .point:nth-child(1) {
    background: #25a2d4;
}

#mv2 .point:nth-child(2) {
    background: #2a7dc0;
}

#mv2 .point:nth-child(3) {
    background: #24499a;
}

#mv2 .point {
    border-radius: 200px;
    width: 270px;
    height: 270px;
    filter: drop-shadow(10px 10px 10px rgba(0, 0, 0, 0.3));
    position: relative;
    margin: 0 auto 30px
}

#mv2 .point p {
    position: absolute;
    text-align: center;
    color: #fff;
    margin: 0 auto;
    left: 0px;
    right: 0px;
    top: 90px;
    line-height: 160%
}

@media screen and (max-width: 1480px) {
    #mv2 {
        margin-top: -200px
    }

    #mv2 .box {
        max-width: 800px
    }

    #mv2 .point {
        border-radius: 200px;
        width: 240px;
        height: 240px;
        filter: drop-shadow(10px 10px 10px rgba(0, 0, 0, 0.3));
        position: relative;
        margin: 0 auto 30px
    }

    #mv2 .point p {
        font-size: 16px;
        top: 90px;
    }
}

@media screen and (max-width: 980px) {
    #mv2 {
        margin-top: -150px
    }

    #mv2 .box {
        max-width: 600px
    }

    #mv2 .point {
        border-radius: 200px;
        width: 180px;
        height: 180px;
        filter: drop-shadow(10px 10px 10px rgba(0, 0, 0, 0.3));
        position: relative;
        margin: 0 auto 30px
    }

    #mv2 .point p {
        font-size: 13px;
        top: 60px;
    }
}

@media screen and (max-width: 780px) {
    #mv2 {
        margin-top: -80px
    }

    #mv2 .box {
        max-width: 600px
    }

    #mv2 .point {
        border-radius: 200px;
        width: 30%;
        height: auto;
        filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.3));
        position: relative;
        margin: 0 auto 30px;
        padding: 15% 0
    }

    #mv2 .point p {
        font-size: 1.8vw;
        top: 35%;
    }
}


/*施設や店舗の修繕管理はお任せください*/
#about {
    margin-top: 50px;
    padding-bottom: 8%
}

#about .contents {
    width: 100%
}

.arrow_box {
    position: relative;
    background: #24499A;
    padding: 20px;
    text-align: center;
    color: #FFFFFF;
    font-size: 27px;
    font-weight: bold;
    width: 550px;
    margin: 0 auto 50px
}

.arrow_box:after, .arrow_box:before {
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    pointer-events: none;
    position: absolute;
    top: 100%;
    left: 50%;
}

.arrow_box:after {
    border-color: rgba(36, 73, 154, 0);
    border-top-width: 20px;
    border-bottom-width: 20px;
    border-left-width: 15px;
    border-right-width: 15px;
    margin-left: -15px;
    border-top-color: #24499A;
}

.arrow_box:before {
    border-color: rgba(255, 255, 255, 0);
    border-top-width: 26px;
    border-bottom-width: 26px;
    border-left-width: 20px;
    border-right-width: 20px;
    margin-left: -20px;
    margin-top: 5px;
}

#about h1 {
    text-align: center
}

#about .txt {
    text-align: center;
    max-width: 815px;
    font-weight: bold;
    font-size: 25px;
    line-height: 160%;
    margin: 60px auto
}

#about .point {
    border-radius: 200px;
    width: 320px;
    height: 90px;
    margin: 0 auto 30px;
    padding-top: 20px;
    padding-left: 50px
}

#about .point:nth-child(1) {
    background: #25a2d4;
    background: url('img/01amet_1.png');
    background-size: 100%;
    background-position: center;
    background-repeat: no-repeat;
}

#about .point:nth-child(2) {
    background: #2a7dc0;
    background: url('img/01amet_2.png');
    background-size: 100%;
    background-position: center;
    background-repeat: no-repeat;
}

#about .point:nth-child(3) {
    background: #24499a;
    background: url('img/01amet_3.png');
    background-size: 100%;
    background-position: center;
    background-repeat: no-repeat;
}

#about .point p {
    text-align: center;
    color: #fff;
    margin: 0 auto;
    line-height: 160%;
    font-size: 29px
}

@media screen and (max-width: 1480px) {
    .arrow_box {
        font-size: 23px;
        width: 450px;
        margin: 0 auto 50px
    }

    #about h1 {
        font-size: 48px;
    }

    #about .txt {
        font-size: 22px;
        max-width: 715px;
        margin: 40px auto
    }

    #about .point {
        border-radius: 200px;
        width: 26%;
        height: 90px;
        margin: 0 auto 30px;
        padding-top: 22px;
        padding-left: 50px
    }

    #about .point p {
        font-size: 25px
    }
}

@media screen and (max-width: 980px) {
    .arrow_box {
        font-size: 18px;
        width: 350px;
        margin: 0 auto 50px
    }

    #about h1 {
        font-size: 38px;
    }

    #about .txt {
        font-size: 18px;
        max-width: 515px;
        margin: 40px auto 20px
    }

    #about .box {
        max-width: 800px;
        margin: 0 auto
    }

    #about .point {
        border-radius: 200px;
        width: 24%;
        height: 90px;
        margin: 0 auto 30px;
        padding-top: 30px;
        padding-left: 30px
    }

    #about .point p {
        font-size: 19px
    }

}

@media screen and (max-width: 780px) {
    #about .contents {
        width: 90%
    }

    .arrow_box {
        font-size: 16px;
        margin: 0 auto 50px;
        padding: 15px 0;
        width: 100%
    }

    #about h1 {
        font-size: 26px;
    }

    #about .txt {
        font-size: 16px;
        max-width: 515px;
        margin: 40px auto
    }

    #about .box {
        max-width: 300px;
        margin: 0 auto
    }

    #about .point {
        border-radius: 200px;
        max-width: 250px;
        width: 70%;
        margin: 0 auto 20px;
        height: 40px;
        padding: 7px 0 0 20px;
    }

    #about .point p {
        font-size: 17px
    }
}


/*お悩み*/
#onayami {
    background: url('img/bg_03.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 8% 0
}

#onayami .contents {
    width: 100%
}

#onayami h1 {
    color: #fff;
    text-align: center
}

.h1_bd {
    border-bottom: 4px solid #25a2d4;
    padding-top: 50px;
    width: 220px;
    margin: 0 auto 50px
}

#onayami .point {
    background: #d9edf9;
    padding: 40px 0 20px;
    width: 30%;
    margin: 0 auto 20px;
    text-align: center;
    filter: drop-shadow(10px 10px 10px rgba(0, 0, 0, 0.5));
    border-radius: 20px
}

#onayami .point img {
    max-width: 250px
}

#onayami .point p {
    width: 90%;
    margin: 30px auto;
    font-weight: bold;
    line-height: 160%;
}

@media screen and (max-width: 1480px) {
    #onayami h1 {
        font-size: 48px;
    }

    #onayami .point p {
        font-size: 20px
    }

    #onayami .contents {
        width: 90%
    }
}

@media screen and (max-width: 980px) {
    #onayami h1 {
        font-size: 38px;
    }

    #onayami .point p {
        font-size: 19px
    }
}

@media screen and (max-width: 780px) {
    #onayami .contents {
        width: 90%
    }

    #onayami h1 {
        font-size: 26px;
    }

    .h1_bd {
        border-bottom: 4px solid #25a2d4;
        padding-top: 50px;
        width: 220px;
        margin: 0 auto 50px
    }

    #onayami .point {
        background: #d9edf9;
        padding: 30px 0;
        width: 100%;
        margin: 0 auto 30px;
        text-align: center;
        filter: drop-shadow(10px 10px 10px rgba(0, 0, 0, 0.5));
        border-radius: 20px
    }

    #onayami .point p {
        font-size: 17px
    }
}


/*選ばれる理由*/
#reason {
    padding: 8% 0
}

#reason .contents {
    width: 100%
}

#reason h1 {
    text-align: center
}

.h1_bd {
    border-bottom: 4px solid #25a2d4;
    padding-top: 50px;
    width: 220px;
    margin: 0 auto 50px
}

#reason .box {
    margin-top: 120px
}

#reason .point {
    padding: 40px 0 20px;
    width: 30%;
    margin: 0 auto 20px;
    text-align: center;
    position: relative
}

#reason .point h1 {
    font-family: 'Poppins', sans-serif;
    font-size: 131px;
    color: #25a2d4;
    text-align: left;
    position: absolute;
    top: -80px;
    left: -10px
}

#reason .point p {
    margin: 30px auto;
    font-weight: bold;
    line-height: 160%;
    font-size: 28px
}

#reason .bf_bg {
    background: linear-gradient(180deg, #fff 0%, #fff 30%, #f2f2f2 30%, #f2f2f2 100%);
}

#reason .af_bg {
    background: linear-gradient(180deg, #f2f2f2 0%, #f2f2f2 30%, #25a2d4 30%, #25a2d4 100%);
}

@media screen and (max-width: 1480px) {
    #reason h1 {
        font-size: 48px;
    }

    #reason .point p {
        font-size: 24px
    }

    #reason .contents {
        width: 90%
    }
}

@media screen and (max-width: 980px) {
    #reason h1 {
        font-size: 38px;
    }

    #reason .point p {
        font-size: 19px
    }
}

@media screen and (max-width: 780px) {
    #reason h1 {
        font-size: 26px;
    }

    .h1_bd {
        border-bottom: 4px solid #25a2d4;
        padding-top: 50px;
        width: 220px;
        margin: 0 auto 50px
    }

    #reason .point {
        width: 100%;
        margin: 0 auto 30px;
        text-align: center;
    }

    #reason .point h1 {
        font-size: 110px;
        top: -50px
    }

    #reason .point p {
        font-size: 19px
    }
}

.bf {
    position: relative;
    width: 100%;
    padding: 8% 0 0
}

.bf img {
    position: relative;
    width: 100%
}

.bf h2 {
    position: absolute;
    margin: 0px auto;
    left: 0px;
    right: 0px;
    top: 12.5%;
    font-size: 31px;
    color: #fff;
    text-align: center
}

.bf .point1 {
    font-weight: bold;
    position: absolute;
    left: 42%;
    top: 31%;
    font-size: 21px;
    line-height: 160%
}

.bf .point1 span {
    color: #ff791f
}

.bf .point2 {
    font-weight: bold;
    position: absolute;
    left: 42%;
    top: 52%;
    font-size: 21px;
    line-height: 160%
}

.bf .point2 span {
    color: #2a85e8
}

.bf .point3 {
    font-weight: bold;
    position: absolute;
    left: 42%;
    top: 73%;
    font-size: 21px;
    line-height: 160%
}

.bf .point3 span {
    color: #32bcbf
}

.bf h3 {
    position: absolute;
    margin: 0px auto;
    left: 0px;
    right: 0px;
    bottom: 2%;
    font-size: 31px;
    color: #fff;
    text-align: center
}

.af {
    position: relative;
    width: 100%;
    padding: 8% 0
}

.af h2 {
    position: absolute;
    margin: 0px auto;
    left: 0px;
    right: 0px;
    top: 12%;
    font-size: 31px;
    color: #fff;
    text-align: center
}

.af h3 {
    position: absolute;
    left: 7%;
    bottom: 18%;
    font-size: 31px;
    color: #fff;
}

@media screen and (max-width: 1180px) {
    .bf h2 {
        font-size: 2.4vw;
    }

    .bf .point1 {
        font-size: 1.6vw;
        left: 41%;
        top: 30.5%;
    }

    .bf .point2 {
        font-size: 1.6vw;
        left: 41%;
        top: 51%;
    }

    .bf .point3 {
        font-size: 1.6vw;
        left: 41%;
        top: 72%;
    }

    .bf h3 {
        font-size: 2.2vw;
        bottom: 3%;
    }

    .af h2 {
        font-size: 2.4vw;
    }

    .af h3 {
        font-size: 2.2vw;
        bottom: 19%;
    }
}


/*お問い合わせ*/
#contact {
    padding: 8% 0
}

#contact .contents {

}

#contact .btn {
    background: url('img/contact.png');
    background-size: 100%;
    background-position: center bottom;
    background-repeat: no-repeat;
    width: 100%;
    height: 200px;
    cursor: pointer;
}

#contact .btn p {
    font-size: 41px;
    font-weight: bold;
    letter-spacing: 2px;
    margin-left: 23%;
    color: #fff;
    text-align: left;
    margin-top: 65px;
}

#contact a {

}

@media screen and (max-width: 1480px) {
    #contact .contents {
        width: 90%
    }

    #contact .btn {
    }

    #contact .btn p {
        font-size: 3vw;
        font-weight: bold;
        letter-spacing: 2px;
        margin-left: 23%;
        margin-top: 70px;
    }
}

@media screen and (max-width: 980px) {
    #contact .btn {
        padding: 6% 0;
    }

    #contact .btn p {
        font-size: 3vw;
        margin-top: 70px;
    }
}

@media screen and (max-width: 780px) {
    #contact .btn {

    }

    #contact .btn p {
        font-size: 3vw;
    }
}


/*システムの詳細*/
#system {
    background: url('img/bg_06.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 8% 0 12%
}

#system .contents {
    width: 100%;
    background: #fff;
    border: 8px solid #f2f2f2;
    padding: 20px 0
}

#system h1 {
    color: #fff
}

#system .h1_bd {
    border-bottom: 4px solid #fff;
    padding-top: 50px;
    width: 220px;
    margin: 0 auto 50px
}

#system .box {
    width: 92%;
    margin: 0 auto
}

#system .point:nth-child(1) {
    padding: 20px 0 20px;
    width: 60%;
    margin: 0 auto 20px;
}

#system .point:nth-child(2) {
    padding: 20px 0 20px;
    width: 40%;
    margin: 0 auto 20px;
}

#system .point h3 {
    margin: 30px auto;
    font-weight: bold;
    line-height: 160%;
    font-size: 26px
}

#system .point h3 span {
    font-size: 80px;
    color: #25a2d4;
    font-family: 'Poppins', sans-serif;
}

#system .point p span {
    font-weight: bold;
    line-height: 160%;
    font-size: 17px;
    padding: 10px 15px;
    color: #fff
}

#system .point p {
    margin: 30px auto;
    font-weight: bold;
    line-height: 160%;
    margin-left: 90px;
    width: 80%;
    font-size: 19px
}

#system .point img {
    margin-top: 180px
}

#system .tag_1 {
    background: #72c6de;
}

#system .tag_2 {
    background: #3469ae
}

#system .tag_3 {
    background: #75babf
}

@media screen and (max-width: 1480px) {
    #system .contents {
        width: 84%
    }

    #system h1 {
        font-size: 48px;
    }

    #system .point p {
        font-size: 16px
    }

    #system .point h3 {
        font-size: 1.7vw
    }

    #system .point h3 span {
        font-size: 80px;
        color: #25a2d4;
        font-family: 'Poppins', sans-serif;
    }

    #system .point p span {
        font-weight: bold;
        line-height: 160%;
        font-size: 15px;
        background: #72c6de;
        padding: 10px 15px;
        color: #fff
    }

    #system .point p {
        margin: 30px auto;
        font-weight: bold;
        line-height: 160%;
        margin-left: 90px;
        width: 70%
    }
}

@media screen and (max-width: 980px) {
    #system h1 {
        font-size: 38px;
    }

    #system .point p {
        font-size: 16px
    }

    #system .point:nth-child(1) {
        padding: 20px 0 10px;
        width: 100%;
        margin: 0 auto 20px;
    }

    #system .point:nth-child(2) {
        padding: 0px 0 20px;
        width: 100%;
        margin: 0 auto 20px;
    }

    #system .point img {
        margin-top: 0px
    }

    #system .point h3 {
        font-size: 4vw
    }

    #system .point h3 span {
        font-size: 12vw;
        color: #25a2d4;
        font-family: 'Poppins', sans-serif;
    }

    #system .point p {
        margin: 30px auto 0;
        font-weight: bold;
        line-height: 160%;
        margin-left: 0px;
        width: 100%
    }

    #system .point p span {
        font-size: 13px;
        padding: 10px;
    }
}

@media screen and (max-width: 780px) {
    #system .contents {
        padding: 0px
    }

    #system h1 {
        font-size: 26px;
    }

    #system .point p {
        font-size: 15px
    }

}


/*料金プラン*/
#plan {
    background: url('img/bg_07.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 8% 0
}

#plan .contents {
    width: 100%
}

#plan h1 {
    text-align: center;
    margin-bottom: 30px
}

#plan .arrow_box {
    width: 310px;
}

#plan .txt {
    text-align: center;
    font-weight: bold;
    font-size: 25px;
    line-height: 160%;
    margin: 60px auto
}

.plan_style {
    margin: 0 auto 30px;
    width: 23%;
}

.plan_style:nth-child(1) {
    background: #56c5e8;
}

.plan_style:nth-child(2) {
    background: #25a2d4
}

.plan_style:nth-child(3) {
    background: #2a7dc0
}

.plan_style:nth-child(4) {
    background: #24499a
}

.plan_style table {
    width: 100%
}

.plan_style tr:nth-child(1) td {
    padding: 35px 0px 40px;
}

.plan_style:nth-child(1) tr:nth-child(1) td p {
    width: 72%;
    background: #fff;
    padding: 5px 0;
    color: #56c5e8;
    text-align: center;
    font-weight: bold;
    margin: 0 auto
}

.plan_style:nth-child(2) tr:nth-child(1) td p {
    width: 72%;
    background: #fff;
    padding: 5px 0;
    color: #25a2d4;
    text-align: center;
    font-weight: bold;
    margin: 0 auto
}

.plan_style:nth-child(3) tr:nth-child(1) td p {
    width: 72%;
    background: #fff;
    padding: 5px 0;
    color: #2a7dc0;
    text-align: center;
    font-weight: bold;
    margin: 0 auto
}

.plan_style:nth-child(4) tr:nth-child(1) td p {
    width: 72%;
    background: #fff;
    padding: 5px 0;
    color: #24499a;
    text-align: center;
    font-weight: bold;
    margin: 0 auto
}


.plan_style:nth-child(2) tr:nth-child(2) td p {
    width: 90%;
}

.plan_style:nth-child(3) tr:nth-child(2) td p {
    width: 90%;
}

.plan_style:nth-child(4) tr:nth-child(2) td p {
    width: 90%;
}

.plan_style tr:nth-child(2) td {
    padding: 0 0px 40px;
}

.plan_style tr:nth-child(2) td p {
    width: 86%;
    color: #fff;
    font-size: 56px;
    letter-spacing: -2px;
    text-align: right;
    line-height: 50%;
    font-weight: bold
}

.plan_style tr:nth-child(2) td p span {
    font-size: 30px;
}

.plan_style tr:nth-child(3) td {
    background: #fff;
}

.plan_style tr:nth-child(3) td p {
    font-size: 20px;
    text-align: center;
    line-height: 240%;
    border-bottom: 2px dotted #00117e;
    width: 72%;
    padding: 35px 0;
    margin: 0 auto;
    color: #00117e
}

.plan_style tr:nth-child(3) td p span {
    font-weight: bold;
    font-size: 30px
}

.plan_style tr:nth-child(4) td {
    background: #fff;
}

.plan_style tr:nth-child(4) td p {
    font-size: 20px;
    text-align: center;
    line-height: 240%;
    border-bottom: 2px dotted #00117e;
    width: 72%;
    padding: 35px 0;
    margin: 0 auto;
    color: #00117e
}

.plan_style tr:nth-child(4) td p span {
    font-weight: bold;
    font-size: 30px
}

.plan_style tr:nth-child(5) td {
    background: #fff;
}

.plan_style tr:nth-child(5) td p {
    font-size: 20px;
    text-align: center;
    line-height: 240%;
    width: 72%;
    padding: 35px 0;
    margin: 0 auto;
    color: #00117e
}

.plan_style tr:nth-child(5) td p span {
    font-weight: bold;
    font-size: 30px
}

.check {
    text-align: right
}

@media screen and (max-width: 1480px) {
    #plan h1 {
        font-size: 48px;
    }

    #plan .txt {
        font-size: 22px;
        margin: 40px auto
    }
}

@media screen and (max-width: 980px) {
    #plan .contents {
        width: 90%
    }

    #plan h1 {
        font-size: 38px;
    }

    #plan .txt {
        font-size: 18px;
        margin: 40px auto 20px
    }

    .plan_style tr:nth-child(2) td p {
        width: 82%;
        font-size: 38px;
        line-height: 55%;
    }

    .plan_style tr:nth-child(2) td p span {
        font-size: 20px;
    }

    .plan_style tr:nth-child(3) td p {
        font-size: 16px;
    }

    .plan_style tr:nth-child(3) td p span {
        font-size: 22px
    }

    .plan_style tr:nth-child(4) td p {
        font-size: 16px;
    }

    .plan_style tr:nth-child(4) td p span {
        font-size: 22px
    }

    .plan_style tr:nth-child(5) td p {
        font-size: 16px;
    }

    .plan_style tr:nth-child(5) td p span {
        font-size: 22px
    }
}

@media screen and (max-width: 780px) {

    #plan h1 {
        font-size: 26px;
    }

    #plan .txt {
        font-size: 16px;
        margin: 40px auto
    }

    .plan_style {
        width: 100%;
    }

    .plan_style tr:nth-child(1) td p {
        width: 90%;
        background: #fff;
        padding: 5px 0;
        color: #56c5e8;
        text-align: center;
        font-weight: bold;
        margin: 0 auto
    }

    .plan_style tr:nth-child(2) td p {
        width: 90%;
        font-size: 42px;
        line-height: 0;
        line-height: 30%;
        margin: 0 auto;
        text-align: center
    }

    .plan_style tr:nth-child(2) td p span {
        font-size: 20px;
    }

    .plan_style tr:nth-child(3) td p {
        font-size: 16px;
        width: 90%
    }

    .plan_style tr:nth-child(3) td p span {
        font-size: 22px
    }

    .plan_style tr:nth-child(4) td p {
        font-size: 16px;
        width: 90%
    }

    .plan_style tr:nth-child(4) td p span {
        font-size: 22px
    }

    .plan_style tr:nth-child(5) td p {
        font-size: 16px;
        width: 90%
    }

    .plan_style tr:nth-child(5) td p span {
        font-size: 22px
    }
}


/*よくあるご質問*/
#faq {
    padding: 8% 0
}

#faq .contents {
    width: 100%
}

.h1_bd {
    border-bottom: 4px solid #25a2d4;
    padding-top: 50px;
    width: 220px;
    margin: 0 auto 50px
}

#reason .box {
    margin-top: 120px
}

#faq h1 {
    text-align: center
}

.q {
    background: #d9edf9;
    filter: drop-shadow(5px 5px 3px rgba(0, 0, 0, 0.3));
    padding: 60px 0;
    width: 100%;
    margin-bottom: 50px
}

.q h3 {
    font-size: 25px;
    color: #24499a;
    width: 90%;
    margin: 0 auto;
    border-bottom: 2px solid #00117e;
    padding-bottom: 50px;
    margin-bottom: 50px
}

.q p {
    width: 90%;
    margin: 0 auto;
    line-height: 160%
}

@media screen and (max-width: 1480px) {
    #faq h1 {
        font-size: 48px;
    }

    #faq .contents {
        width: 90%
    }
}

@media screen and (max-width: 980px) {
    #faq h1 {
        font-size: 38px;
    }

    .q {
        background: #d9edf9;
        filter: drop-shadow(5px 5px 3px rgba(0, 0, 0, 0.3));
        padding: 30px 0;
        width: 100%;
        margin-bottom: 30px
    }

    .q h3 {
        font-size: 20px;
        padding-bottom: 20px;
        margin-bottom: 20px
    }

    .q p {
        width: 90%;
        margin: 0 auto;
        line-height: 160%;
    }
}

@media screen and (max-width: 780px) {
    #faq h1 {
        font-size: 26px;
    }

    .h1_bd {
        border-bottom: 4px solid #25a2d4;
        padding-top: 50px;
        width: 220px;
        margin: 0 auto 50px
    }
}

/*フッター*/

footer {
    background: #333333;
    padding: 10px;
}

footer p {
    text-align: center;
    color: #fff;
    font-size: 16px;
    margin-top: 10px;
}

.footer_logo {
    text-align: center;
    margin: 50px auto
}

.footer_menu {
    display: flex;
    flex-wrap: wrap;
    max-width: 1160px;
    margin: 0 auto;
    width: 90%
}

.footer_menu li a {
    color: #fff;
    padding: 0 35px 0 0;
    font-size: 19px;
}

.footer_menu li:last-child a {
    padding: 0 0 0 0;
}

@media screen and (max-width: 980px) {
    .footer_menu {
        display: inline;
        text-align: center
    }

    .footer_menu li {
        margin-bottom: 30px
    }

    .footer_menu li a {
        color: #fff;
        padding: 0;
        font-size: 16px;
    }

    footer p {
        text-align: center;
        color: #fff;
        font-size: 13px;
        margin-top: 60px
    }

    .footer_logo img {
        width: 100%;
        max-width: 300px
    }
}


/* フェードイン用のCSS */
.slide-bottom {
    opacity: 0;
    transform: translateY(20px);
    transition: all 1.3s 0s ease-out;
}

.slide-bottom2 {
    opacity: 0;
    transform: translateY(20px);
    transition: all 1.3s 0.3s ease-out;
}

.slide-bottom3 {
    opacity: 0;
    transform: translateY(20px);
    transition: all 1.3s 0.6s ease-out;
}

.slide-left {
    opacity: 0;
    transform: translate(-20px, 0);
    transition: all 1s 0s ease-out;
}

.slide-left2 {
    opacity: 0;
    transform: translate(-20px, 0);
    transition: all 1s 0.3s ease-out;
}

.slide-left3 {
    opacity: 0;
    transform: translate(-20px, 0);
    transition: all 1s 0.6s ease-out;
}

.slide-left4 {
    opacity: 0;
    transform: translate(-20px, 0);
    transition: all 1s 0.9s ease-out;
}

