@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap');

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
html {
    font-size: 10px;
}

body,
body input,
body textarea,
body button {
    position: relative;
    -webkit-text-size-adjust: 100%;
    font-family: "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, "Yu Gothic", YuGothic, "メイリオ", Meiryo, sans-serif;
}

body {
    color: #261008;
    font-size: 1.5rem;
    font-weight: 400;
    line-height: 2.8rem;
    letter-spacing: 0.05rem;
}

iframe {
    display: block;
}

.header_home {
    width: 100%;
}

    .header_catch{
        background-color: #c61f1e;
        color: #fff;
        font-size: .9em;
        text-indent: 1em;
        padding: 5px 0;
    }

    .header_wrap {
        width: 94%;
        position: relative;
        margin: 0 auto;
        display: -webkit-flex;
        display: -ms-flex;
        display: flex;
        justify-content: space-between;
        -ms-align-items: center;
        align-items: center;
        padding: 30px 0;
    }

        .logo {
            transition: all.5s;
        }

            .logo:hover {
                opacity: 0.7;
            }

        .header_nav{
            background-color: #c61f1e;
            min-width: 430px;
            max-width: 800px;
            width: 100%;
            margin-left: 10px;
        }
            .header_nav_wrap {
                display: -ms-flex;
                display: -webkit-box;
                display: -ms-flexbox;
                display: flex;
                -webkit-box-pack: space-between;
                -ms-flex-pack: space-between;
                justify-content: space-between;
            }

            .header_nav_list {
                text-align: center;
                width: 24%;
                box-sizing: border-box;
                padding: .8em 0;
                position: relative;
            }
                .header_nav_list::after{
                    content: "";
                    width: 1px;
                    height: 70%;
                    background-color: #fff;
                    display: block;
                    position: absolute;
                    right: 0;
                    top:15%;
                }
                    .header_nav_list:last-child::after{
                        display: none;
                    }

                .gmenu {
                    display: block;
                    text-decoration: none;
                    color: #fff;
                    font-size: 1.6rem;
                    font-weight: 500;
                    letter-spacing: 0.2rem;
                    -webkit-transition: all 0.5s;
                    transition: all 0.5s;
                    position: relative;
                    height: 100%;
                    width: 100%;
                }

                    .gmenu::after {
                        position: absolute;
                        bottom: -5px;
                        left: 0;
                        content: '';
                        width: 100%;
                        height: 2px;
                        background: #f3d18a;
                        -webkit-transform: scale(0, 1);
                        transform: scale(0, 1);
                        -webkit-transform-origin: right top;
                        transform-origin: right top;
                        -webkit-transition: -webkit-transform .3s;
                        transition: -webkit-transform .3s;
                        transition: transform .3s;
                        transition: transform .3s, -webkit-transform .3s;
                    }

                    .gmenu:hover {
                        color: #f3d18a;
                    }

                    .gmenu:hover::after {
                        -webkit-transform-origin: left top;
                        transform-origin: left top;
                        -webkit-transform: scale(1, 1);
                        transform: scale(1, 1);
                    }

        .mv {
            width: 100%;
            height:60vh;
            background: url("../img/mv.jpg") no-repeat center;
            background-size: cover;
            position: relative;
        }
        .top_body .mv{            
            background: url("../img/top_mv.jpg") no-repeat center;
            background-size: cover;
        }
.mv a{
    color: #261008;
}
            .mv_copy {
                font-size: 1.2em;
                background:  url("../img/mv_copy.png") no-repeat right;
                background-size: auto 100%;
                position: absolute;
                right: 0;
                top: 9%;
                width: 50%;
                padding: 2em 0;
            }

                .mv_copy p{
                    text-align: center;
                    margin-left: auto;
                    margin-right: 5%;
                    max-width:330px;
                    font-family: "font-family: 'Noto Sans JP', sans-serif;";
                    font-weight: 400;
                }

            .mv_detail {
                box-sizing: border-box;
                background: #fff;
                border-radius: 20px;
                position: absolute;
                padding: 1.8em 1em;
                left: 5%;
                bottom: 10%;
                border: 6px solid #c61f1e;
                box-shadow: 0px 0px 15px 6px #c61f1e;
                max-width: 640px;
                width: 100%
            }

                .mv_detail .flex-box{
                    display: flex;
                    justify-content: space-around;
                }

                    .mv_detail .flex-box>div{
                        text-align: center;
                        padding: 5px;
                    }

                        .mv_detail .flex-box h2{
                            font-size: 2em;
                            background:  #c61f1e;
                            color: #fff;
                            letter-spacing: 2px;
                            max-width:6em;
                            margin: 0 auto 30px;
                            padding: .5em 0 ;
                        }

                        .mv_detail .flex-box p{
                            font-size: 1.3em;
                            font-weight: bold;
                        }

                            .mv_detail .flex-box span{
                                font-size: 2.2em;
                                font-family: "font-family: 'Noto Sans JP', sans-serif;";
                                font-weight: bold;
                                color: #c61f1e;
                                letter-spacing: 4px;
                            }

                .mv_detail .flex-box dl{
                    font-weight: bold;
                    padding-left: 20px;
                }

                    .mv_detail .flex-box dt{
                        font-size: 1.5em;
                        font-weight: bold;
                        text-align: center;
                        line-height: 1.5;
                        margin-bottom: 20px;
                        letter-spacing: 1px;
                    }

                    .mv_detail .flex-box dd{
                        box-sizing: border-box;
                        color: #c61f1e;
                        font-weight: bold;
                        width: 90%;
                        margin: 0 auto;
                        font-size: .9em;
                        line-height: 1.7;
                    }

            .scroll_btn_wrap {
                position: absolute;
                bottom: 10px;
                left: 0;
                right: 0;
                margin: 0 auto;
                text-align: center;
                    }
            a#scroll_btn {
                position: absolute;
                  z-index: 2;
                  display: inline-block;
                  -webkit-transform: translate(0, -50%);
                  transform: translate(0, -50%);
                  text-decoration: none;
                  padding-bottom: 70px;
                color: #c61f1e;
                text-shadow: 1px 1px 15px #fff;
                font-weight: bold;
                }
                a#scroll_btn span {
                  position: absolute;
                  top: 0;
                  left: 50%;
                  width: 24px;
                  height: 24px;
                  margin-left: -12px;
                  border-left: 2px solid #c61f1e;
                  border-bottom: 2px solid #c61f1e;
                  -webkit-transform: rotate(-45deg);
                  transform: rotate(-45deg);
                  -webkit-animation: sdb 1.5s infinite;
                  animation: sdb 1.5s infinite;
                  box-sizing: border-box;
                }
                @-webkit-keyframes sdb {
                  0% {
                    -webkit-transform: rotate(-45deg) translate(0, 0);
                    opacity: 0;
                  }
                  50% {
                    opacity: 1;
                  }
                  100% {
                    -webkit-transform: rotate(-45deg) translate(-30px, 30px);
                    opacity: 0;
                  }
                }
                @keyframes sdb {
                  0% {
                    transform: rotate(-45deg) translate(0, 0);
                    opacity: 0;
                  }
                  50% {
                    opacity: 1;
                  }
                  100% {
                    transform: rotate(-45deg) translate(-30px, 30px);
                    opacity: 0;
                  }
                }
    .container {
        width: 100%;
    }

        .container>section{
            padding: 100px 0;
            margin: 0 auto;
        }

/*-- section1 --*/

#sec1 .box_wrap{
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}
    #sec1 .box_wrap>div{
        width: 33%;
        text-align: center;
        min-width: 380px;
        max-width: 480px;
        margin-bottom: 5%;
    }

        #sec1 .box_wrap h2{
            text-align: left;
            line-height: 1.5;
            height: 70px;
            margin-bottom: 15px;
            display: flex;
            justify-content: center;
            align-items: center;
        }

            #sec1 .box1 h2::before{
                content: "";
                display: block;
                width: 63px;
                height: 62px;
                background: url("../img/sec1_h2_1.png") no-repeat center;
                background-size: cover;
                margin-right: 30px
            }

            #sec1 .box2 h2::before{
                content: "";
                display: block;
                width: 63px;
                height: 62px;
                background: url("../img/sec1_h2_2.png") no-repeat center;
                background-size: cover;
                margin-right: 30px
            }

            #sec1 .box3 h2::before{
                content: "";
                display: block;
                width: 63px;
                height: 62px;
                background: url("../img/sec1_h2_3.png") no-repeat center;
                background-size: cover;
                margin-right: 30px
            }

        #sec1 .text_area{
            background: #c61f1e;
            border-radius: 20px;
            padding: 1em 5px;
            box-sizing: border-box;
            position: relative;
            z-index: 1;
        }

            #sec1 .text_area::after{
                border: solid transparent;
                content:'';
                height:0;
                width:0;
                pointer-events:none;
                position:absolute;
                border-color: rgba(198, 31, 30, 0);
                border-top-width:19px;
                border-bottom-width:19px;
                border-left-width:15px;
                border-right-width:15px;
                margin-left: -15px;
                border-top-color:#c61f1e;
                top:100%;
                left:20%;
            }

            #sec1 .text_area p{
                color: #fff;
                font-size: 1.2em;
                letter-spacing: 1px;
                padding: .3em 0;
            }

            #sec1 .text_area p.deco{
                font-size: 2.3rem;
                margin: .3em auto 5px;
                position: relative;
            }

                #sec1 .box1 .text_area p.deco::before{
                    content: "・・・・・・・・・・・・";
                    color: #f9ef53;
                    display: block;
                    top: -.5em;
                    position: absolute;
                    left: 0;
                    width: 100%;
                }

                #sec1 .box2 .text_area p.deco::before{
                    content: "・・・・・・・・・・・・・・　";
                    color: #f9ef53;
                    display: block;
                    top: -.5em;
                    position: absolute;
                    left: 0;
                    width: 100%;
                }

                #sec1 .box3 .text_area p.deco::before{
                    content: "・・・・・・・・・・・";
                    color: #f9ef53;
                    display: block;
                    top: -.5em;
                    position: absolute;
                    left: 0;
                    width: 100%;
                }

            #sec1 .contents img{
                width: 93%;
            }

        #sec1 .contents h3{
            font-size: 2.5rem;
            border-radius: 50px;
            padding: .6em;
            color: #fff;
            width: 60%;
            margin: 25px auto 0;
            min-width: 10em;
        }

            #sec1 .box1 h3{
                background: #db9cc5;
            }

            #sec1 .box2 h3{
                background: #99cedd;
            }

            #sec1 .box3 h3{
                background: #b1c482;
            }

    #sec1 .box_wrap>div.box4{
        width: 100%;
        min-width: none;
        max-width: none;
        margin-right: auto;
        margin-bottom: 0;
        }

        #sec1 .box4 p{
            background: url("../img/sec1_box4_bg.png") no-repeat center;
            background-size: cover;
            font-size: 1.5em;
            width: 200px;
            padding: 1em 0 2em 1em;
            margin: auto;
        }

/*-- section2 --*/

#sec2{
    background: url("../img/sec2_bg.png") repeat;
    background-size: 1100px 1100px;
    padding-top: 0;
}

    .headline{
        background: #c61f1e;
        padding: 20px 0 ;
        margin-bottom: 100px;
        position: relative;
    }

        .headline p{
            text-align: center;
            color: #fff;
            font-size: 2rem;
            letter-spacing: 2px;
            line-height: 2em;
        }

            .headline p>span{
                border-bottom: 2px solid #fff;
                padding:0 5px 5px; 
            }

                .headline p>span span{
                    font-size: 1.5em;
                    font-weight: bold;
                    margin: 0 15px;
                }

        .headline_arrow{
            width: 0px;
          border-color: #c61f1e;
          border-style: solid;
          border-width: 60px;
          border-left-color: transparent;
          border-top-color: transparent;
          border-right-color: transparent;
            position: absolute;
          -ms-transform: rotate(180deg);
          -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
            left: 0;
            right: 0;
            bottom: -130px;
            margin: 0 auto;
        }

            .headline_arrow::before{
                background: #c61f1e;
                content: "";
                display: block;
                width: 40px;
                height: 10px;
                position: absolute;
                left: -20px;
                right: 0;
                bottom: -70px;
                margin: 0 auto;
            }

    #sec2 .box{
        background: #fff;
        border: solid 3px #888888;
        border-radius: 20px;
        box-sizing: border-box;
        display: flex;
        justify-content: space-between;
        align-items: center;
        line-height: 3em;
        margin: 20px auto 80px;
        padding: 30px ;
        max-width: 1200px;
        width: 98%;
    }

        #sec2 .box img{
            max-width: 360px;
            width: 100%;
            min-width: 300px;
        }

        #sec2 .text_area{
            box-sizing: border-box;
            padding: 20px 0 20px 30px;
        }

            #sec2 .box h2{
                font-size: 1.6em;
                letter-spacing: 3px;
                margin-bottom: 30px;
                z-index: 2;
            }

                #sec2 .box h2 span:first-child{
                    color: #c61f1e;
                }

                #sec2 .box h2 small{
                    font-size: 1.1rem;
                    display: inline-block;
                    float: right
                }

/*-- section3 --*/

section.contact_sec{
    border: 25px solid #c61f1e;
    box-sizing: border-box;
    padding: 40px 0 20px;
}

    section.contact_sec .box{
        text-align: center;
        width: 100%;
        min-width: 300px;
        max-width: 980px;
        margin: 0 auto;
    }

        section.contact_sec .text_area{
            line-height: 4em;
        }

            section.contact_sec h2{
                font-size: 2em;
                font-weight: normal;
                border-bottom: 2px solid #261008;
                max-width: 11em;
                margin: 0 auto 30px;
                letter-spacing: 3px;
            }

                section.contact_sec .tel a{
                    text-decoration: none;
                    font-size: 2em;
                    letter-spacing: 3px;
                    font-weight: bold;
                    color: #261008;
                }

                section.contact_sec p{
                    font-size: 1.4em;
                    letter-spacing: 2px;
                    margin: 30px auto;
                }

            section.contact_sec .btn_area{
                display: flex;
                flex-wrap: wrap;
                justify-content: space-around;
            }

                section.contact_sec .btn_wrap{
                    width: 98%;
                    max-width: 350px;
                    min-width: 280px;
                    margin: 40px auto 25px;
                }

                section.contact_sec p small{
                    font-size: 80%;
                }

/*-- section4 --*/

#sec4{
    text-align: center;
}

    #sec4 h2{
        margin-bottom: 60px;
        letter-spacing: 3px;
    }

    #sec4 img{
        max-width: 730px;
        width: 100%;
    }

    #sec4 p{
        text-align: left;
        max-width: 700px;
        margin: 0 auto;
        padding-top:60px; 
    }

/*-- section5 --*/
section#sec5 {
    padding-top: 0;
}
#sec5 .box_wrap{
    border: 1px solid #c61f1e;
    box-sizing: border-box;
    box-shadow: 0px 0px 10px 2px #c61f1e;
    border-radius: 20px;
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    max-width:1200px;
    width: 98%;
    margin: -40px auto 0;
    padding: 80px 20px;
}

    #sec5 h2{
        text-align: center;
        width: 100%;
        font-size: 1.8em;
        margin-bottom: 70px;
        line-height: 1.5em;
    }

    #sec5 .box{
        width: 100%;
        max-width: 500px;
        min-width: 300px;
        box-sizing: border-box;
        padding: 10px 10px 60px;
    }

        #sec5 .box img{
            width: 100%;
            margin-bottom: 1em;
        }

    #sec5 .movie_wrap h3 span{
        padding:0 .5em .5em;
    }

        .movie{
            text-align: center;
            margin: 40px auto 0;
            padding:0 10px;
        }

         .movie iframe{
                width: 100%;
                max-width: 600px;
             min-width: 200px;
                margin: 0 auto;
             height: 400px;
            }

/*-- section6 --*/

    #sec6 .inner_1{
        background: url("../img/sec6_bg_1.png") no-repeat center;
        background-size: cover;
        width: 100%;
        padding: 40px 0;
        margin: 60px auto;
    }

    #sec6 .inner_2{
        background: url("../img/sec6_bg_2.png") no-repeat center;
        background-size: cover;
        width: 100%;
        padding: 40px 0;
        margin: 60px auto;
    }

        #sec6 .box_wrap{
            max-width: 1400px;
            display: flex;
            justify-content: space-around;
            flex-wrap: wrap;
            width: 100%;
            margin: 0 auto;
        }

        #sec6 .inner_1 .box_wrap{
            flex-direction: row-reverse;
        }

            #sec6 .box1{
                background: #eef3cd;
                box-sizing: border-box;
                display:flex;
                justify-content: space-around;
                align-items: center;
                border: solid 3px #c61f1e;
                border-radius: 20px;
                width: 100%;
                max-width: 600px;
                padding:40px 20px;
                position: relative;
            }

                #sec6 .box1 figure{
                    width: 210px;
                    height: 250px;
                    border: #c61f1e dashed 3px;
                    border-radius: 2px;
                    padding: 5px;
                }

                    #sec6 .box1 figure img{
                        width:100%;
                    }

                #sec6 .box1 li{
                    font-size: 1.4rem;
                }

            #sec6 .box2{
                background: #fdf8d8;
                box-sizing: border-box;
                display: flex;
                align-items: center;
                border: solid 3px #c61f1e;
                border-radius: 20px;
                width: 100%;
                max-width: 600px;
                padding:40px;
                position: relative;
            }

                #sec6 .box2 dl{
                    font-size: 1.4rem;
                    padding-left: 20px;
                }

                    #sec6 .box2 dt{
                        padding-bottom: .4em;
                        position: relative;
                    }
                        #sec6 .box2 dt::before{
                            content: "";
                            display: inline-block;
                            width: 15px;
                            height: 15px;
                            background: url("../img/qa_q.png") no-repeat center;
                            background-size: cover;
                            position: absolute;
                            top:.5em;
                            left: -25px;
                        }

                    #sec6 .box2 dd{
                        padding-bottom: 1.3em;
                        position: relative;
                    }

                        #sec6 .box2 dd::before{
                            content: "";
                            display: inline-block;
                            width: 15px;
                            height: 15px;
                            background: url("../img/qa_a.png") no-repeat center;
                            background-size: cover;
                            position: absolute;
                            top:.5em;
                            left: -25px;
                        }

            #sec6 .box_wrap .box{
                width: 100%;
                box-sizing: border-box;
                padding: 10px;
                max-width: 650px;
                margin: 0 auto;
            }

                #sec6 .box_wrap .box img{
                    width: 100%;
                }

                #sec6 .img_mastery{
                    background: url("../img/img_mastery.png") no-repeat center;
                    background-size: cover;
                    position: absolute;
                    bottom: -15px;
                    right: -30px;
                    width: 266px;
                    height: 107px;
                }

                #sec6 .img_fresh{
                    background: url("../img/img_fresh.png") no-repeat center;
                    background-size: cover;
                    position: absolute;
                    bottom: -15px;
                    right: -30px;
                    width: 267px;
                    height: 125px;
                }

/*-- section7 --*/
/*-- section8 --*/

    #sec8 .box_wrap{
        display: flex;
        flex-wrap: wrap;
    }

        #sec8 h2{
            background: url("../img/sec8_h2_bg.png") no-repeat;
            background-position: center top;
            background-size: auto 380px;
            width: 20%;
            height: 100%;
            min-height: 450px;
        }

        #sec8 .box{
            background: #c61f1e;
            padding: 40px 30px;
            width: 80%;
            align-items: center;
        }

            #sec8 .box p{
                color: #fff;
                font-size: 1.7rem;
                line-height: 2em
            }

    #sec8 .name_wrap{
        display: flex;
        justify-content: flex-end;
        padding: 60px 7% 60px 0;
    }

        #sec8 .name_wrap h3{
            border: #c61f1e 7px solid;
            text-align: center;
            max-width: 400px;
            width: 100%;
            padding: 0.7em 0;
            font-size: 2.8rem;
            line-height: 1.7em;
        }

    #sec8 .movie_wrap{
        text-align: center;
        padding-top: 60px;
    }

        #sec8 .movie_wrap h3{
            font-size: 2.5rem;
            letter-spacing: 2px;
            display: flex;
            justify-content: center;
            align-items: center;
        }

            #sec8 .movie_wrap h3 span.side_line{
                background: #c61f1e;
                width: 13%;
                height: 5px;
                box-sizing: border-box;
            }

            #sec8 .movie_wrap h3 span.dot_ul{
                padding: 0 0 10px;
                border-bottom: dotted #c61f1e 10px;
                background: #fff;
                margin: 0 2%;
                line-height: 1.5em;
            }

        #sec8 .movie{
            margin: 80px auto 20px;
        }

/*-- section9 --*/

#sec9{
    background: #fdf8d8;
    padding-top: 0;
}

    #sec9 .box_wrap{
        display: flex;
        justify-content: space-around;
        flex-wrap:wrap;
        width: 98%;
        max-width: 1400px;
        margin: 0 auto;
    }

        #sec9 .box{
            width: 100%;
            max-width: 380px;
            text-align: center;
            margin-bottom: 60px;
        }

            #sec9 .box img{
                width: 100%;
            }

            #sec9 .text_area::before{
                background: #261008;
                content: "";
                display: block;
                height: 2px;
                width: 300px;
                margin: 30px auto;
            }

            #sec9 .text_area::after{
                background: #261008;
                content: "";
                display: block;
                height: 2px;
                width: 300px;
                margin: 30px auto 0;
            }

            #sec9 .box p{
                line-height: 2em;
                padding: 20px 0 0;
            }

/*-- section10 --*/

#sec10{
    background: #fdf8d8;
    padding-top: 0;
    border-bottom: dotted #c61f1e 10px;
}

    #sec10 h2{
        margin: 50px auto;
        font-size: 160%;
    }

    #sec10 .box_wrap{
        width: 98%;
        margin: 0 auto;
        max-width: 1400px;
    }

        #sec10 .box{
            display: flex;
            align-items: center;
            justify-content: space-around;
            flex-wrap: wrap;
            padding: 20px;
        }

            #sec10 .box img{
                max-width: 500px;
                min-width: 300px;
                width: 100%;
            }

            #sec10 .text_area{
                font-size: 2rem;
                font-weight: bold;
                line-height: 2em;
                width: 55%;
            }

                #sec10 ul{
                    list-style: none;
                }

/*-- section11 --*/

#sec11 .table_wrap{
    background: #fffcf0;
    max-width: 1400px;
    width: 98%;
    margin: 0 auto;
    border-bottom-left-radius: 40px;
    border-bottom-right-radius: 40px;
}

    #sec11 table{
        column-span: none;
        font-size: 2rem;
        letter-spacing: 2px;
        line-height: 2em;
        width: 100%;
    }

        #sec11 h2{
            background: #c61f1e;
            color: #fff;
            text-align: center;
            font-size: 4rem;
            padding: 1em 0;
            border-top-left-radius: 40px;
            border-top-right-radius: 40px;
        }

        #sec11 tbody{
            display: block;
            padding: 40px;
            width: 98%;
            margin: 20px auto  0;
        }

            #sec11 tr{
                display: flex;
                width: 100%;
                border-top:#302522 1px solid;
                padding: 1.3em;
            }

                #sec11 th{
                    text-align: left;
                    width: 30%;
                    display: block;
                }

                #sec11 td{
                    width: 70%;
                    display: block;
                }

/*-- section12 --*/

#sec12{
    background: #c61f1e;
    padding: 50px 0;
}

#sec12 .form_wrap{
    background: #fff;
    max-width: 980px;
    width: 98%;
    margin: 0 auto;
    box-sizing: border-box;
    padding:  30px 0;
    border-radius: 40px;
}

#sec12 .form_wrap h3{
    width: 90%;
    max-width: 600px;
    margin: 80px auto 40px;
}

#sec12 h2{
    text-align: center;
    font-size: 3rem;
}

#sec12 form{
    width: 90%;
    max-width: 600px;
    margin: 30px auto;
}

form dl dt {
    margin-bottom: .3em;
    font-size: 1.1em;
}

form dl dd {
    margin-bottom: 2em;
    font-size: 1.1em;
}

form dl dt span{
    background: #c61f1e;
    color: #fff;
    font-size: 1rem;
    margin-left: 2em;
    padding: 2px 5px;
    letter-spacing: 2px;
}

form dl dd input,form dl dd textarea{
    background: #EBEBEB;
    border: solid 1px #A2A1A1;
}

form dl dd input.text{
    min-height: 2.5em;
    width: 100%;
}

form dl dd.radio{
    padding-left: 1em;
}

form dl dd.radio span{
    margin-left: 10%;
}

form dl dd.radio span:first-child{
    margin-left: 0;
}

form dl dd.age input{
    min-height: 2.5em;
    min-width: 5em;
}

form dl dd.tel{
    position: relative;
}
form dl dd.tel input{
    min-height: 2.5em;
    width: 50%;
}

form dl dd.tel::after{
    content: "ハイフンなし可";
    font-size: 1.2rem;
    padding-left: 2em;
    position: absolute;
    bottom:0;
}

form dl dd textarea{
    width: 100%!important;
    min-height: 8em;
}

.submit button.btn{
    font-size: 1.7rem;
    max-width: 250px;
    margin: 0 auto;
    padding: 10px 25px;
    border-radius: 8px;
    box-shadow: 5px 5px 15px 1px rgb(135,28,33,0.9);
    text-shadow: none;


}

/*-- footer --*/

footer .container{
    padding: 100px 0 20px;
    text-align: center;
}

.copyright {
    margin-top: 40px;
    font-size: 1.2rem;
    line-height: 2px;
}

/*-- commmon --*/

.jc_center {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    justify-content: center;
}

.btn {
    background: #c61f1e;
    border-radius: 20px;
    text-decoration: none;
    display: block;
    color: #fff;
    font-size: 2em;
    text-align: center;
    padding: 30px 0;
    width: 100%;
    letter-spacing: 0.2em;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    position: relative;
    overflow: hidden;
    z-index: 10;
    box-shadow: 8px 8px 10px 3px rgb(135,28,33);
}

.btn::before {
    position: absolute;
    top: 0;
    right: -50px;
    bottom: 0;
    left: 0;
    border-right: 100px solid transparent;
    border-bottom: 100px solid #f3d18a;
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    content: "";
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    z-index: -1;
}

.btn:hover {
    color: #c61f1e;;
}

.btn:hover::before {
    -webkit-transform: translateX(0);
    transform: translateX(0);
}


.fixed {
    position: fixed !important;
    width: 100%;
    height: 100%;
}


.txt12_grey {
    font-size: 1.2rem;
    color: #fff;
    font-weight: 400;
    line-height: 1.8rem;
    padding-left: 10px;
}


.txt12 {
    font-size: 1.2rem;
}

.txt12_left {
    font-size: 1.2rem;
    text-align: left
}

.mr30 {
    margin-right: 30px;
}

.mr20 {
    margin-right: 20px;
}

.mb20 {
    margin-bottom: 20px;
}

.mb60 {
    margin-bottom: 60px;
}

.mt10 {
    margin-top: 10px;
}

.mt10 {
    margin-top: 10px;
}

.mt20 {
    margin-top: 20px;
}

.mt30 {
    margin-top: 30px;
}

.mt40 {
    margin-top: 40px;
}

.mt50 {
    margin-top: 50px;
}

.pt50 {
    padding-top: 50px;
}

.db {
    display: block;
}

.ta_center {
    text-align: center;
}


.ta_right {
    text-align: right;
}

.ta_center_pc {
    text-align: center;
}
.y_ul{
    background: url("../img/y_ul_bg.png");
}

@keyframes scale {
    0% {
        transform: scale(1.2);
    }
    100% {
        transform: scale(1);
    }
}

@-webkit-keyframes sk-foldCubeAngle {
    0%,
    10% {
        -webkit-transform: perspective(140px) rotateX(-180deg);
        transform: perspective(140px) rotateX(-180deg);
        opacity: 0;
    }
    25%,
    75% {
        -webkit-transform: perspective(140px) rotateX(0deg);
        transform: perspective(140px) rotateX(0deg);
        opacity: 1;
    }
    90%,
    100% {
        -webkit-transform: perspective(140px) rotateY(180deg);
        transform: perspective(140px) rotateY(180deg);
        opacity: 0;
    }
}

@keyframes sk-foldCubeAngle {
    0%,
    10% {
        -webkit-transform: perspective(140px) rotateX(-180deg);
        transform: perspective(140px) rotateX(-180deg);
        opacity: 0;
    }
    25%,
    75% {
        -webkit-transform: perspective(140px) rotateX(0deg);
        transform: perspective(140px) rotateX(0deg);
        opacity: 1;
    }
    90%,
    100% {
        -webkit-transform: perspective(140px) rotateY(180deg);
        transform: perspective(140px) rotateY(180deg);
        opacity: 0;
    }
}

#page-top {
    font-size: 0;
    position: fixed;
    bottom: 6px;
    right: 6px;
    opacity: 0;
    background: #c61f1e;
    height: 40px;
    width: 40px;
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}
#page-top.fade-in {
    color: #fff;
    font-size: 1.2rem;
    opacity: 0.6;
    transition: opacity 1s;
    text-align: center;
}
.mv_detail .note{
    text-align: center;
    position: relative;
    top: 10px;
    font-size: 120%;
    font-weight: bold;
    text-decoration: underline;
}