@charset "UTF-8";

:root {
    --color-gray-1: #f6f7f1;
}

@keyframes pathmove {
    0% {
        height: 0;
        opacity: 1;
    }

    50% {
        height: 26px;
    }
}

@keyframes pathmoveSP {
    0% {
        height: 0;
        opacity: 1;
    }

    50% {
        height: 44px;
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes fadeOut {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

#h_top {
    position: fixed;
    top: 0;
    width: 100%;
    background-color: transparent;
    z-index: 4;
}

#h_top .gnav__list > li > a {
    color: var(--color-white);
}


#h_top .btn-toggle-menu > span {
    background-color: var(--color-white);
}

#header {
    transition: top .4s ease-in;
}

#header.top {
    top: -70px;

}

.logo_sp_open {
    display: none;
}

@media screen and (min-width: 768px) {
    #h_top .h-button_list .button-outline--size-s {
        color: var(--color-white);
        border-color: var(--color-white);
    }

    #h_top .h-button_list .button-outline--size-s:hover {
        background-color: var(--color-white);
        color: #000;
    }

    #h_top .h-button_list .button--size-s {
        background-color: var(--color-white);
        border-color: var(--color-white);
        color: #000;
    }
}

@media screen and (max-width: 767px) {
    .g-open #h_top {
        background-color: var(--color-white);
    }

    .g-open #h_top .logo img {
        display: none;
    }

    .g-open #h_top .logo .logo_sp_open {
        display: block;
    }

    .g-open #h_top .btn-toggle-menu > span {
        background-color: #555;
    }
}

@media screen and (min-width:768px) {
    #main_visual {
        position: relative;
        min-height: calc(600px + 10.3vw);
    }
}

.camp_visual {
    position: relative;
    min-height: calc(600px + 10.3vw);
}

.camp_visual .m_slider {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

.m_slider .m_slide {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 1s ease-in-out;
}

.m_slider .m_slide.active {
    opacity: 1;
}

.camp_visual .visual-image {
    position: relative;
    height: calc(600px + 10.3vw);
    animation-delay: 4.7s;
}


@media screen and (max-width:767px) {
    #main_visual {
        background-color: var(--color-gray-1);
    }

    .camp_visual {
        min-height: auto;
        height: calc(550px + 10.3vw);
    }

    .camp_visual .visual-image {
        position: relative;
        height: calc(550px + 10.3vw);
        animation-delay: 4.7s;
    }


}

@media screen and (max-width: 767px) {
    .float_bnr {
        box-shadow: none;
    }
}



.scrolldown {
    padding: 0 0 2rem;
    position: absolute;
    bottom: 0;
    right: .6rem;
    color: var(--color-white);
    writing-mode: vertical-lr;
}

.scrolldown .scrolldown__txt {
    padding: 0 .2rem;
}

.scrolldown .scrolldown__line {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 26px;
}

.scrolldown .scrolldown__line:after {
    position: absolute;
    left: 50%;
    top: 0;
    content: "";
    width: 2px;
    height: 26px;
    background-color: var(--color-white);
    transform: translateX(-50%);
    animation: pathmove 1.4s ease-in-out infinite;
    opacity: 1;
}

@media screen and (max-width: 767px) {
    .scrolldown {
        min-height: 110px;
    }

    .scrolldown .scrolldown__line {
        height: 44px;
    }

    .scrolldown .scrolldown__line:after {
        height: 44px;
        animation: pathmoveSP 1.2s ease-in-out infinite;
    }
}

.slide_price_copy {
    display: flex;
    align-items: center;
    position: absolute;
    width: 176px;
    height: 176px;
    border-radius: 50%;
    background-color: #ED479B;
    justify-content: center;
    text-align: center;
    color: #fff;
    font-weight: bold;
    font-size: 1.13rem;
}

@media screen and (min-width:768px) {
    .slide_price_copy {
        top: 41.8%;
        left: 7%;
    }
}


.pr-text-md {
    font-size: 1.25rem;
}


.pr-text-lg {
    font-size: 2.25rem;
}

@media screen and (min-width:768px) and (max-width:950px) {
    .slide_price_copy {
        top: 38.8%;
    }
}

@media screen and (max-width:767px) {
    .slide_price_copy {
        left: 5.4vw;
        bottom: 15vw;
        width: 38.5vw;
        height: 38.5vw;
        font-size: 4vw;
    }

    .pr-text-md {
        font-size: 4.6vw;
    }

    .pr-text-lg {
        font-size: 8vw;
    }
}

.banner {
    padding: .4rem 1.5rem .7rem;
    display: block;
    border-radius: 8px;
    position: absolute;
    background-color: #ED479B;
    text-align: center;
    color: #fff;
    font-weight: bold;
    font-size: 1.63rem;
    line-height: 1.39;
}

@media screen and (min-width: 768px) {
    .banner {
        top: 67%;
        left: 7%;
    }
}

@media screen and (min-width:768px) and (max-width:950px) {
    .banner {
        top: 66%;
    }
}

@media screen and (max-width:767px) {
    .banner {
        padding: .2rem .9rem .5rem;
        font-size: 6vw;
        bottom: 2vw;
        left: 5.4vw;
    }

}

.slide_copy_wh-box {
    position: absolute;
    top: 78.5%;
    left: 6%;
    max-width: 319px;
    padding: 1.8rem 1.1rem 1rem;
    border-radius: 16px;
    background-color: #fff;
}

@media screen and (min-width:768px) {
    .slide_copy_wh-box {
        position: absolute;
        top: 78.5%;
        left: 6%;
    }
}

.slide_copy_wh-box .pr-text-md + .is-style-ds-text-m {
    margin-top: .2rem;
}

.rb-button {
    display: flex;
    position: absolute;
    top: -20px;
    left: 25px;
    padding: 0 .5rem 0 .5rem;
    min-width: 180px;
    min-height: 40px;
    color: #fff;
    font-size: 1.13rem;
    font-weight: bold;
    align-items: center;
    background-color: #ED479B;
}

/* .slide_copy_wh-box .rb-button {
    display: flex;
    position: absolute;
    top: -20px;
    left: 25px;
    padding: 0 .5rem 0 .5rem;
    min-width: 180px;
    min-height: 40px;
    color: #fff;
    font-size: 1.13rem;
    font-weight: bold;
    align-items: center;
    background-color: #ED479B;
} */

.rb-button-left:before,
.rb-button-left:after {
    position: absolute;
    left: -10px;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-bottom: 20px solid #ED479B;
    border-top: 0;
}

.rb-button-left:before {
    bottom: 0;
}

.rb-button-left:after {
    top: 0;
    transform: rotate(180deg);
}

.rb-button-right:before,
.rb-button-right:after {
    position: absolute;
    right: -10px;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-bottom: 20px solid #ED479B;
    border-top: 0;
}

.rb-button-right:before {
    bottom: 0;
}

.rb-button-right:after {
    top: 0;
    transform: rotate(180deg);
}

/* .slide_copy_wh-box .rib-button:before,.slide_copy_wh-box .rib-button::after {
    border-top-width: 20px;
    border-bottom-width: 20px;
}

.slide_copy_wh-box .rib-button:before {
    border-left-width: 10px;
}

.slide_copy_wh-box .rib-button::after {
    border-right-width: 10px;
} */

@media screen and (max-width:767px) {
    .slide_copy_wh-box {
        position: relative;
        margin: 11.5vw 1rem 6vw;
        padding: 8vw 5.9vw 3.5vw;
        left: 0;
        max-width: 100%;
    }

    .slide_copy_wh-box .pr-text-md {
        font-size: 5.5vw;
    }

    .slide_copy_wh-box .rb-button {
        min-height: 10.7vw;
        font-size: 4.8vw;
        left: 7.9vw;
        top: -5.35vw;
    }

    .slide_copy_wh-box .rb-button-left:before,
    .slide_copy_wh-box .rb-button-left:after {
        border-right-width: 2.675vw;
        border-left-width: 2.675vw;
        border-bottom-width: 5.35vw;
        left: -2.675vw;
    }

    .slide_copy_wh-box .rb-button-right:before,
    .slide_copy_wh-box .rb-button-right:after {
        border-right-width: 2.675vw;
        border-left-width: 2.675vw;
        border-bottom-width: 5.35vw;
        right: -2.675vw;
    }
}

.slide_copy_wrap {
    position: absolute;
    right: 72px;
    bottom: 2.5vw;
}

.slide_copy {
    display: inline-block;
    padding: .2vw 1.7vw .5vw 1.8vw;
    background-color: #fff;
    color: #000;
    font-size: 1.7vw;
    line-height: 2;
}

.slide_copy--sm {
    font-size: 1.88vw;
    line-height: 1.27;
}

.slide_copy--sm span {
    font-size: .9em;
}

.slide_copy--lg {
    font-size: 4.23vw;
    line-height: 1.28;
    padding-bottom: .68vw;
}

.slide_copy--lg span {
    font-size: .82em;
}

.slide_copy--md {
    font-size: 4.15vw;
    line-height: 1.27;
    padding-bottom: .7vw;
}

.slide_copy--md span {
    font-size: .81em;
}


@media screen and (max-width:767px) {
    .slide_copy_wrap {
        position: relative;
        padding: 1.7rem 1.25rem 2.25rem;
        width: 100%;
        right: 0;
        left: 0;
        bottom: 0;
        background-color: var(--color-gray-1);
    }

    .slide_copy {
        padding: 0;
        background: none;
        font-size: 4.3vw;
    }

    .slide_copy--sm {
        margin-top: 15px;
        font-size: 6.5vw;
    }

    .slide_copy--lg {
        margin-top: .3rem;
    }

    .slide_copy--md,
    .slide_copy--lg {
        font-size: 11.8vw;
    }

    .slide_copy_spbox {
        position: absolute;
        left: 0;
        bottom: 8vw;
        padding: 4vw 5.9vw;
        background-color: #fff;
        color: #000;
        font-size: 7.5vw;
        font-weight: 700;
        line-height: 1.4;
    }

    .slide_copy_spbox span {
        font-size: .9em;
    }

}

.float_btn {
    position: fixed;
    left: 0;
    right: 0;
    bottom: -56px;
    padding: 0 .5rem;
    margin: 0 auto;
    max-width: 480px;
    width: 100%;
    transition: bottom 0.5s ease;
}

.float_btn i {
    position: relative;
    top: 2px;
    margin-left: 1rem;
    font-size: 1.75rem;
}

.float_btn.show {
    bottom: 0;
    z-index: 3;
}

.float_btn .button {
    font-size: 1.25rem;
    width: 100%;
    min-height: 56px;
    border-radius: 12px;
    border: 2px solid #fff;
    border-bottom: 2px solid #ed479b;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    font-weight: bold;
    font-size: 1.13rem;
}

@media screen and (max-width:767px) {
    .float_btn.show {
        bottom: -1px;
    }

    .float_btn .button {
        border-bottom-color: transparent;
        min-height: 44px;
    }

    .float_btn i {
        top: 1px;
    }

    .sec-camp .button--white.arrow:after {
        right: .5rem;
    }
}

.btn_bnr {
    position: absolute;
    left: 2rem;
    bottom: 2rem;
    padding: 0 .75rem .2rem 1rem;
    display: flex;
    align-items: center;
    min-width: 200px;
    min-height: 96px;
    border-radius: 10px;
    background-color: var(--color-white);
    text-decoration: none;
    color: var(--color-primary);
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1.3;
    opacity: 0;
}

.btn_bnr.add {
    opacity: 1;
}

.btn_bnr i {
    margin-left: .75rem;
    font-size: 1.75rem;
}

.camp_visual .btn_bnr {
    animation-delay: 6s;
}

@media(hover: hover) {
    .btn_bnr:hover {
        background-color: var(--color-primary);
        color: var(--color-white);
    }
}

@media screen and (max-width: 767px) {
    .btn_bnr {
        left: 1rem;
        bottom: 3.875rem;
    }
}

#feature {
    padding-top: 3.3rem;
    padding-bottom: 4.6rem;
}

.heading3--size-s {
    font-size: 1.75rem;
    font-weight: 400;
}

.feature_list {
    padding: 0;
    display: flex;
    margin: .9rem auto 0;
    max-width: 900px;
    list-style: none;
    gap: 4.4125rem;
    line-height: 1.35;
    align-items: center;
}

.feature_list li {
    width: 33.33%;
}

.feature_list a {
    text-decoration: none;
    color: var(--color-gray);
}

.feature_list .num {
    margin-bottom: .9rem;
    color: #000;
    font-size: 4rem;
    font-weight: 700;
}

.feature_list .num::after {
    content: "";
    display: block;
    width: 100%;
    height: 8px;
    background: url(../img/RBLine.svg);
    background-size: 100% auto;
}

@media screen and (max-width: 767px) {
    #feature {
        padding: 2.8rem 0 3.5rem;
    }

    .feature_list {
        margin-top: 2rem;
        flex-wrap: wrap;
        flex-direction: column;
        justify-content: center;
        gap: 1.8rem;
    }

    .feature_list li {
        max-width: 251px;
        width: 100%;
    }
}


.news_list {
    margin: 2.9rem 0 4rem;
}

.news_row {
    display: flex;
    justify-content: space-between;
    background-color: #fff;
}

.news_row + .news_row {
    margin-top: .8rem;
}

.news_row>* {
    width: 100%;
}

.news_row .news_img{
    max-width: 224px;
}

.news_row .news_copy{
    max-width: calc(100% - 224px);
    padding: 2rem;
    display: flex;
    flex-wrap: wrap;
}

.news_row .news_copy .btn {
    margin-bottom: 1.1rem;
    padding-right: .94rem;
}

.news_row .news_copy .button--size-xs {
    padding: 0 .6rem .1rem;
    min-width: 112px;
    min-height: 23px;
    font-size: .88rem;
    border-radius: 4px;
}

.news_row .news_copy .date {
    margin-bottom: 1.1rem;
    padding: 0 .94rem;
    font-size: .88rem;
    line-height: 1.7;
}

.news_row .news_copy .tit {
    display: block;
    width: 100%;
}

.news_row .news_copy .tit a {
    text-decoration: none;
    color: #333;
    font-size: 1rem;
}

.news_row .news_copy .tit a:hover {
    color: var(--color-primary);
}

@media screen and (max-width: 767px) { 
    .news_list {
        margin: 2.1rem 0 2.2rem;
    }

    .news_row {
        margin-top: 2.1rem;
        padding: 1rem 1rem 1.3rem;
        display: block;
    }

    .news_row>* {
        width: 100%;
    }

    .news_row + .news_row {
        margin-top: .7rem;
    }

    .news_row .news_img{
        margin-bottom: 1rem;
        max-width: 100%;
    }

    .news_row .news_img img {
        width: 100%;
        height: 47vw;
        object-fit: cover;
    }

    .news_row .news_copy{
        max-width: 100%;
        padding: 0;
    }
 
}


.title-headline {
    margin: 0 !important;
    max-width: 640px;
    font-size: 3.5rem;
    font-weight: 900;
    line-height: 1.45;
}

.title-headline:after {
    content: "";
    display: block;
    width: 100%;
    height: 16px;
    display: block;
    background: url(../img/RBLine.svg) no-repeat;
    background-size: 100% auto;
}

@media screen and (max-width: 767px) {
    .title-headline {
        font-size: 2.75rem;
        line-height: 1.5;
    }

    .title-headline:after {
        content: "";
        display: block;
        width: 100%;
        height: 16px;
        display: block;
        background: url(../img/RBLine_sp.svg) no-repeat;
        background-size: 100% auto;
    }
}

.point-title {
    margin-bottom: 1.25rem;
}

.point-title .point-title__txt {
    display: inline-block;
    font-size: 1.13rem;
    writing-mode: vertical-lr;
    transform: rotate(180deg);
}

.point-title .point-title__num {
    margin-left: 1rem;
    display: inline-block;
    font-size: 5rem;
    line-height: 1;
}

@media screen and (max-width: 767px) {
    .point-title {
        line-height: 1.25;
    }

}

.point-title02 {
    margin-bottom: .8rem;
    font-size: 1.88rem;
}

.t-highlight {
    background: linear-gradient(transparent 70%, #ffe200 70%);
    background-position-y: 40px;
}

.is-style-ds-text-m {
    color: var(--color-gray);
    font-weight: 500;
}

.sec_point .title3-m + .is-style-ds-text-m {
    margin-top: .6rem;
    margin-bottom: 0;
}

.title3--size-s {
    font-size: 1.375rem;
}


.sec_point .grid-media-text {
    margin-top: 2rem;
}

.sec_point .grid-media-text + .grid-media-text {
    margin-top: 1.6rem;
}

@media screen and (min-width: 768px) {
    .sec_point .grid-media-text .grid-media-text__content {
        max-width: calc(100% - 256px);
        order: 2;
    }

    .sec_point .grid-media-text .grid-media-text__img {
        max-width: 256px;
        order: 1;
    }

}

@media screen and (max-width: 767px) {
    .sec_point .inner_ptb68 {
        padding-top: 2.9rem;
    }

    .sec_point .grid-media-text {
        gap: 1rem;
    }

    .sec_point .grid-media-text + .grid-media-text {
        margin-top: 2.5rem;
    }

    .sec_point .grid-media-text .grid-media-text__img img {
        width: 100%;
        height: 47vw;
        object-fit: cover;
    }

}

#point02 .t-highlight {
    background: linear-gradient(transparent 77%, #ffe200 77%);
    background-position-y: -4.5px;
}

#point03 .grid-media-text .t-highlight {
    background: linear-gradient(transparent 64%, #ffe200 64%);
    background-position-y: 46px;
}

.camera_link {
    margin-top: 2.25rem;
}

.rib-button-txt {
    margin-bottom: .4rem;
    color: #218eeb;
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 2;
}

.rib-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 2rem 0 2rem;
    min-width: 365px;
    min-height: 63px;
    background-color: #218eeb;
    border-color: #218eeb;
    border-radius: 0;
    text-align: center;
    text-decoration: none;
    ;
    color: #fff;
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.2;
}

#point02 .rib-button {
    padding: 0px 2rem 0 2.6rem;
}

#point03 .rib-button {
    padding: 0 4rem 0 4rem;
}

.camera_link .rib-button .rib-sm-txt {
    font-size: 1.5rem;
}

/* .rib-btn {
    position: relative;
    margin-top: 4rem;
}

.rib-btn a {
    transition: all 0.3s ease-in-out;
}

.rib-btn a:hover .rib-tag {
  display: inline-block;
} */

.rib-tag {
    display: inline-block;
    margin-bottom: 1.3rem;
    background-color: #E84798;
    color: white;
    font-size: 1rem;
    font-weight: bold;
    padding: .25rem 2.25rem;
    border-radius: 16px;
    white-space: nowrap;
    position: relative;
    /* top: -59px;
    left: 50%;
    transform: translateX(-50%); */
}

.rib-tag::after {
    content: "";
    position: absolute;
    bottom: -14px;
    left: 17%;
    border-left: 11.5px solid transparent;
    border-right: 11.5px solid transparent;
    border-top: 15px solid #E84798;
}

.rib-btn .arrow:after {
    color: var(--color-white);
}


@media(hover: hover) {
    .rib-btn .button--pink:hover {
        background: transparent;
        color: #ed479b;
        opacity: 1;
    }

    .rib-btn .arrow:hover:after {
        color: #ed479b;
        z-index: 1;
    }
}

.rib-button:before,
.rib-button::after {
    position: absolute;
    top: 0;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 32px solid transparent;
    border-bottom: 32px solid transparent;
}

.rib-button:before {
    left: 0px;
    border-left: 20px solid var(--color-white);
    border-right: 0;
}

.rib-button:after {
    right: 0;
    border-right: 20px solid var(--color-white);
    border-left: 0;
}

.bg-gray-1 .rib-button:before {
    border-left-color: var(--color-gray-1);
}

.bg-gray-1 .rib-button::after {
    border-right-color: var(--color-gray-1);
}


.rib-button i {
    margin-right: 1.3rem;
}

@media screen and (max-width: 767px) {
    .rib-button {
        min-width: inherit;
        max-width: 375px;
        min-height: 80px;
        width: 100%;
        font-size: 1.5rem;
        flex-wrap: wrap;
    }

    .rib-button i {
        font-size: 1.75rem;
    }

    .rib-button:before,
    .rib-button:after {
        border-top: 40px solid transparent;
        border-bottom: 40px solid transparent;
    }

    .rib-button:before {
        left: 0;
    }

    .rib-button:after {
        right: 0;
    }

    .camera_link .rib-button .rib-sm-txt {
        font-size: 1.25rem;
    }

    #point02 .rib-button,
    #point03 .rib-button {
        min-height: 80px;
        width: 100%;
        flex-wrap: wrap;
        position: relative;
    }

    #point02 .rib-button {
        padding: 1.5vw 4.5vw 1.5vw 4.5vw;
    }

    #point03 .rib-button {
        padding: 1.5vw 9.5vw 1.5vw 9.5vw;
    }

    #point02 .rib-button i,
    #point03 .rib-button i {
        position: absolute;
    }

    #point02 .rib-button i {
        left: 9vw;
    }

    #point03 .rib-button i {
        left: 12vw;
    }

    /* #point02 .rib-button:before, #point02 .rib-button::after, #point03 .rib-button:before, #point03 .rib-button::after {
        border-top: 40px solid transparent;
        border-bottom: 40px solid transparent;
    }
    
    #point02 .rib-button:before, #point03 .rib-button:before {
        left: 0px;
    }

    #point02 .rib-button:after, #point03 .rib-button:after {
        right: 0px;
    } 

    .rib-btn {
        margin-top: 3.5rem;
    }*/
}

@media screen and (max-width: 320px) {
    .rib-button {
        padding-left: 12vw;
        font-size: 6vw;
    }
}

.title3-m {
    font-size: 1.75rem;
    font-weight: 500;
}

.pt2_diagram {
    text-align: center;
}

.pt2_diagram img {
    max-width: 432px;
}

@media screen and (max-width: 767px) {
    .pt2_diagram img {
        max-width: 100%;
    }
}


.title-headline + .title3-m {
    margin-top: .4rem;
}

.title3-m + .is-style-ds-text-m {
    margin-top: 0;
    margin-bottom: 3.5rem;
}


@media screen and (max-width: 767px) {
    .title-headline + .title3-m {
        margin-top: .5rem;
        font-size: 1.5rem;
    }

    .title3-m + .is-style-ds-text-m {
        margin-top: .3rem;
        margin-bottom: 1.9rem;
    }
}

.course-box {
    --color-course: #71af32;
    --color-rgba-course: rgba(113, 175, 50, .6);
}

.course-box__heading {
    display: flex;
    background-color: var(--color-course);
    text-align: center;
    min-height: 64px;
    color: #fff;
    font-size: 1.375rem;
    font-weight: bold;
    align-items: center;
    justify-content: center;
}


.course-box__body {
    border: 3px solid var(--color-course);
    padding: 2.2rem 1.5rem 2.2rem;
    font-weight: 500;
}

.course-box .is-style-title2 {
    color: var(--color-course);
}

.course-box .is-style-title2 span {
    font-size: 1.5rem;
}

.course-box .is-style-title2 + .is-style-ds-text {
    margin-top: .8rem;
}

.course-box .course-price-row {
    margin-top: 1rem;
    display: flex;
    align-items: center;
    white-space: nowrap;
}

.course-box .course-price-row + .course-price-row {
    margin-top: 0;
}

.course-price-row .bx-sm {
    margin-top: 5px;
    display: flex;
    width: 54px;
    min-height: 34px;
    border-radius: 8px;
    background-color: var(--color-course);
    color: #fff;
    font-size: 1.13rem;
    font-weight: bold;
    align-items: center;
    justify-content: center;
}

.course-price-row .course-price {
    padding-left: .75rem;
    width: calc(100% - 54px);
    color: var(--color-course);
    font-size: 2.75rem;
    font-weight: 900;
}

.course-price-row .course-price span {
    display: inline-block;
}

.course-price-row .course-price .price {
    text-align: right;
    min-width: 176px;
}

.course-price .yen {
    margin-left: .2rem;
    font-size: 1.5rem;
}

.course-price .tax {
    font-size: .88rem;
}

.course-price .tax-note {
    font-weight: 400;
}

.course-price--yearly .bx-sm {
    opacity: .7;
}

.course-price--yearly .course-price span {
    opacity: .7;
}

@media screen and (min-width:768px) and (max-width:880px) {
    .course-price-row .course-price {
        padding-left: .5rem;
        font-size: 4vw;
    }

    .course-price-row .course-price .price {
        min-width: 17vw;
    }

    .course-price-row .course-price .yen {
        font-size: .75em;
    }

    .course-price-row .course-price .tax {
        font-size: .5em;
    }

    .bd-box .course-price-row .course-price {
        font-size: 3.5vw;
    }

    .bd-box .course-price-row .price {
        min-width: 14vw;
    }

    .bd-box .course-price-row .bx-sm {
        width: 6vw;
        font-size: 2vw;
    }

}


@media screen and (max-width:767px) {
    .course-box__body {
        padding: 1.7rem 1rem 1.5rem;
    }

    .course-price-row .bx-sm {
        padding-bottom: .1em;
        width: 14vw;
        font-size: 4.8vw;
    }

    .course-price-row .course-price {
        font-size: 9.5vw;
    }

    .course-price-row .course-price .price {
        min-width: 38vw;
    }

    .course-price .yen {
        font-size: .6em;
    }

    .course-price .tax {
        font-size: .35em;
    }

    .bd-box .course-price-row .bx-sm {
        font-size: 4vw;
        width: 11vw;
    }

    .bd-box .course-price-row .course-price {
        font-size: 8.8vw;
    }

    .bd-box .course-price-row .course-price .price {
        min-width: 35vw;
    }

    .sec-course .ds-text-sp {
        font-size: .88rem;
    }
}


.course-tbl {
    margin-top: .75rem;
    border-top: 1px solid var(--color-course);
}

.course-tbl .ds-table {
    margin-top: 0;
    width: 100%;
}

.course-tbl .ds-table th,
.course-tbl .ds-table td {
    padding: .3rem 0;
    border: none;
    background: none;
    text-align: left;
}

.course-tbl .ds-table tr {
    border-bottom: 1px solid var(--color-course);
}

.course-tbl .ds-table th {
    width: 30%;
    font-weight: bold;
    vertical-align: top;
}

.course-tbl .ds-table td {
    width: 70%;
    font-weight: 500;
}

.dst-caution {
    font-size: .88rem;
}

.acd-content-wrap {
    margin-top: .2rem;
}

.acd-title {
    position: relative;
    padding: .6rem 1.375rem .7rem;
    font-size: 1.13rem;
    font-weight: bold;
    cursor: pointer;
}

.course-name-parent {
    background-color: var(--color-course);
    color: #fff;
}

.course-name-parent:not(.active) {
    border-bottom: 1px solid var(--color-gray-1);
}

.course-box .plus_icon {
    position: absolute;
    top: 0;
    right: 0;
    padding-right: 1.25rem;
    align-items: center;
    display: inline-flex;
    box-sizing: border-box;
    width: 54px;
    height: 100%;
    text-align: right;
    justify-content: flex-end;
}

.course-box .plus_icon::before {
    text-rendering: auto;
    font-size: 1rem;
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    font-style: normal;
    font-variant: normal;
    content: '\2b';
    font-size: 1.5rem;
    transition: all .3s;
}

.course-box .acd-title.active .plus_icon::before {
    content: '\f068';
    transform: rotate(180deg);
}

.acd-content:not(.has-child) {
    padding: .7rem 1rem 1.13rem 1.375rem;
    border: 1px solid var(--color-course);
}

.acd-content {
    display: none;
}

.accordion--child .acd-title {
    border: 1px solid var(--color-rgba-course);
    border-bottom: 1px solid var(--color-course);
    color: var(--color-course);
}

.accordion--child .acd-content {
    padding-right: .8rem;
    padding: .7rem 1rem 1.13rem 1.375rem;
}

.course-box .bd-box {
    position: relative;
    margin-top: .2rem;
    padding: .9rem 1.5rem;
    border-radius: 0;
    border-color: var(--color-course);
}

.course-box .bd-box--size-s {
    padding: .9rem 1.375rem;
}

.course-box .bd-box--size-s .course-price-row {
    margin-top: 0;
}

.course-box .bd-box + .bd-box {
    margin-top: 4.2rem;
}

@media screen and (min-width:768px) and (max-width:880px) {
    .course-box .bd-box--size-s {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

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

    .sec-course .ds-grid--space-ml > * {
        margin-top: 0;
    }

    .course-box .bd-box {
        padding: .9rem 1rem;
    }

    .course-box .bd-box--size-s {
        padding: .9rem .5rem;
    }

    .sp-acd-title {
        position: relative;
        cursor: pointer;
    }

    .course-box .sp-acd-title::after {
        position: absolute;
        right: 1rem;
        text-rendering: auto;
        font-size: 1rem;
        font-family: "Font Awesome 6 Free";
        font-weight: 900;
        -moz-osx-font-smoothing: grayscale;
        -webkit-font-smoothing: antialiased;
        font-style: normal;
        font-variant: normal;
        content: '\2b';
        font-size: 1.5rem;
        transition: all .3s;
    }

    .course-box .sp-acd-title.active::after {
        content: '\f068';
        transform: rotate(180deg);
    }

    .sp-acd-content {
        display: none;
    }
}

.course-box .rb-button--lg {
    top: -43px;
    margin-left: 3px;
    min-width: 85%;
    min-height: 50px;
    text-align: center;
    justify-content: center;
    background-color: var(--color-course);
    font-size: 1.25rem;
}

.course-box .rb-button--lg span {
    font-size: 1rem;
}

.course-box .rb-button--lg .rb-button-left:before,
.course-box .rb-button--lg .rb-button-left:after {
    left: -12px;
    border-bottom-color: var(--color-course);
    border-left-width: 12.5px;
    border-right-width: 12.5px;
    border-bottom-width: 25px;
}

.course-box .rb-button--lg .rb-button-right:before,
.course-box .rb-button--lg .rb-button-right:after {
    right: -12px;
    border-bottom-color: var(--color-course);
    border-bottom-color: var(--color-course);
    border-left-width: 12.5px;
    border-right-width: 12.5px;
    border-bottom-width: 25px;
}

@media screen and (min-width:768px) and (max-width:880px) {
    .course-box .rb-button--lg {
        font-size: 1rem;
    }

    .course-box .rb-button--lg span {
        font-size: .75rem;
    }
}

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

    .course-box .rb-button--lg {
        margin-left: 0;
        left: 4vw;
        min-width: 90%;
        font-size: 4.8vw;
    }

    .course-box .rb-button--lg span {
        font-size: .7em;
    }
}

.course-box--master {
    --color-course: #f07f19;
    --color-rgba-course: rgba(240, 127, 55, .6);
}


.course-box--subject {
    --color-course: #4D4399;
    --color-rgba-course: rgba(77, 67, 153, .6);
}

.course-box .bd-dotted {
    margin: 3rem -1.5rem;
    border: none;
    border-bottom: 2px dotted var(--color-course);
}

@media screen and (max-width:767px) {
    .course-box .bd-dotted {
        margin: 3rem -1rem;
    }
}


.course-box--personal {
    --color-course: #34acd5;
    --color-rgba-course: rgba(52, 172, 213, .6);
}

.step-list {
    margin-top: 2.2rem;
}

.step-box {
    position: relative;
    padding: 1rem 1.25rem 1.4rem;
    display: flex;
    flex-direction: column;
    background-color: #3150A3;
    border-radius: 16px;
    height: 100%;
    font-weight: 500;
    text-align: center;
    color: #fff;
}

.step-box.arrow:after {
    top: 50%;
    right: -33px;
    color: #3150A3;
    font-size: 2.5rem;
    transform: translateY(-50%);
}

.step-box .title-4 {
    position: absolute;
    text-align: left;
    font-weight: bold;
}

.step-number {
    margin-bottom: 1rem;
    font-size: 4rem;
    font-weight: bold;
    line-height: 1;
}

.is-style-ds-text-l + .is-style-ds-text {
    margin-top: .4rem;
    line-height: 1.5;
}

@media screen and (min-width:768px) {
    .step-list {
        margin: 2rem -1.375rem 2.5rem;
    }

    .step-list > * {
        padding: 0 1.375rem;
    }
}


@media screen and (max-width:767px) {
    .step-list {
        margin: 2rem auto 0;
        max-width: 287px;
    }

    .step-list .col + .col {
        margin-top: 3.7rem;
    }

    .step-box.arrow:after {
        width: 100%;
        top: auto;
        left: 0;
        right: 0;
        bottom: -57px;
        text-align: center;
        transform: rotate(90deg) translate(0);
    }
}

.is-style-ds-text + .is-style-ds-text-l {
    margin-top: 1rem;
}


.sec-faq .qa_box .qa_row:first-child {
    margin-top: 1rem;
    border-top: 1px solid #ccc;
}

.sec-faq .ds-box + .ds-box {
    margin-top: 3.125rem;
}

@media screen and (max-width: 767px) {
    .sec-faq .ds-box + .ds-box {
        margin-top:2.5rem;
    }

}

.bg-pink {
    background-color: #ed479b;
}

.card--row .card__title {
    color: #000;
    line-height: 2;
}

.card--row .card__title + .button-outline {
    margin-top: 1.5rem;
}

.card--row + .card--row {
    margin-top: 2rem;
}

@media screen and (min-width: 768px) and (max-width: 1040px) {
    .card--row .card__title {
        font-size: 1.1rem;
    }
}

@media screen and (min-width: 768px) {
    .card--row {
        position: relative;
        display: flex;
        justify-content: space-between;
        min-height: 227px;
    }

    .card--row .card__body {
        padding: 1.6rem 2.6rem 2rem;
        width: 63.3%;
    }

    .card--row .card__img {
        position: absolute;
        top: 0;
        right: 0;
        width: 36.7%;
        height: 100%;
    }

    .card--row .card__img .obj-fit-image {
        height: 100%;
    }
}

@media screen and (max-width: 767px) {
    #feature .inner--size-s {
        padding-bottom: 2.5rem;
    }

    .card--row {
        display: flex;
        flex-direction: column;
    }

    .card--row .card__body {
        padding: 1rem 1rem 3rem;
    }

    .card--row .card__title + .button-outline {
        margin-top: 1.3rem;
    }
}

.button-icn_wrap {
    margin: 0 auto;
    padding: 0;
    max-width: 812px;
    justify-content: space-between;
    list-style: none;
}


@media screen and (max-width: 767px) {
    .button-icn_wrap {
        margin-bottom: 3rem;
        padding: 0;
        max-width: 75vw;
    }

}

@media screen and (min-width: 768px) {
    #community .card .card__body {
        padding-left: 1.4rem;
        padding-bottom: 1.25rem;
    }
}

@media screen and (max-width: 767px) {
    #community .card .card__body {
        min-height: 197px;
    }
}


@media screen and (max-width: 767px) {
    #advice .ds-box {
        margin: 3rem -1rem 0;
    }

    .button-icn_wrap02 {
        margin: 0;
        flex-wrap: wrap;
        justify-content: center;
    }

    .button-icn_wrap02 .col {
        width: 48%;
        padding: 0;
        text-align: center;
    }
}

.img_lecturer {
    margin-top: 2.5rem;
    text-align: center;
}

@media screen and (min-width: 768px) {
    .img_lecturer {
        margin: 2.5rem auto 0;
        max-width: 543px;
    }
}

.section--top {
    padding: 5rem 0;
}

.section--top .inner {
    padding-top: 0;
    padding-bottom: 0;
}

.swiper {
    margin-top: 3.125rem;
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next,
.swiper-button-next,
.swiper-rtl .swiper-button-prev {
    top: 44%;
}

.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after,
.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
    color: var(--color-white);
    font-size: 2.25rem;
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
    left: 1.5rem;
}

.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
    content: '\f053';
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
    right: 1.5rem;
}

.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
    content: "\f054";
    right: 1.5rem;
}

.swiper .swiper-slide {
    padding-left: 1rem;
}

.swiper .swiper-slide a {
    text-decoration: none;
    color: var(--color-gray);
}

.swiper-slide .slide-vd iframe {
    vertical-align: middle;
    width: 100%;
    height: 13.6vw;
}

.swiper-slide .slide-vd + .swiper-slide .is-style-ds-text--size-s {
    margin-top: .4rem;
}


.section--top {
    padding: 4rem 0;
}

@media screen and (max-width: 767px) {
    .section--top {
        padding: 3.2rem 0 4rem;
    }

}

.swiper {
    margin-top: 2.5rem;
}

.swiper-controls {
    margin-top: 1.8rem;
    display: flex;
    justify-content: center;
    align-items: center;
}

.swiper-controls > * {
    position: static;
}

.swiper-controls .swiper-button-next,
.swiper-controls .swiper-button-prev {
    top: auto;
    bottom: 0;
    margin-top: 0;
}

.swiper-controls .swiper-button-prev {
    left: auto;
}

.swiper-controls .swiper-button-next {
    right: auto;
}

.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after,
.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
    color: var(--color-primary);
    font-size: 1.6rem;
}

.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    position: relative;
    top: -4px;
    margin: 0;
    padding: 0 1rem;
    width: auto;
}

.swiper-pagination-bullet {
    width: 8px;
    height: 8px;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 5px;
}

.swiper-pagination-bullet-active {
    background: var(--color-primary);
}



@media screen and (max-width: 767px) {
    .swiper-slide .slide-vd iframe {
        height: 45.4vw;
    }

}

@media screen and (min-width: 768px) {
    .swiper + .btn-wrap--size-m {
        margin-top: 2rem;
    }
}


.btn_application {
    margin: 1.25rem auto 0;
    max-width: 764px;
    display: flex;
    justify-content: space-between;
    gap: 0 2rem;
}

.btn_application .btn-col {
    width: 50%;
}

.btn_application .btn-col .t_small {
    margin-top: 1rem;
    font-size: 1rem;
    font-weight: normal;
}


.button-lg-lb {
    width: 100%;
    padding: 1.4rem 0;
    background-color: var(--color-light-sky);
    border-radius: 10px;
    text-align: center;
    color: var(--color-primary);
    font-size: 1.13rem;
    font-weight: 700;
    line-height: 1.8;
}

@media screen and (max-width: 767px) {
    .button-lg-lb {
        padding: 1.6rem 0;
    }
}


@media screen and (max-width: 767px) {
    .btn_application {
        margin-top: 1.4rem;
        max-width: 100%;
        flex-direction: column;
        gap: 1rem 0;
    }

    .btn_application .btn-col {
        width: 100%;
    }
}


/* #hayawari */

#hayawari .is-style-heading2 {
    text-align: center;
}

#hayawari .is-style-heading2 span {
    font-size: 3.5rem;
}

#hayawari .box {
    margin: 2rem 0;
    text-align: center;
}

#hayawari .box a {
    display: block;
    padding: 1rem 0;
    background-color: #D65B8E;
    border: 2px solid #D65B8E;
    border-radius: 20px;
    color: #fff;
    text-decoration: none;
}

#hayawari .box a:hover {
    opacity: 60%;
}

#hayawari .box p {
    padding-bottom: .5rem;
}

#hayawari .box .t1 {
    font-size: 1.2rem;
}

#hayawari .box .t2 {
    font-size: 1.6rem;
    padding-bottom: .5rem;
}

#hayawari .box .t3 {
    font-size: 1.2rem;
}

#hayawari .box .t4 {
    padding-bottom: 0;
}

#hayawari .box.tokutai a {
    background-color: var(--color-gray-1);
    border-color: var(--color-primary);
    color: var(--color-primary);
}


/* #next_class */
.next_class {
    margin-top: 3rem;
    padding: 0.5rem 0;
    border: var(--color-primary) solid 1px;
    text-align: center;
    font-size: 1.1rem;
    color: var(--color-primary);
}
