@charset "UTF-8";

/* ===========================
main
============================*/
/* sectionschoolIbttB */

/* 画像ZoomInアニメ */
.mainImg__outer {
    overflow: hidden;
    width: 100%;
    position: relative;
}

.mainImg {
    width: 100%;
}

.mainImg__outer img {
    /* img要素に以下のアニメーションプロパティが適用されます: */
    animation: zoom-in 4s linear 0s 1 normal both;
}

.mainTopic {
    color: #FFF;
    text-align: center;
    font-family: Marcellus;
    font-size: 1.6rem;
    letter-spacing: 0.96px;
    text-transform: uppercase;
    position: absolute;
    top: 12px;
    left: 50%;
    transform: translateX(-49%);
    width: 96%;
}

.mainTopic span {
    letter-spacing: 3.2px;
}

.section--schoolIbttB p {
    width: 300px;
    color: var(--primary-green);
    font-family: "Noto Serif JP";
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 1.6px;
    margin: 50px auto 0;
    text-align: center;
}

.section--schoolIbttB {
    position: relative;
}

.section--schoolIbttB::after {
    content: "";
    width: 90.6%;
    height: 0.6px;
    background-color: var(--primary-green);
    position: absolute;
    bottom: -12px;
    left: 50%;
    transform: translateX(-50%);
}

/* sectionIbtt pc*/
@media screen and (min-width:1025px) {
    .mainTopic {
        font-size: 3.7rem;
        letter-spacing: 7.4px;
        top: 50px;
        transform: translateX(-50%);
        width: 100%;
    }

    .section--schoolIbttB p {
        width: 704px;
        font-size: 2rem;
        letter-spacing: 2px;
        margin: 110px auto 0;
    }

    .section--schoolIbttB::after {
        width: 62.6%;
        bottom: -12px;
        min-width: 800px;
    }
}
/* pc 1025px */

/* sectionIbtt tb */
@media screen and (min-width: 768px) and (max-width: 1024px) {
        .mainTopic {
            font-size: 2.2rem;
            letter-spacing: 4.4px;
            top: 35px;
            width: 100%;
            transform: translateX(-50%);
        }

        .section--schoolIbttB p {
            width: 564px;
        }

        .section--schoolIbttB::after {
            width: 77.1%;
            bottom: -12px;
            max-width: 650px;
        }
}
/* tb 768px-1024px */

/* sectionCourse */
.enTxt {
    color: rgba(255, 255, 255, 0.70);
    text-align: center;
    font-family: Marcellus;
    font-size: 2.2rem;
    letter-spacing: 4.4px;
    text-transform: uppercase;
    margin-top: 70px;
}

.section--course h3 {
    text-align: center;
    font-family: "Noto Serif JP";
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: 2px;
    position: relative;
}

.section--course h3:after {
    content: "";
    width: 0.6px;
    height: 50px;
    background-color: var(--primary-glay);
    position: absolute;
    bottom: -74px;
    left: 50%;
    transform: translateX(-50%);
}

.title__small {
    font-weight: 400;
}

.course__desk span {
    margin-top: 16px;
    display: inline-block;
}

.txt,
.courseDesk__item p,
.section--curriculum li, 
.section--curriculum p,
.section--swedishMassage p {
    font-size: 1.6rem;
    letter-spacing: 0.96px;
}

.course__desk {
    width: 91.4%;
    margin: 100px auto 0;
}

.courseImg,
.curriculumImg__sp {
    width: 82.7%;
    margin: 40px 0 0 auto;
    display: block;
}

.courseImg--tb {
    display: none;
}

.courseDesk__list {
    margin: 95px auto 0;
    width: 91.4%;
} 

.courseDesk__list ul {
    padding: 16px 10px;
    margin-top: 20px;
    border-radius: 1px;
    background: var(--primary-beigeSchool);
    gap: 16px;
    display: flex;
    flex-direction: column;
    position: relative;
}

.courseDesk__list ul::before {
    content: "";
    width: 100%;
    height: 0.6px;
    background-color: var(--primary-glay);
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
}

h3,
.courseDesk__item h4,
.ability__list dt,
.openingInfo__outer dt {
    font-family: "Noto Serif JP";
    font-size: 1.7rem;
    font-weight: 600;
    line-height: 1.8; /* 30.6px */
    letter-spacing: 3.4px;
}

.courseDesk__item h4 {
    width: 101%;
}

.goal__list li {
    display: flex;
    align-items: flex-start;
    gap: 5px;
}

.goal__list img {
    width: 19px;
    margin-top: 3px;
}

.course__suggest {
    margin-top: 80px;
}

.bold {
    color: var(--primary-green);
    font-weight: 700;
}

/* sectionCourse pc*/
@media screen and (min-width:1025px) {
    .enTxt {
        font-size: 4.8rem;
        letter-spacing: 9.6px;
        margin-top: 190px;
    }

    .section--course h3 {
        font-size: 2.4rem;
        letter-spacing: 4.8px;
    }

    .section--course h3:after {
        height: 90px;
        bottom: -120px;
    }

    .course__desk span {
        margin-top: 10px;
    }

    .course__desk {
        width:  68%;
        margin: 196px auto 0;
    }

    .courseImg {
        width: 70.1%;
        margin: 80px 0 0 auto;
    }

    .courseDesk__list {
        margin: 120px auto 0;
        width: 81.7%;
        max-width: 1900px;
    } 

    .courseDesk__list ul {
        gap: 10px;
    }

    h3,
    .courseDesk__item h4,
    .ability__list dt,
    .openingInfo__outer dt {
        font-size: 2rem;
        line-height: 1.5; /* 30.6px */
        letter-spacing: 2px;
    }

    .courseDesk__item h4 {
        width: 100%;
        margin-left: 6px;
    }

    .suggest__list li {
        padding-left: 10px;
    }

    .suggest__list p {
        text-indent: -15px;
    }
}
/* pc 1025px */

/* sectionCourse tb */
@media screen and (min-width: 768px) and (max-width: 1024px) {
        .enTxt {
            font-size: 2.7rem;
            letter-spacing: 5.4px;
            margin-top: 100px;
        }

        .section--course h3:after {
            height: 50px;
            bottom: -70px;
        }

        .course__desk {
            width:  76.8%;
            margin: 100px auto 0;
        }

        .courseImg--tb {
            display: block;
            width: 70.5%;
            margin: 50px 0 0 auto;
        }

        .courseImg--spPc {
            display: none;
        }

        .courseDesk__list {
            margin: 100px auto 0;
            width: 87.5%;
        }

        .goal__list li {
            gap: 5px;
        }

        .course__suggest {
            margin-top: 50px;
        }

        .suggest__list li {
            padding-left: 10px;
        }

        .suggest__list p {
            text-indent: -15px;
        }
}
/* tb 768px-1024px */

/* sectionCurriculum */
.section--curriculum {
    margin-top: 90px;
}

.section--curriculum h3,
.section--curriculum p {
    margin-left: 5.3%;
}

.section--curriculum p {
    margin-top: 40px;
}

.section--curriculum p,
.section--curriculum li {
    line-height: 1.4;
}

.section--curriculum ul {
    width: 91.4%;
    padding: 10px;
    margin: 20px auto 0;
    border-radius: 1px;
    border: 2px solid var(--primary-beigeSchool);
    box-shadow: 4px 4px 4px 0px var(--primary-beigeSchool);
}

.section--curriculum li {
    margin-top: 10px;
    text-indent: -17px;
    padding-left: 17px;
}

.section--curriculum li:first-of-type {
    margin-top: 0;
}

.curriculumImg {
    display: none;
}

/* sectioncurriculm pc*/
@media screen and (min-width:1025px) {
    .section--curriculum {
        margin-top: 210px;
    }

    .section--curriculum h3,
    .section--curriculum p {
        margin-left: 9.1%;
    }

    .section--curriculum p {
        margin-top: 40px;
    }

    .section--curriculum ul {
        width: 81.7%;
    }

    .section--curriculum li {
        text-indent: 0;
        padding-left: 0;
    }

    .curriculumImg {
        width: 76%;
        display: block;
        margin: 120px 0 0 auto;
    }

    .curriculumImg__sp {
        display: none;
    }
}
/* pc 1025px */

/* sectionCurriculum tb */
@media screen and (min-width: 768px) and (max-width: 1024px) {
       .section--curriculum {
            margin-top: 140px;
        }

        .section--curriculum h3,
        .section--curriculum p {
            margin-left: 5.6%;
        }

        .section--curriculum p {
            margin-top: 30px;
        }

        .section--curriculum ul {
            width: 88.6%;
        }

        .curriculumImg {
            width: 82%;
            display: block;
            margin: 50px 0 0 auto;
        }

        .curriculumImg__sp {
            display: none;
        }
}
/* tb 768px-1024px */

/* sectionAbility */
.section--ability {
    margin-bottom: 85px;
}

.section--ability h3 {
    margin-top: 80px;
    color: rgba(255, 255, 255, 0.70);
    text-align: center;
    font-family: Marcellus;
    font-size: 2.2rem;
    font-weight: 400;
    letter-spacing: 4.4px;
    text-transform: uppercase;
}

.ability__list li {
    width: 82.1%;
    margin: 30px 5.2% 0 auto;
    position: relative;
}

.ability__list li::before {
    content: "";
    width: 0.6px;
    height: 100%;
    background-color: var(--primary-glay);
    position: absolute;
    top: 15px;
    left: -7px;
}

.ability__list p {
    font-family: Marcellus;
    font-size: 2rem;
    line-height: 1.6; /* 32px */
    letter-spacing: 0.8px;
    position: absolute;
    top: 0;
    left: -27px;
}

.item__number--02 {
    top: 14px !important;
}

.ability__list dt {
    letter-spacing: 1.7px;
    position: relative;
}

.ability__list dt::after {
    content: "";
    width: 109%;
    height: 0.6px;
    background-color: var(--primary-glay);
    position: absolute;
    bottom: -6px;
    left: -27px;
}

.item__title02,
.item__title03 {
    margin-top: 60px;
}

.item__txt {
    font-size: 1.6rem;
    letter-spacing: 0.96px;
    margin-top: 15px;
}

.item__txt span {
    margin-top: 24px;
    display: inline-block;
}

.item__txt--01 span {
    margin-top: 0;
    display: inline;
}

.item__txt .bold {
    color: var(--primary-black);
}

.indent {
    text-indent: -17px;
    padding-left: 17px;
}


/* sectionAbility pc*/
@media screen and (min-width:1025px) {
    .section--ability {
        margin-bottom: 140px;
    }

    .section--ability h3 {
        margin-top: 160px;
        font-size: 4.8rem;
        letter-spacing: 9.6px;
    }

    .ability__list li {
        width: 69.8%;
        margin: 114px 12% 0 auto;
    }

    .list01{
        margin-top: 75px !important;
    }

    .ability__list {
        max-width: 2400px;
    }

    .ability__list p {
        font-size: 3rem;
        letter-spacing: 1.2px;
        top: 1px;
        left: -102px;
    }

    .item__number--02 {
        top: 1px !important;
    }

    .ability__list dt {
        letter-spacing: 2px;
    }

    .ability__list li::before {
        left: -26px;
    }

    .ability__list dt::after {
        width: 107%;
        left: -58px;
    }

    .item__title02,
    .item__title03 {
        margin-top: 114px;
    }

    .item__txt {
        margin-top: 28px;
    }

    .item__txt--02 {
        display: flex;
        flex-direction: column;
    }

    .indent {
        text-indent: -34px;
        padding-left: 42px;
    }
}
/* pc 1025px */

/* sectionAbility tb */
@media screen and (min-width: 768px) and (max-width: 1024px) {
        .section--ability {
            margin-bottom: 140px;
        }

        .section--ability h3 {
            font-size: 2.6rem;
            letter-spacing: 5.2px;
        }

        .ability__list li {
            width: 74%;
            margin: 60px 11.2% 0 auto;
        }

        .list01{
            margin-top: 40px !important;
        }

        .ability__list p {
            top: 1px;
            left: -33px;
        }

        .item__number--02 {
            top: 1px !important;
        }

        .ability__list li::before {
            left: -10px;
        }

        .ability__list dt::after {
            left: -33px;
        }

        .item__title02,
        .item__title03 {
            margin-top: 0;
        }

        .item__txt {
            margin-top: 15px;
        }
}
/* tb 768px-1024px */


/* sectionswedishMassage */
.section--swedishMassage {
    display: flex;
    padding: 80px 4.2% 100px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 30px;
    background: var(--primary-beigeSchool);
}

/* sectionSwedishMassage pc*/
@media screen and (min-width:1025px) {
    .section--swedishMassage {
        padding: 150px 11.9%;
        align-items: start;
    }
}
/* pc 1025px */

/* sectionSwedishMassage tb */
@media screen and (min-width: 768px) and (max-width: 1024px) {
       .section--swedishMassage {
            padding: 80px 11.1%;
            align-items: start;
        } 
}
/* tb 768px-1024px */

/* sectioncourseInfo */
.section--courseInfo {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.openingInfo__outer {
    display: flex;
    width: 91.4%;
    max-width: 500px;
    padding: 14px 0px;
    margin-top: 90px;
    flex-direction: column;
    align-items: center;
    border-radius: 1px;
    background: rgba(53, 101, 104, 0.10);
    box-shadow: 0px 1px 4px 0px var(--line, rgba(47, 47, 47, 0.30));
}

.openingInfo__outer dt {
    text-align: center;
    color: var(--primary-green);
    position: relative
}

.openingInfo__outer dt::after {
    content: "";
    width: 280px;
    height: 0.6px;
    background-color: var(--primary-green);
    position: absolute;
    bottom: -12px;
    left: 50%;
    transform: translateX(-50%);
}

.openingInfo__outer dd {
    font-family: "Noto Serif JP";
    text-align: center;
    font-size: 1.7rem;
    font-weight: 500;
    margin-top: 25px;
    letter-spacing: 1.02px;
    height: 110px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.info__outer,
.flame {
    display: flex;
    flex-direction: column;
    align-self: start;
    /* width: 91.4%; */
    width: 343px;
    margin: 0 auto;
}

.topic--courseInfo {
    margin-top: 80px;
}

.courseTitle {
    margin-top: 16px;
    color: var(--primary-green);
    font-family: "Noto Serif JP";
    font-size: 1.7rem;
    font-weight: 600;
    line-height: 1.8; /* 30.6px */
    letter-spacing: 1.7px;
}

/* table */
.empty {
    display: none;
}

.courseTable {
    margin-top: 20px;
}

.courseTable--online {
    margin-top: 50px;
}

.itemBox {
    display: flex;
}

.tableTitle {
    width: 78px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-right: 1px solid var(--primary-glay);
    border-left: 1px solid var(--primary-glay);
}

.tableTitle__outer--01 div:first-of-type {
    height: 225.7px;
    position: relative;
}

.tableTitle__outer--01 div:nth-of-type(2),
.tableTitle__outer--01 div:nth-of-type(3),
.tableTitle__outer--02 div:nth-of-type(3) {
    height: 85.5px;
    position: relative;
}

.tableTitle__outer--01 div:nth-of-type(4),
.tableTitle__outer--02 div:nth-of-type(4) {
    height: 115.7px;
    position: relative;
}

.tableTitle__outer--01 div:nth-of-type(5),
.tableTitle__outer--02 div:nth-of-type(5) {
    height: 166px;
    position: relative;
}

.tableTitle__outer--02 div:first-of-type {
    height: 458.9px;
    position: relative;
}

.tableTitle__outer--02 div:nth-of-type(2) {
    height: 531.7px;
    position: relative;
}

.tableTitle__outer--01 div:first-of-type::before,
.tableTitle__outer--02 div:first-of-type::before,
.tableTitle__outer--01 div:nth-of-type(2)::before,
.tableTitle__outer--02 div:nth-of-type(2)::before,
.tableTitle__outer--01 div:nth-of-type(3)::before,
.tableTitle__outer--02 div:nth-of-type(3)::before,
.tableTitle__outer--01 div:nth-of-type(4)::before,
.tableTitle__outer--02 div:nth-of-type(4)::before,
.tableTitle__outer--01 div:nth-of-type(5)::before,
.tableTitle__outer--02 div:nth-of-type(5)::before {
    content: "";
    width: 342.2px;
    height: 1.3px;
    background-color: var(--primary-glay);
    position: absolute;
    left: 0;
    bottom: 0;
    transform: scaleY(0.5); /* 半分にして1px相当に */
    transform-origin: bottom;
}

.title__class {
    width: 343px;
    padding: 19px 0px;
    text-align: center;
    border-radius: 1px 1px 0px 0px;
    background: var(--primary-greenLow);
    border-top: 1px solid var(--primary-glay);
    border-right: 1px solid var(--primary-glay);
    border-left: 1px solid var(--primary-glay);
    border-bottom: 1px solid var(--primary-glay);
}

.title__class--online {
    background-color: var(--secondary-green);
}

.tableItem {
    width: 265px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-bottom: 20px;
    padding-top: 20px;
    background-color: var(--primary-beigeSalon);
    /* border-top: 1px solid var(--primary-glay); */
    border-right: 1px solid var(--primary-glay);
}

.tableItem__outer {
    width: 100%;
}

.table__desk  {
    text-align: start;
    width: 210px;
}

.table__desk--fee,
.fee__mt {
    margin-top: 20px;
}

.contentsBox--place01,
.contentsBox--term p:last-child,
.contentsBox--fee {
    text-align: center;
}

.contentsBox--place02 p {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.table__desk--place {
    width: auto;
}

.contentsBox--place02 div {
    margin-top: 20px;
}

.contentsBox--place02 div:first-child {
    margin-top: 0;
}

.contentsBox--schedule p {
    width: 235px;
}

.contentsBox--term p:last-of-type,
.contentsBox--capacity p:last-of-type {
    margin-top: 8px;
}

/* table文字設定 */
.title__class,
.tableItem p,
.tableTitle,
.contentsBox--fee,
.contentsBox--place01,
.contentsBox--place02 {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.4; /* 22.4px */
    letter-spacing: 0.64px;
}

.title__class,
.tableTitle,
.contentsBox--place01,
.contentsBox--place02 p {
    font-weight: 500;
}

.fee {
    color: var(--primary-black);
    text-align: center;
    font-size: 2rem;
    font-weight: 500;
    letter-spacing: 0.8px;
}

.tax,
.table__desk,
.capacity span,
.tableItem .table__desk--fee,
.tableItem .table__desk--capacity {
    color: var(--primary-blackLow);
    font-size: 1.4rem;
    font-weight: 400;
    letter-spacing: 0.56px;
}

.tax {
    color: var(--primary-black);
}

.contentsBox--schedule,
.contentsBox--term,
.capacity,
.contentsBox--fee p {
    font-weight: 400;
}

.underline,
.contentsBox--fee p {
    color: var(--primary-blackLow);
}

.underline:hover {
    color: var(--primary-green);
    border-bottom: 0.6px solid var(--primary-green);
}

.termSmall {
    font-size: 1.5rem;
    letter-spacing: 0.3px;
}

/* contact */
.contact {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.contact strong {
    margin-top: 60px;
    font-family: "Noto Serif JP";
    font-size: 1.7rem;
    font-weight: 600;
    line-height: 1.8; /* 30.6px */
    letter-spacing: 1.7px;
    display: block;
}

.btn__inner {
    display: flex;
    width: 280px;
    padding: 10px;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 1px;
    background: var(--primary-green);
    box-shadow: 2px 4px 4px 0px var(--line, rgba(47, 47, 47, 0.30));
}

.btn__inner:hover {
    box-shadow: 0 1px 10px rgba(0, 0, 0, 0.5), 0 0 50px rgba(128, 128, 128, 0.1) ;
    border-color: transparent;
}

.btn__inner:first-of-type {
    margin-top: 20px;
}

.btn__inner:last-of-type {
    margin-top: 24px;
}

.contact p {
    color: #FFF;
    text-align: center;
    font-family: "Noto Serif JP";
    font-size: 1.7rem;
    font-weight: 500;
    line-height: 1.5; /* 25.5px */
    letter-spacing: 1.02px;
}

/* sectionCourseInfo pc*/
@media screen and (min-width:1025px) {
    .openingInfo__outer {
        width: 720px;
        max-width: initial;
        display: block;
        margin: 150px auto 0 0;
        padding-bottom: 14px;
    }

    .openingInfo__outer dt::after {
        width: 658px;
        bottom: -12px;
    }

    .openingInfo__outer dd {
        margin-top: 22px;
        height: 110px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .info__outer,
    .flame {
        /* width: 75.7%; */
        width: 1090px;
        justify-content: center;
    }

    .topic--courseInfo {
        margin-top: 85px;
    }

    .courseTitle {
        margin-top: 0;
        font-size: 2rem;
        line-height: 1.5; 
        letter-spacing: 2px;
    }

    .place p {
        align-items: flex-start;
    }

    /* table */
    .flame {
        display: flex;
        flex-direction: row;
        justify-content: flex-end;
    }
    
    .tableTitle__outer--02,
    .tableItem--schedule02,
    .tableItem--term02,
    .tableItem--capacity02 {
        display: none;
    }

    .classBox {
        display: flex;
    }

    .empty {
        display: block;
        width: 250px;
        border-top: 1px solid var(--primary-glay);
        border-left: 1px solid var(--primary-glay);
        border-right: 1px solid var(--primary-glay);
        border-bottom: 1px solid var(--primary-glay);
    }

    .courseTable {
        margin-top: 15px;
        margin-left: -420px;
    }

    .tableTitle {
        width: 250px;
    }

    .title__class {
        width: 420px;
        padding: 17.5px 0px;
        border-left: none;
    }

    .tableItem {
        width: 420px;
    }

    .table__desk  {
        width: 370px;
    }

    .contentsBox--fee .table__desk--fee {
        margin-top: 0;
    }

    .fee__mt {
        margin-bottom: 20px;
    }

    .table__desk--place02 {
        width: 384px;
    }

    .contentsBox--schedule p {
        width: auto;
    }

    .table__desk--capacity {
        width: 500px;
    }

    .contentsBox--place02 p {
        align-items: start;
    }

    .tableTitle__outer--01 div:first-of-type,
    .tableItem__outer01 .tableItem:first-child {
        height: 318.5px;
    }

    .tableTitle__outer--01 div:nth-of-type(2),
    .tableItem__outer01 .tableItem:nth-child(2) {
        height: 357.5px;
    }

    .tableTitle__outer--01 div:nth-of-type(3) {
        height: 62.9px;
    }
    
    .tableTitle__outer--01 div:nth-of-type(4) {
        height: 93.3px;
    }

    .tableTitle__outer--01 div:nth-of-type(5) {
        height: 109.5px;
    }

    .tableTitle__outer--01 div:first-of-type::before,
    .tableTitle__outer--02 div:first-of-type::before,
    .tableTitle__outer--01 div:nth-of-type(2)::before, 
    .tableTitle__outer--02 div:nth-of-type(2)::before, 
    .tableTitle__outer--01 div:nth-of-type(3)::before, 
    .tableTitle__outer--02 div:nth-of-type(3)::before, 
    .tableTitle__outer--01 div:nth-of-type(4)::before, 
    .tableTitle__outer--02 div:nth-of-type(4)::before, 
    .tableTitle__outer--01 div:nth-of-type(5)::before, 
    .tableTitle__outer--02 div:nth-of-type(5)::before {
        width: 1090px;
    }

    .tableItem--schedule,
    .tableItem--term,
    .tableItem--capacity {
        width: 840px;
    }

    .tableItem--capacity {
        text-align: center;
    }

    /* table文字設定 */
    .title__class,
    .tableTitle,
    .contentsBox--place01,
    .contentsBox--place02 p {
        font-size: 1.8rem;
        letter-spacing: 0.72px;
    }

    /* contact */
    .contact strong {
        margin-top: 70px;
        font-size: 2rem;
        line-height: 1.5; /* 30.6px */
        letter-spacing: 2px;
    }

    .contactBtn__outer {
        display: flex;
        gap: 24px;
        margin-top: 20px;
    }

    .btn__inner {
        margin-top: 0 !important;
    }
}
/* pc 1025px */

/* sectionCourseInfo カスタムブレイクポイント */
@media screen and (min-width: 550px) and (max-width: 767.9px) {
    .info__outer,
    .flame,
    .title__class {
        width:500px;
    }

    .tableItem {
        width: 422px;
    }

    .contentsBox--schedule p,
    .contentsBox--term {
        width: 292px;
    }

    .contentsBox--term {
        text-align: center;
    }

    .table__desk {
        text-align: start;
        width: 300px;
    }

    .table__desk--place {
        text-align: start;
        display: inline-block;
        width: auto;
    }

    .tableTitle__outer--01 div:first-of-type {
        height: 166.4px;
    }

    .tableTitle__outer--01 div:nth-of-type(2), 
    .tableTitle__outer--01 div:nth-of-type(3), 
    .tableTitle__outer--02 div:nth-of-type(3) {
        height: 84.9px;
    }

    .tableTitle__outer--01 div:nth-of-type(4),
     .tableTitle__outer--02 div:nth-of-type(4) {
        height: 115.2px;
    }

    .tableTitle__outer--01 div:nth-of-type(5),
    .tableTitle__outer--02 div:nth-of-type(5) {
        height: 148.8px;
    }

    .tableTitle__outer--02 div:first-of-type {
        height: 380px;
    }

    .tableTitle__outer--02 div:nth-of-type(2) {
        height: 452.7px;
    }

    .tableTitle__outer--01 div:first-of-type::before,
    .tableTitle__outer--02 div:first-of-type::before,
    .tableTitle__outer--01 div:nth-of-type(2)::before,
    .tableTitle__outer--02 div:nth-of-type(2)::before,
    .tableTitle__outer--01 div:nth-of-type(3)::before,
    .tableTitle__outer--02 div:nth-of-type(3)::before,
    .tableTitle__outer--01 div:nth-of-type(4)::before,
    .tableTitle__outer--02 div:nth-of-type(4)::before,
    .tableTitle__outer--01 div:nth-of-type(5)::before,
    .tableTitle__outer--02 div:nth-of-type(5)::before {
        width: 499.2px;
    }
}
/* カスタム　426px-767px */

/* sectionCourseInfo tb */
@media screen and (min-width: 768px) and (max-width: 1024px) {
        .openingInfo__outer {
            width: 550px;
            max-width: initial;
            display: block;
            margin: 110px auto 0 0;
        }

        .openingInfo__outer dt::after {
            width: 502px;
            bottom: -15px;
        }

        .openingInfo__outer dd {
            margin-top: 25px;
            height: 110px;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .openingInfo__outer .pcSpan {
            display: none;
        }

        .info__outer,
        .flame {
            /* width: 89.6%; */
            width: 688px;
        }

        .openingInfo__outer .pcSpan {
            display: inline-block;
        }

        .topic--courseInfo {
            margin-top: 80px;
        }

        .courseTitle {
            margin-top: 4px;
        }

        .courseTable--online {
            width: 305px;
        }

        .title__class {
            border-left: none;
        }

        /* table */
        .flame {
            display: flex;
            flex-direction: row;
            justify-content: flex-end;
        }
        
        .tableTitle__outer--02,
        .tableItem--schedule02,
        .tableItem--term02,
        .tableItem--capacity02 {
            display: none;
        }

        .classBox {
            display: flex;
        }

        .empty {
            display: block;
            width: 76px;
            border-top: 1px solid var(--primary-glay);
            border-left: 1px solid var(--primary-glay);
            border-right: 1px solid var(--primary-glay);
            border-bottom: 1px solid var(--primary-glay);
        }

        .courseTable {
            margin-top: 15px;
            margin-left: -305.1px;
        }

        .tableTitle {
            width: 76px;
        }

        .title__class {
            width: 305px;
            padding: 19px 0px;
        }

        .tableItem {
            width: 305px;
        }

        .table__desk  {
            width: 280px;
        }

        .table__desk--fee {
            margin-top: 10px;
        }

        .fee__mt {
            margin-bottom: 20px;
        }

        .fee__mt .spBr {
            display: block;
        }

        .contentsBox--place02 .spBr{
            display: block;
        }

        .table__desk--capacity {
            width: 500px;
        }
            
        .tableTitle__outer--01 div:first-of-type,
        .tableItem__outer01 .tableItem:first-child {
            height: 390.1px;
        }

        .tableTitle__outer--01 div:nth-of-type(2),
        .tableItem__outer01 .tableItem:nth-child(2) {
            height: 472.9px;
        }

        .tableTitle__outer--01 div:nth-of-type(3) {
            height: 62.9px;
        }
        
        .tableTitle__outer--01 div:nth-of-type(4) {
            height: 93.3px;
        }

        .tableTitle__outer--01 div:nth-of-type(5) {
            height: 109.4px;
        }

        .tableTitle__outer--01 div:first-of-type::before,
        .tableTitle__outer--02 div:first-of-type::before,
        .tableTitle__outer--01 div:nth-of-type(2)::before,
        .tableTitle__outer--02 div:nth-of-type(2)::before,
        .tableTitle__outer--01 div:nth-of-type(3)::before,
        .tableTitle__outer--02 div:nth-of-type(3)::before,
        .tableTitle__outer--01 div:nth-of-type(4)::before,
        .tableTitle__outer--02 div:nth-of-type(4)::before,
        .tableTitle__outer--01 div:nth-of-type(5)::before,
        .tableTitle__outer--02 div:nth-of-type(5)::before {
            width: 685.6px;
        }

        .tableItem--schedule,
        .tableItem--term,
        .tableItem--capacity {
            width: 610px;
        }

        .capacity {
            text-align: center;
        }

        .contentsBox--schedule p {
            width: auto;
        }

        /* contact */
        .contact strong {
            margin-top: 70px;
            text-align: center;
        }

        .contactBtn__outer {
            display: flex;
            gap: 24px;
            margin-top: 20px;
        }

        .btn__inner {
            margin-top: 0 !important;
        } 
}
/* tb 768px-1024px */

/* sectionCourseInfo カスタムブレイクポイント */
@media (min-width: 900px) and (max-width: 1150px) {
    .info__outer, 
    .flame {
        width: 850px;
    }

    .flame {
        transform: translateX(379px);
        justify-content: flex-start;
    }
        
    .section--courseInfo {
        overflow-x: hidden;
    }

    .courseTable {
        margin-left: -380px;
    }

    .tableTitle,
    .empty {
        width: 90px;
    }

    .tableItem {
        width: 380px;
    }

    .title__class {
        width: 380px;
        padding: 19px 0px;
    }

    .tableItem--schedule,
    .tableItem--term,
    .tableItem--capacity {
        width: 760px;
    }

    .table__desk  {
        width: 280px;
    }

    .fee__outer .table__desk--fee02 {
        margin-top: 10px;
    }

    .fee__mt .spBr {
        display: block;
    }

    .table__desk--fee .pcBr {
        display: none;
    }

    .contentsBox--place02 .spBr {
        display: block;
    }

    .contentsBox--place02 p {
        align-items: center;
    }

    .table__desk--fee {
        margin-top: 10px !important;
    }

    .table__desk--capacity {
        width: 500px;
    }
    
    .tableTitle__outer--01 div:first-of-type,
    .tableItem__outer01 .tableItem:first-child {
        height: 390.1px;
    }

    .tableTitle__outer--01 div:nth-of-type(2),
    .tableItem__outer01 .tableItem:nth-child(2) {
        height: 473px;
    }

    .tableTitle__outer--01 div:nth-of-type(3) {
        height: 62.9px;
    }
    
    .tableTitle__outer--01 div:nth-of-type(4) {
        height: 93.3px;
    }

    .tableTitle__outer--01 div:nth-of-type(5) {
        height: 109.5px;
    }

    .tableTitle__outer--01 div:first-of-type::before,
    .tableTitle__outer--02 div:first-of-type::before,
    .tableTitle__outer--01 div:nth-of-type(2)::before,
    .tableTitle__outer--02 div:nth-of-type(2)::before,
    .tableTitle__outer--01 div:nth-of-type(3)::before,
    .tableTitle__outer--02 div:nth-of-type(3)::before,
    .tableTitle__outer--01 div:nth-of-type(4)::before,
    .tableTitle__outer--02 div:nth-of-type(4)::before,
    .tableTitle__outer--01 div:nth-of-type(5)::before,
    .tableTitle__outer--02 div:nth-of-type(5)::before {
        width: 849.6px;
    }

    .title__class, 
    .tableTitle, 
    .contentsBox--place01, 
    .contentsBox--place02 p {
        font-size: 1.6rem;
        letter-spacing: 0.64px;
    }

    /* contact */
    .contact strong {
        margin-top: 70px;
        text-align: center;
    }

    .contactBtn__outer {
        display: flex;
        gap: 24px;
        margin-top: 20px;
    }

    .btn__inner {
        margin-top: 0 !important;
    } 
}
/* カスタム　900px-1150px */

/* sectionCourseInfo カスタムブレイクポイント */
@media (max-width: 366px) {
    .info__outer,
    .flame,
    .title__class {
        width: 295px;
    }

    .tableItem {
        width: 223px;
    }

    .tableTitle {
        width: 72px;
    }

    .contentsBox--schedule p,
    .contentsBox--term {
        width: 195px;
    }

    .table__desk--place {
        text-align: start;
        display: inline-block;
        width: 195px;
    }

    .table__desk {
        text-align: start;
        width: 195px;
    }

    .tableTitle__outer--01 div:nth-of-type(2) {
        height: 102.7px;
    }

    .tableTitle__outer--01 div:nth-of-type(3),
    .tableTitle__outer--02 div:nth-of-type(3) {
        height: 107.7px;
    }

    .tableTitle__outer--02 div:nth-of-type(4),
    .tableTitle__outer--01 div:nth-of-type(4) {
        height: 138.1px;
    }

    .tableTitle__outer--02 div:nth-of-type(2) {
        height: 571px;
    }

    .tableTitle__outer--02 div:nth-of-type(5) {
        height: 166px;
    }

    .tableTitle__outer--01 div:first-of-type::before,
    .tableTitle__outer--02 div:first-of-type::before,
    .tableTitle__outer--01 div:nth-of-type(2)::before,
    .tableTitle__outer--02 div:nth-of-type(2)::before,
    .tableTitle__outer--01 div:nth-of-type(3)::before,
    .tableTitle__outer--02 div:nth-of-type(3)::before,
    .tableTitle__outer--01 div:nth-of-type(4)::before,
    .tableTitle__outer--02 div:nth-of-type(4)::before,
    .tableTitle__outer--01 div:nth-of-type(5)::before,
    .tableTitle__outer--02 div:nth-of-type(5)::before {
        width: 294.2px;
    }

    .termSmall {
        font-size: 1.4rem;
    }
}
/* カスタム　366px */

/* sectionclassSchedule */
.section--classSchedule h3 {
    margin-top: 160px;
    text-align: center;
}

.section--classSchedule p {
    margin: 30px auto 0;
    width: 91.4%;
    max-width: 414px;
    display: block;
    font-family: "Noto Serif JP";
    font-size: 1.7rem;
    letter-spacing: 1.02px;
}

.course__link {
    width: 90.7%;
    max-width: 350px;
    height: 88px;
    padding: 20px 0;
    margin: 50px auto 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 1px;
    border: 1px solid var(--primary-blackLow);
    box-shadow: 2px 2px 4px 0px var(--line, rgba(47, 47, 47, 0.10));
    font-family: "Noto Serif JP";
    font-size: 1.5rem;
    line-height: 1.6; /* 24px */
    letter-spacing: 0.6px;
}

.course__link:last-child {
    margin-top: 30px;
}

.course__link:hover {
    color: #FFF;
    background-color: var(--primary-green);
    box-shadow: 0 1px 10px rgba(0, 0, 0, 0.4), 0 0 50px rgba(128, 128, 128, 0.1) ;
    border-color: transparent;
}

.arrow {
    font-size: 1.6rem;
    letter-spacing: 1.6px;
    margin-left: 18px;
}

/* sectionClassschedule pc*/
@media screen and (min-width:1025px) {
   .section--classSchedule h3 {
        margin-top: 290px;
    }

    .section--classSchedule p {
        margin: 60px auto 0;
        text-align: center;
    }
    
    .course__linkOuter {
        display: flex;
        gap: 50px;
        width: 720px;
        margin: 30px auto 0;
        justify-content: center;
    }

    .course__link {
        width: 340px;
        max-width: none;
        padding: 20px 30px;
        margin: 0 auto;
    }

    .course__link:last-child {
        margin-top: 0;
    }
}
/* pc 1025px */

/* sectionClassschedule tb */
@media screen and (min-width: 768px) and (max-width: 1024px) {
        .section--classSchedule h3 {
            margin-top: 190px;
        }    
                
        .course__link:last-child {
            margin-top: 50px;
        }
    
        .course__link--02 {
            margin-top: 30px !important;
        }
}
/* tb 768px-1024px */

/* sectionSchedule */
.section--schedule h3 {
    margin-top: 155px;
    text-align: center;
}

.section--schedule p {
    font-family: "Noto Serif JP";
    font-size: 1.6rem;
    letter-spacing: 0.96px;
    width: 81.6%;
    max-width: 462px;
    margin: 50px auto 40px;
}

.google__schedule {
    display: flex;
}

.google__schedule iframe {
    height: 279px;
    margin: 0 auto;
    width: 91.4%;
    min-width: 300px;
    max-width: 400px;
}

.course__link--toTop {
    margin: 150px auto 180px !important;
}

/* sectionSchedule pc*/
@media screen and (min-width:1025px) {
    .section--schedule h3 {
        font-size: 2rem;
        letter-spacing: 4px;
        margin-top: 200px;
    }
    
    .section--schedule p {
        font-size: 1.7rem;
        letter-spacing: 1.02px;
        width: 491px;
        max-width: none;
        margin: 40px auto;
    }
    
    .google__schedule iframe {
        width: 580px;
        height: 394px;
        min-width: initial;
        max-width: initial;
    }

    .course__link--toTop {
        margin: 160px auto 280px !important;
    }
}
/* pc 1025px */

/* sectionSchedule tb*/
@media screen and (min-width: 768px) and (max-width: 1024px) {
        .section--schedule h3 {
            margin-top: 150px;
        }
            
        .section--schedule p {
            margin: 40px auto;
        }
        
        .google__schedule iframe {
            width: 500px;
            height: 340px;
            max-width: none;
        }
            
        .course__link--toTop {
            margin: 170px auto 180px!important;
        }
}
/* tb 768px-1024px */

/* 各種 カスタムブレイクポイント */
@media (max-width: 340px) {
    .section--schoolIbttB p {
        width: 97.3%;
        font-size: 1.4rem;
    }

    .enTxt {
        font-size: 2rem
    }

    .section--course h3 {
        font-size: 1.8rem;
        letter-spacing: 1px;
    }
    
    .courseDesk__item h4 {
        font-size: 1.6rem;
        letter-spacing: 1px;
    }

    .section--curriculum p {
        letter-spacing: 0.5px;
        font-size: 1.5rem;
    }
}

/* else カスタムブレイクポイント */
@media (min-width: 950px) and (max-width: 1200px) {
    .mainTopic {
        font-size: 3rem;
    }
    
    .enTxt,
    .section--ability h3 {
        font-size: 3.8rem;
    }
}