.box-shared {
    position: relative;
    background: url("../img/shared/bg3.jpg") repeat center;
    padding: 10vw 8%
}

.box-shared::before {
    content: "";
    position: absolute;
    inset: 2vw;
    border: 1px solid #9d9880
}

.box-shared h4 {
    text-align: center;
    line-height: 1;
    letter-spacing: .1em
}

.box-shared .list {
    margin-top: 5vw
}

.box-shared .list .child {
    position: relative;
    padding-left: 15px;
    margin-left: 8px
}

.box-shared .list .child::before {
    content: "";
    position: absolute;
    top: 10px;
    bottom: 10px;
    left: 0;
    background: #9d9880;
    width: 1px
}

@media screen and (min-width: 768px) {
    .box-shared {
        width: 680px;
        padding: 44px 49px 27px 50px
    }

    .box-shared::before {
        inset: 10px
    }

    .box-shared h4 {
        text-align: left
    }

    .box-shared .list {
        display: flex;
        justify-content: space-between;
        margin-top: 14px
    }

    .box-shared .list .child::before {
        top: 0px;
        bottom: 0px
    }
}

#sec1 {
    background: url("../img/course/sec1_deco.png") no-repeat right top/60%;
    padding-top: 20vw
}

#sec1 .set1 h2 {
    text-align: center;
    line-height: 2;
    letter-spacing: .1em
}

#sec1 .set1 h2 span {
    letter-spacing: .1em
}

#sec1 .set1 .txt {
    margin-top: 5vw
}

#sec1 .set2 {
    background: url("../img/course/sec1_deco2.png") no-repeat center/200%;
    margin-top: 10vw
}

#sec1 .set2 h3 {
    text-align: center;
    background: url("../img/course/sec1_deco_ttl.png") no-repeat center bottom/100%;
    width: 70%;
    margin: 0 auto;
    padding-bottom: 5.5vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec1 .set2 .group-link {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    row-gap: 5vw;
    margin-top: 5vw
}

#sec1 .set2 .group-link li {
    width: 48%
}

#sec1 .set2 .group-link li a {
    position: relative;
    display: block
}

#sec1 .set2 .group-link li a::before {
    content: "";
    position: absolute;
    inset: 2vw 2vw 6vw;
    border: 1px solid #9d9880
}

#sec1 .set2 .group-link li a .txt {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    background: url("../img/shared/bg2.jpg") repeat center;
    color: #fff;
    height: 35vw;
    font-size: 3.7vw;
    line-height: 1.9;
    letter-spacing: .1em
}

#sec1 .set2 .group-link li a .arrow {
    position: relative;
    z-index: 1;
    width: 30%;
    margin: 4vw auto 0
}

#sec1 .set2 .group-link li:last-child {
    margin: 0 auto
}

#sec1 .set3 {
    margin-top: 10vw
}

#sec1 .set3 .box-parallax {
    height: 70vw
}

@media screen and (min-width: 768px) {
    #sec1 {
        background-size: auto;
        padding-top: 138px
    }

    #sec1 .set1 .group-txt {
        margin: 0 auto;
        padding-left: 80px
    }

    #sec1 .set1 h2 {
        text-align: left;
        line-height: 103px;
        margin-left: 89px
    }

    #sec1 .set1 .txt {
        margin-top: 0
    }

    #sec1 .set2 {
        background-position: center bottom;
        background-size: 100%;
        padding-bottom: 133px;
        margin-top: 88px
    }

    #sec1 .set2 .wrap {
        max-width: 1200px
    }

    #sec1 .set2 h3 {
        width: 376px;
        padding-bottom: 32px
    }

    #sec1 .set2 .group-link {
        flex-wrap: nowrap;
        gap: 30px;
        max-width: 1146px;
        margin: 37px auto 0
    }

    #sec1 .set2 .group-link li {
        max-width: 355px;
        width: 100%
    }

    #sec1 .set2 .group-link li a::before {
        inset: 23px 23px 42px
    }

    #sec1 .set2 .group-link li a .txt {
        height: 240px;
        font-size: 30px;
        transition: .3s
    }

    #sec1 .set2 .group-link li a .arrow {
        width: -moz-fit-content;
        width: fit-content;
        margin: 22px auto 0
    }

    #sec1 .set2 .group-link li a:hover .txt {
        background: #eeddbd;
        color: #000
    }

    #sec1 .set2 .group-link li:last-child {
        margin: 0
    }

    #sec1 .set3 {
        margin-top: 0
    }

    #sec1 .set3 .box-parallax {
        height: 780px
    }
}

#sec2 {
    background: url("../img/course/sec2_deco.png") no-repeat left top/60%;
    padding: 5vw 0 20vw
}

#sec2 .set1 .note1 {
    text-align: right;
    margin-right: -2%
}

#sec2 .set1 .photo1 {
    margin-top: 3vw
}

#sec2 .set1 .box1 {
    margin-top: 7vw
}

#sec2 .set1 .box1 h2 {
    background: url("../img/course/sec2_set1_deco_ttl.png") no-repeat center bottom/100%;
    width: 85%;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 4vw;
    letter-spacing: .1em
}

#sec2 .set1 .box1 h2 small {
    letter-spacing: .1em
}

#sec2 .set1 .box1 .price1 {
    background: #fffaf0;
    width: -moz-fit-content;
    width: fit-content;
    margin: 5vw auto 0;
    padding: 0 2vw;
    line-height: 1.5454545455;
    letter-spacing: .1em
}

#sec2 .set1 .box1 .price1 span {
    margin-left: 1.5vw;
    letter-spacing: .1em
}

#sec2 .set1 .box1 .price2 {
    text-align: center;
    margin-top: 5vw;
    line-height: 1.6;
    letter-spacing: .1em
}

#sec2 .set1 .box1 .price2 span {
    margin-left: 1.5vw
}

#sec2 .set1 .box1 .note2 {
    text-align: center;
    margin-top: 5vw
}

#sec2 .set1 .box1 .txt {
    margin-top: 5vw
}

#sec2 .set1 .box2 {
    margin-top: 10vw
}

#sec2 .set1 .photo2 {
    margin-top: 10vw
}

#sec2 .set2 {
    position: relative;
    margin-top: 10vw
}

#sec2 .set2 .deco {
    position: absolute;
    bottom: -30vw;
    right: 0;
    z-index: 1;
    width: 40%
}

#sec2 .set2 .wrap {
    border: 1px solid #bfaa83;
    border-radius: 25px;
    margin: 0 3%;
    padding: 10vw 5%
}

#sec2 .set2 .wrap::before {
    content: "";
    position: absolute;
    inset: 2px;
    border: 2px solid #bfaa83;
    border-radius: 22.5px
}

#sec2 .set2 h3 {
    text-align: center;
    background: url("../img/course/sec2_set2_deco_ttl.png") no-repeat center bottom/100%;
    width: 80%;
    margin: 0 auto;
    padding-bottom: 5vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec2 .set2 h3 span {
    letter-spacing: .1em
}

#sec2 .set2 .group-photo {
    margin-top: 8vw
}

#sec2 .set2 .group-photo .slick-dots {
    position: absolute;
    top: 53vw;
    left: 0;
    right: 0;
    justify-content: center
}

#sec2 .set2 .group-photo .slick-dots li {
    width: 50px
}

#sec2 .set2 .group-photo .slick-dots li button {
    border-color: #000
}

#sec2 .set2 .group-photo .slick-dots li.slick-active button {
    background: #000
}

#sec2 .set2 .group-photo li .txt {
    text-align: center;
    margin-top: 12vw;
    line-height: 1;
    letter-spacing: .1em
}

@media screen and (min-width: 768px) {
    #sec2 {
        background-size: auto;
        padding: 53px 0 138px
    }

    #sec2 .set1 .wrap {
        max-width: 1130px;
        padding: 0 30px
    }

    #sec2 .set1 .note1 {
        margin-right: -69px
    }

    #sec2 .set1 .photo1 {
        position: absolute;
        top: 51px;
        left: 565px;
        right: -105px;
        margin-top: 0;
        height: 440px
    }

    #sec2 .set1 .box1 {
        margin-top: 0;
        padding-top: 83px
    }

    #sec2 .set1 .box1 h2 {
        width: 446px;
        margin: 0;
        padding-bottom: 31px
    }

    #sec2 .set1 .box1 .price1 {
        margin: 17px 0 0 21px;
        padding: 0 16px 0 13px
    }

    #sec2 .set1 .box1 .price1 span {
        margin-left: 12px
    }

    #sec2 .set1 .box1 .price2 {
        text-align: left;
        margin: 26px 0 0 33px
    }

    #sec2 .set1 .box1 .price2 span {
        margin-left: 6px
    }

    #sec2 .set1 .box1 .note2 {
        text-align: left;
        margin: 12px 0 0 33px
    }

    #sec2 .set1 .box1 .txt {
        margin: 43px 0 0 33px
    }

    #sec2 .set1 .box2 {
        margin: 64px 0 0 33px
    }

    #sec2 .set1 .photo2 {
        position: absolute;
        top: 510px;
        right: -186px;
        margin-top: 0
    }

    #sec2 .set2 {
        margin: 76px 30px 0
    }

    #sec2 .set2 .deco {
        bottom: -332px;
        right: -30px;
        width: auto
    }

    #sec2 .set2 .wrap {
        max-width: 1400px;
        border-radius: 50px;
        margin: 0 auto;
        padding: 78px 0
    }

    #sec2 .set2 .wrap::before {
        inset: 4px;
        border-width: 3px;
        border-radius: 45px
    }

    #sec2 .set2 h3 {
        width: 385px;
        padding-bottom: 33px
    }

    #sec2 .set2 .group-photo {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        row-gap: 54px;
        max-width: 1000px;
        margin: 60px auto 0
    }

    #sec2 .set2 .group-photo li {
        width: 470px
    }

    #sec2 .set2 .group-photo li .txt {
        margin-top: 21px
    }
}

@media screen and (min-width: 768px)and (max-width: 1500px) {
    #sec2 .set1 .photo1 {
        right: calc(-50vw + 50% + 80px)
    }

    #sec2 .set1 .photo2 {
        right: calc(-50vw + 50%)
    }
}

@media screen and (min-width: 768px)and (max-width: 1350px) {
    #sec2 .set1 .note1 {
        margin-right: calc(-50vw + 50% + 80px)
    }
}

#sec3 {
    padding-bottom: 15vw
}

#sec3 .set1 .photo {
    position: relative;
    margin-left: -6%
}

#sec3 .set1 .photo::before {
    content: "";
    position: absolute;
    inset: 0 30% -2vw 0;
    z-index: -1;
    background: url("../img/shared/bg2.jpg") repeat center
}

#sec3 .set1 .group-txt h2 {
    background: url("../img/shared/bg2.jpg") repeat center;
    color: #fff;
    width: -moz-fit-content;
    width: fit-content;
    margin: 10vw auto 0;
    padding: 0 1vw;
    line-height: 1.6176470588;
    letter-spacing: .1em
}

#sec3 .set1 .group-txt .price {
    background: #fffaf0;
    width: -moz-fit-content;
    width: fit-content;
    margin: 8vw auto 0;
    padding: 0 2vw;
    line-height: 1.5454545455;
    letter-spacing: .1em
}

#sec3 .set1 .group-txt .price span {
    margin-left: 1.5vw;
    letter-spacing: .1em
}

#sec3 .set1 .group-txt .note {
    text-align: center;
    margin-top: 2vw
}

#sec3 .set1 .group-txt .txt {
    margin-top: 5vw
}

#sec3 .set2 {
    margin-top: 10vw
}

#sec3 .set2 .photo {
    margin: 10vw 10% 0
}

@media screen and (max-width: 767px) {
    #sec3 .set1 h2 {
        font-size: 5.5vw
    }
}

@media screen and (min-width: 768px) {
    #sec3 {
        padding-bottom: 130px
    }

    #sec3 .set1 .wrap {
        max-width: 1200px
    }

    #sec3 .set1 .photo {
        margin-left: 0;
        height: 590px;
        top: 0;
        left: calc(-50vw + 50%);
        right: 485px
    }

    #sec3 .set1 .photo::before {
        inset: 0 278px -18px 0
    }

    #sec3 .set1 .group-txt {
        position: relative;
        z-index: 1;
        width: 630px;
        margin-left: auto;
        padding: 55px 0 68px
    }

    #sec3 .set1 .group-txt h2 {
        margin: 0;
        padding: 0 0 0 6px
    }

    #sec3 .set1 .group-txt .price {
        margin: 25px 0 0 193px;
        padding: 0 7px 0 22px
    }

    #sec3 .set1 .group-txt .price span {
        margin-left: 12px
    }

    #sec3 .set1 .group-txt .note {
        text-align: left;
        margin: 5px 0 0 214px
    }

    #sec3 .set1 .group-txt .txt {
        margin: 34px 0 0 216px
    }

    #sec3 .set2 {
        margin-top: 68px
    }

    #sec3 .set2 .wrap {
        max-width: 906px
    }

    #sec3 .set2 .box {
        width: 570px;
        padding: 50px 67px 41px 50px
    }

    #sec3 .set2 .photo {
        margin: 0;
        top: -68px;
        left: 640px;
        right: -224px;
        height: 400px
    }
}

#sec4 {
    padding-bottom: 15vw
}

#sec4 .wrap {
    background: url("../img/shared/bg3.jpg") repeat center;
    padding: 10vw 10%;
    margin: 0 3%
}

#sec4 .wrap::before {
    content: "";
    position: absolute;
    inset: 2vw;
    border: 1px solid #9d9880
}

#sec4 .left .price {
    text-align: center;
    line-height: 1;
    letter-spacing: .1em
}

#sec4 .left .price span {
    margin-left: 1.5vw;
    letter-spacing: .1em
}

#sec4 .left .note {
    text-align: center;
    margin-top: 2vw
}

#sec4 .left .txt {
    margin-top: 5vw
}

#sec4 .right {
    border-top: 1px dotted #42403c;
    padding-top: 7vw;
    margin-top: 7vw
}

#sec4 .right h4 {
    text-align: center;
    line-height: 1;
    letter-spacing: .1em
}

#sec4 .right .list {
    margin-top: 5vw
}

@media screen and (min-width: 768px) {
    #sec4 {
        padding-bottom: 122px
    }

    #sec4 .wrap {
        display: flex;
        justify-content: space-between;
        max-width: 1100px;
        padding: 80px 49px 69px 100px;
        margin: 0px auto
    }

    #sec4 .wrap::before {
        inset: 9px
    }

    #sec4 .wrap:after {
        content: "";
        position: absolute;
        top: 59px;
        bottom: 64px;
        left: 50%;
        transform: translateX(-50%);
        border-left: 1px dotted #42403c
    }

    #sec4 .left .price {
        text-align: left
    }

    #sec4 .left .price span {
        margin-left: 12px
    }

    #sec4 .left .note {
        text-align: left;
        margin-top: 8px
    }

    #sec4 .left .txt {
        margin-top: 43px
    }

    #sec4 .right {
        border-top: none;
        padding-top: 0;
        margin-top: 0
    }

    #sec4 .right h4 {
        text-align: left
    }

    #sec4 .right .list {
        margin-top: 14px
    }
}

#sec5 {
    color: #fff
}

#sec5 .top {
    position: relative
}

#sec5 .top .sub-txt {
    position: absolute;
    top: 13vw;
    left: 50%;
    z-index: 1;
    transform: translateX(-50%);
    background: url("../img/course/sec5_deco_ttl.png") no-repeat center bottom/100%;
    filter: drop-shadow(2px 2px 10px #000);
    width: 70.13%;
    padding-bottom: 6vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec5 .top .sub-txt span {
    letter-spacing: .1em
}

#sec5 .bot {
    position: relative;
    z-index: 1;
    padding: 15vw 5.33% 18vw
}

#sec5 .bot::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -2;
    background: url("../img/course/sec5_bg_pc.jpg") no-repeat center/cover
}

#sec5 .bot:after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: rgba(40, 36, 25, .8)
}

#sec5 .bot h2 {
    text-align: center;
    line-height: 1.21;
    letter-spacing: .1em
}

#sec5 .bot h2 span {
    letter-spacing: .1em
}

#sec5 .bot .txt {
    margin-top: 6vw
}

@media screen and (min-width: 768px) {
    #sec5 {
        background: url("../img/course/sec5_bg_pc.jpg") no-repeat center/cover;
        padding: 25px
    }

    #sec5 .box {
        background: rgba(40, 36, 25, .6);
        width: 580px;
        margin-left: auto;
        padding: 135px 0 119px
    }

    #sec5 .top .sub-txt {
        position: unset;
        transform: none;
        filter: unset;
        width: 376px;
        margin: 0 auto;
        padding-bottom: 34px;
        font-size: 29px
    }

    #sec5 .top .sub-txt span {
        font-size: 36px
    }

    #sec5 .bot {
        padding: 14px 0 0
    }

    #sec5 .bot::before {
        display: none
    }

    #sec5 .bot:after {
        display: none
    }

    #sec5 .bot .txt {
        width: 409px;
        margin: 45px auto 0
    }
}

#sec6 {
    padding-top: 10vw
}

#sec6 .set1 .photo {
    margin: 0 -6% 0 6%
}

#sec6 .set1 .group-txt .sub-txt {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    border-radius: 50%;
    background: url("../img/shared/bg2.jpg") repeat center;
    color: #fff;
    width: 30vw;
    height: 30vw;
    margin: -15vw 0 -7vw -3%;
    padding: 0 0 2vw 1vw;
    line-height: 1.29;
    letter-spacing: .1em
}

#sec6 .set1 .group-txt .price {
    background: #fffaf0;
    width: -moz-fit-content;
    width: fit-content;
    margin: 5vw auto 0;
    padding: 0 2vw;
    line-height: 1.5454545455;
    letter-spacing: .1em
}

#sec6 .set1 .group-txt .price span {
    margin-left: 1.5vw;
    letter-spacing: .1em
}

#sec6 .set1 .group-txt .txt {
    margin-top: 5vw
}

#sec6 .set1 .box-shared {
    margin-top: 5vw
}

#sec6 .set2 {
    position: relative;
    margin-top: 15vw
}

#sec6 .set2 .deco1 {
    position: absolute;
    top: -10vw;
    right: 0;
    z-index: -1;
    width: 65%
}

#sec6 .set2 .deco2 {
    position: absolute;
    bottom: -20vw;
    left: 0;
    z-index: -1;
    width: 60%
}

#sec6 .set2 .box {
    position: relative
}

#sec6 .set2 .box dt {
    position: absolute;
    bottom: 2vw;
    left: 2vw;
    right: 2vw;
    z-index: 1;
    font-size: 3.2vw;
    line-height: 1.5;
    letter-spacing: .1em
}

#sec6 .set2 .box1 {
    margin-right: 10%
}

#sec6 .set2 .box1 dt {
    text-align: right;
    color: #fff
}

#sec6 .set2 .box2 {
    margin-left: 10%
}

#sec6 .set2 .box2 dt {
    color: #000
}

#sec6 .set2 .ttl {
    position: relative;
    z-index: 1
}

#sec6 .set2 .ttl h3 {
    margin: 9vw 0 8vw;
    line-height: 1.25;
    letter-spacing: .1em
}

#sec6 .set2 .ttl h3 span {
    display: block;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto 5vw;
    padding: 0 6vw 0 9vw;
    background: url("../img/shared/bg2.jpg") repeat center;
    color: #fff
}

@media screen and (min-width: 768px) {
    #sec6 {
        padding-top: 69px
    }

    #sec6 .set1 .wrap {
        max-width: 1276px;
        padding: 0 30px
    }

    #sec6 .set1 .photo {
        top: 56px;
        left: -38px;
        right: 544px;
        margin: 0;
        height: 550px
    }

    #sec6 .set1 .group-txt {
        width: 604px;
        margin-left: auto
    }

    #sec6 .set1 .group-txt .sub-txt {
        width: 160px;
        height: 160px;
        margin: 0;
        padding: 0 0 11px 8px
    }

    #sec6 .set1 .group-txt .price {
        margin: -58px 107px 0 auto;
        padding: 0 13px 0 15px
    }

    #sec6 .set1 .group-txt .price span {
        margin-left: 12px
    }

    #sec6 .set1 .group-txt .txt {
        width: -moz-fit-content;
        width: fit-content;
        margin: 28px 38px 0 auto
    }

    #sec6 .set1 .box-shared {
        width: 835px;
        margin: 55px 0 0 auto;
        padding: 51px 45px 35px 51px
    }

    #sec6 .set2 {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        margin-top: 116px
    }

    #sec6 .set2 .deco1 {
        top: -153px;
        width: auto
    }

    #sec6 .set2 .deco2 {
        top: 0;
        bottom: auto;
        width: auto
    }

    #sec6 .set2 .box {
        width: calc(50% - 50px)
    }

    #sec6 .set2 .box dt {
        bottom: 18px;
        left: 14px;
        right: 18px;
        font-size: 24px
    }

    #sec6 .set2 .box dd {
        height: 550px
    }

    #sec6 .set2 .box1 {
        margin-right: 0
    }

    #sec6 .set2 .box2 {
        margin: 135px 0 0
    }

    #sec6 .set2 .ttl h3 {
        position: absolute;
        top: 198px;
        left: 50%;
        z-index: 1;
        transform: translateX(-50%);
        margin: 0
    }

    #sec6 .set2 .ttl h3 span {
        width: 458px;
        margin: 0 auto 51px;
        padding: 0 0 0 15px
    }
}

@media screen and (min-width: 768px)and (max-width: 1460px) {
    #sec6 .set2 .box dt {
        font-size: 1.6vw;
        bottom: 1.2vw;
        left: .9333333333vw;
        right: 1.2vw
    }
}

@media screen and (min-width: 768px)and (max-width: 1200px) {
    #sec6 .set1 .box-shared {
        width: 860px
    }
}

#sec7 {
    padding-top: 15vw
}

#sec7 h2 {
    background: url("../img/course/sec7_deco_ttl.png") no-repeat center bottom/100%;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto 10vw;
    padding-bottom: 4vw;
    text-align: center;
    letter-spacing: .1em;
    line-height: 1.5192307692
}

#sec7 h2 small {
    letter-spacing: .1em
}

#sec7 .toggle {
    position: relative;
    background: url("../img/shared/bg3.jpg") repeat center
}

#sec7 .toggle::before {
    content: "";
    position: absolute;
    border: 1px solid #9d9880;
    inset: 2vw
}

#sec7 .toggle .toggle-link .inner {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 5vw;
    padding: 10vw 0
}

#sec7 .toggle .toggle-link .name-price {
    line-height: 1.5681818182
}

#sec7 .toggle .toggle-link .name-price * {
    letter-spacing: .1em
}

#sec7 .toggle .toggle-link .name-price .name-price dt span {
    margin-left: 1vw
}

#sec7 .toggle .toggle-link .name-price .name-price dd span {
    margin-left: 1.5vw
}

#sec7 .toggle .toggle-link .arrow {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    width: 28vw;
    height: 28vw;
    text-align: center;
    font-size: 3.7vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec7 .toggle .toggle-link .arrow::before {
    content: "";
    position: absolute;
    bottom: 5vw;
    left: 50%;
    transform: translateX(-50%);
    background: url("../img/shared/icon_arrow_down_w.png") no-repeat center/100%;
    width: 5vw;
    height: 4.5vw
}

#sec7 .toggle .toggle-link .arrow:after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: url("../img/shared/bg2.jpg") repeat center;
    -webkit-clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%)
}

#sec7 .toggle .toggle-main {
    margin: 0 8%;
    padding-bottom: 10vw
}

#sec7 .toggle .toggle-main .row .col+.col {
    margin-top: 5vw
}

#sec7 .toggle .toggle-main .row .col .item+.item {
    margin-top: 5vw
}

#sec7 .toggle .toggle-main .row .col .item h3 {
    text-align: center;
    border: 1px solid #222;
    color: #222;
    margin-bottom: 10px;
    font-size: 18px;
    line-height: 48px;
    letter-spacing: .16em
}

#sec7 .toggle .toggle-main .row .col .item p {
    text-align: center;
    color: #333
}

#sec7 .toggle .toggle-main .close-x {
    position: relative;
    display: block;
    width: 30px;
    height: 30px;
    margin: 5vw auto 0
}

#sec7 .toggle .toggle-main .close-x::before,
#sec7 .toggle .toggle-main .close-x::after {
    content: "";
    position: absolute;
    background: #000;
    height: 3px;
    width: 40px;
    top: 50%;
    left: 50%
}

#sec7 .toggle .toggle-main .close-x::before {
    transform: translate(-50%, -50%) rotate(45deg)
}

#sec7 .toggle .toggle-main .close-x::after {
    transform: translate(-50%, -50%) rotate(-45deg)
}

#sec7 .toggle.active .toggle-link .arrow::before {
    transform: translateX(-50%) rotate(180deg)
}

#sec7 .toggle2 {
    background-image: url("../img/shared/bg4.jpg")
}

#sec7 .toggle2::before {
    border-color: #9d9880
}

@media screen and (max-width: 768px) {
    #sec7 .fs44 {
        font-size: 6.47vw
    }

    #sec7 .fs52 {
        font-size: 7.53vw
    }
}

@media screen and (min-width: 768px) {
    #sec7 {
        padding-top: 96px
    }

    #sec7 h2 {
        background-size: auto;
        width: -moz-fit-content;
        width: fit-content;
        margin: 0 auto 56px;
        padding-bottom: 29px
    }

    #sec7 .toggle::before {
        inset: 30px
    }

    #sec7 .toggle .toggle-link {
        display: block;
        padding: 0;
        transition: .3s
    }

    #sec7 .toggle .toggle-link .inner {
        position: relative;
        max-width: 1200px;
        margin: 0 auto;
        padding: 118px 0 124px
    }

    #sec7 .toggle .toggle-link .name-price dt span {
        margin-left: 5px
    }

    #sec7 .toggle .toggle-link .name-price dd span {
        margin-left: 12px
    }

    #sec7 .toggle .toggle-link .arrow {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 48px;
        width: 150px;
        height: 150px;
        padding-bottom: 10px;
        font-size: 16px
    }

    #sec7 .toggle .toggle-link .arrow::before {
        bottom: 30px;
        width: 29px;
        height: 20px
    }

    #sec7 .toggle .toggle-link:hover {
        opacity: .7
    }

    #sec7 .toggle .toggle-main {
        margin: -55px 0 0;
        padding-bottom: 100px
    }

    #sec7 .toggle .toggle-main .row {
        display: flex;
        justify-content: space-between;
        max-width: 916px;
        margin: 0 auto
    }

    #sec7 .toggle .toggle-main .row .col {
        width: 287px
    }

    #sec7 .toggle .toggle-main .row .col+.col {
        margin-top: 0
    }

    #sec7 .toggle .toggle-main .row .col .item+.item {
        margin-top: 45px
    }

    #sec7 .toggle .toggle-main .row .col .item h3 {
        margin-bottom: 19px;
        font-size: 21px;
        line-height: 52px
    }

    #sec7 .toggle .toggle-main .row .col .item p {
        text-align: center;
        font-size: 17px;
        line-height: 36px
    }

    #sec7 .toggle .toggle-main .close-x {
        cursor: pointer;
        width: 37px;
        height: 37px;
        margin: 70px auto 0
    }

    #sec7 .toggle .toggle-main .close-x:hover {
        opacity: .7
    }

    #sec7 .toggle .toggle-main .close-x::before,
    #sec7 .toggle .toggle-main .close-x::after {
        width: 50px
    }

    #sec7 .toggle2 {
        background-image: url("../img/shared/bg4.jpg")
    }

    #sec7 .toggle2::before {
        border-color: #9d9880
    }
}

#sec8 {
    position: relative;
    background: url("../img/course/sec8_bg.jpg") repeat center/cover;
    color: #fff;
    padding: 15vw 6vw
}

#sec8::before {
    content: "";
    position: absolute;
    inset: 2vw;
    z-index: 1;
    background: rgba(40, 36, 25, .6)
}

#sec8 .wrap {
    padding: 0;
    z-index: 2
}

#sec8 h2 {
    text-align: center;
    line-height: 1;
    letter-spacing: .16em
}

#sec8 .contact {
    margin: 10vw 8% 0
}

#sec8 .contact .btn-tel {
    position: relative;
    border-bottom: 1px solid #fff;
    text-align: center;
    margin-bottom: 7vw;
    padding-bottom: 7vw
}

#sec8 .contact .btn-tel::before {
    content: "";
    position: absolute;
    background: #fff;
    height: 1px;
    bottom: 3px;
    left: 0;
    right: 0
}

#sec8 .contact .btn-tel dl {
    line-height: 1
}

#sec8 .contact .btn-tel dl dt {
    font-size: 30px;
    letter-spacing: .1em
}

#sec8 .contact .btn-tel dl dt span {
    position: relative;
    top: -4px
}

#sec8 .contact .btn-tel dl dt img {
    width: 23px;
    margin: -8px 8px 0 0
}

#sec8 .contact .btn-tel dl dd {
    margin-top: 8px;
    font-size: 13px;
    line-height: 17px;
    letter-spacing: .04em
}

@media screen and (min-width: 768px) {
    #sec8 {
        padding: 188px 0 165px
    }

    #sec8::before {
        inset: 25px
    }

    #sec8 .wrap {
        max-width: 1020px;
        padding: 0;
        z-index: 2
    }

    #sec8 .contact {
        position: relative;
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin: 55px 0 0
    }

    #sec8 .contact::before,
    #sec8 .contact:after {
        content: "";
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        background: #fff;
        width: 1px;
        height: 130px
    }

    #sec8 .contact::before {
        left: calc(50% - 2px)
    }

    #sec8 .contact:after {
        left: calc(50% + 2px)
    }

    #sec8 .contact .btn-tel {
        border-bottom: none;
        margin: 0 0 0 51px;
        padding-bottom: 0
    }

    #sec8 .contact .btn-tel::before {
        display: none
    }

    #sec8 .contact .btn-tel dl {
        line-height: 1
    }

    #sec8 .contact .btn-tel dl dt {
        font-size: 50.5px
    }

    #sec8 .contact .btn-tel dl dt span {
        top: -6px
    }

    #sec8 .contact .btn-tel dl dt img {
        width: 40px;
        margin: -14px 14px 0 0
    }

    #sec8 .contact .btn-tel dl dd {
        margin-top: 17px;
        font-size: 22px;
        line-height: 25px
    }

    #sec8 .contact .btn-web {
        width: 448px
    }

    #sec8 .contact .btn-web a {
        gap: 15px;
        font-size: 27px;
        line-height: 93px
    }

    #sec8 .contact .btn-web a::before {
        width: 30px;
        height: 30px
    }
}