@charset "utf-8";

*,
::before,
::after {
  font-size: 16.5px;
}

@media (max-width: 1040px) {

  *,
  ::before,
  ::after {
    font-size: 14px;
  }
}

/** ▼▼▼▼▼ FARST VIEW ▼▼▼▼▼ **/
#farstview {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100vh;
    margin-top: 89px;
    background: url(../images/bg_farstview.png) no-repeat center center / cover;
}

#farstview h1 {
    width: 50%;
    height: auto;
}
/** ▲▲▲▲▲ FARST VIEW ▲▲▲▲▲ **/

/** ▼▼▼▼▼ CATCH ▼▼▼▼▼ **/
#catch {
    margin-top: 60px;
}

#catch h2 {
    font-size: 1.66em;
    font-weight: 700;
    line-height: 200%;
    letter-spacing: 0.05em;
    text-align: center;
}
/** ▲▲▲▲▲ CATCH ▲▲▲▲▲ **/

/** ▼▼▼▼▼ LESSON ▼▼▼▼▼ **/
#lesson {
    margin-top: 100px;
    display: flex;
    justify-content: center;
}

#lesson > ul {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: row-reverse;
    width: 1000px;
    list-style: none;
}

#lesson > ul > li:nth-child(1) {
    width: 350px;
    margin: 20px 0 0 20px;
    background: #9bac87;
}

#lesson > ul > li:nth-child(1) img {
    position: relative;
    top: -20px;
    left: -20px;
    /**width: 100%;
    height: auto;**/
}

#lesson > ul > li:nth-child(2) {
    width: 600px;
}

#lesson > ul > li:nth-child(2) > h2 {
    margin-top: -10px;
}

#lesson > ul > li:nth-child(2) > p {
    margin-top: 30px;
}

#lesson > ul > li:nth-child(2) > ul {
    margin-top: 40px;
    padding-left: 20px;
}

#lesson > ul > li:nth-child(2) > ul > li {
    margin-bottom: 15px;
    list-style-type: disc;
    font-size: 1.11em;
    letter-spacing: 0.05em;
}

#lesson > ul > li:nth-child(2) > div.is {
    margin-top: 20px;
    padding: 30px;
    border-radius: 10px;
    background: #e1e6db;
    font-size: 0.83em;
    line-height: 200%;
    letter-spacing: 0.05em;
}

#lesson > ul > li:nth-child(2) > div.is > h3 {
    font-size: 1.2em;
    font-weight: 700;
    letter-spacing: 0.05em;
    margin-bottom: 20px;
}

#lesson > ul > li:nth-child(2) > div.is > span {
    display: block;
    margin-top: 20px;
    text-align: right;
}

#lesson > ul > li:nth-child(2) > div.is > span > a {
    text-decoration: underline;
    text-align: right;
}

#lesson > ul > li:nth-child(2) > div.btn {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
}

#lesson > ul > li:nth-child(2) > div.btn a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 290px;
    height: 50px;
    background: #9bac87;
    border-radius: 5px;
    font-size: 1.11em;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 100%;
    color: #FFFFFF;
}

#lesson > ul > li:nth-child(2) > ul.ask {
    display: flex;
    justify-content: space-between;
    width: 600px;
    padding: 0;
}

#lesson > ul > li:nth-child(2) > ul.ask > li:nth-child(1) {
    width: 460px;
    list-style: none;
}

#lesson > ul > li:nth-child(2) > ul.ask > li:nth-child(1) > p {
    font-size: 0.9em;
    line-height: 200%;
}

#lesson > ul > li:nth-child(2) > ul.ask > li:nth-child(1) > a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 600px;
    height: 50px;
    margin-top: 10px;
    background: #9bac87;
    border-radius: 5px;
    font-size: 1.11em;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 100%;
    color: #FFFFFF;
}

#lesson > ul > li:nth-child(2) > ul.ask > li:nth-child(2) {
    width: 120px;
    list-style: none;
    padding-top: 5px;
}

#lesson > ul > li:nth-child(2) > ul.ask > li:nth-child(2) > a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 120px;
    height: 120px;
    background: #9bac87;
    border-radius: 5px;
}

#lesson > ul > li:nth-child(2) > ul.ask > li:nth-child(2) > a img {
    width: 100px;
    height: auto;
}
/** ▲▲▲▲▲ LESSON ▲▲▲▲▲ **/

/** ▼▼▼▼▼ MAIN COACH ▼▼▼▼▼ **/
#main_coach {
    /**display: flex;
    justify-content: center;**/
    margin-top: 100px;
}

#main_coach h2 {
    width: 350px;
    margin: 0 auto;
    text-align: center;
}

#main_coach > ul {
    display: flex;
    justify-content: space-between;
    width: 1000px;
    margin: 60px auto 0 auto;
}

#main_coach > ul > li {
    width: 470px;
}

#main_coach > ul > li > span {
    display: block;
    width: 450px;
    height: 550px;
    background: #9bac87;
}

#main_coach > ul > li:nth-child(1) > span {
    position: relative;
    top: 20px;
    left: 20px;
}

#main_coach > ul > li:nth-child(1) > span > img {
    position: relative;
    top: -20px;
    left: -20px;
}

#main_coach > ul > li:nth-child(2) > span {
    position: relative;
    top: 0;
    left: 20px;
}

#main_coach > ul > li:nth-child(2) > span > img {
    position: relative;
    top: 20px;
    left: -20px;
}

/**#main_coach > ul > li > img {
    width: 450px;
}**/

#main_coach > ul > li > h3 {
    margin-top: 50px;
    text-align: center;
}

#main_coach > ul > li > p {
    margin-top: 30px;
}
/** ▲▲▲▲▲ MAIN COACH ▲▲▲▲▲ **/

/** ▼▼▼▼▼ COACH ▼▼▼▼▼ **/
#coach {
    margin-top: 100px;
}

#coach h2 {
    width: 350px;
    margin: 0 auto;
    text-align: center;
}

#coach > ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 1000px;
    margin: 60px auto 0 auto;
}

#coach > ul > li:nth-child(1) {
    width: 300px;
}

#coach > ul > li:nth-child(2) {
    width: 650px;
}

#coach > ul > li:nth-child(2) > p {
    margin-top: 20px;
}

#coach > a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 700px;
    height: 80px;
    margin: 100px auto 0 auto;
    background: #9bac87;
    border-radius: 15px;
    font-size: 1.38em;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0.05em;
    color: #FFFFFF;
}
/** ▲▲▲▲▲ COACH ▲▲▲▲▲ **/


.ttl {
    width: 100%;
    font-size: 1.55em;
    line-height: 130%;
    letter-spacing: 0.05em;
    border-bottom: 5px solid #9bac87;
}

.text_01 {
    font-size: 1em;
    font-weight: 500;
    line-height: 200%;
    letter-spacing: 0.05em;
}

.text_02 {
    font-size: 1.38em;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0.05em;
}


@media (max-width: 1040px) {
    /** ▼▼▼▼▼ FARST VIEW ▼▼▼▼▼ **/
    #farstview {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 100vh;
        margin-top: 72px;
        background: url(../images/bg_farstview.png) no-repeat left -250px center / cover;
    }

    #farstview h1 {
        width: 50%;
        height: auto;
    }
    /** ▲▲▲▲▲ FARST VIEW ▲▲▲▲▲ **/

    /** ▼▼▼▼▼ CATCH ▼▼▼▼▼ **/
    /**#catch {
        margin-top: 60px;
    }**/

    /**#catch h2 {
        font-size: 1.66em;
        font-weight: 700;
        line-height: 200%;
        letter-spacing: 0.05em;
        text-align: center;
    }**/
    /** ▲▲▲▲▲ CATCH ▲▲▲▲▲ **/

    /** ▼▼▼▼▼ LESSON ▼▼▼▼▼ **/
    #lesson {
        /**margin-top: 100px;
        display: flex;
        justify-content: center;**/
    }

    #lesson > ul {
        /**display: flex;
        list-style: none;**/
        flex-direction: column;
        justify-content: center;
        align-items: center;
        width: 100%;
    }

    #lesson > ul > li:nth-child(1) {
        width: 95%;
        margin: 5% 0 0 5%;
        /**background: #9bac87;**/
    }

    #lesson > ul > li:nth-child(1) img {
        position: relative;
        top: -5%;
        left: -5%;
        /**width: 100%;
        height: auto;**/
    }

    #lesson > ul > li:nth-child(2) {
        width: 95%;
    }

    #lesson > ul > li:nth-child(2) > h2 {
        margin-top: 30px;
    }

    /**#lesson > ul > li:nth-child(2) > p {
        margin-top: 30px;
    }**/

    /**#lesson > ul > li:nth-child(2) > ul {
        margin-top: 40px;
        padding-left: 20px;
    }**/

    /**#lesson > ul > li:nth-child(2) > ul > li {
        margin-bottom: 15px;
        list-style-type: disc;
        font-size: 1.11em;
        letter-spacing: 0.05em;
    }**/

    /**#lesson > ul > li:nth-child(2) > div.is {
        margin-top: 20px;
        padding: 30px;
        border-radius: 10px;
        background: #e1e6db;
        font-size: 0.83em;
        line-height: 200%;
        letter-spacing: 0.05em;
    }**/

    /**#lesson > ul > li:nth-child(2) > div.is > h3 {
        font-size: 1.2em;
        font-weight: 700;
        letter-spacing: 0.05em;
        margin-bottom: 20px;
    }**/

    /**#lesson > ul > li:nth-child(2) > div.is > span {
        display: block;
        margin-top: 20px;
        text-align: right;
    }**/

    /**#lesson > ul > li:nth-child(2) > div.is > span > a {
        text-decoration: underline;
        text-align: right;
    }**/

    #lesson > ul > li:nth-child(2) > div.btn {
        /**display: flex;
        justify-content: space-between;
        margin-top: 20px;**/
        /**flex-direction: column;**/
        align-items: center;
    }

    #lesson > ul > li:nth-child(2) > div.btn a:nth-child(1) {
        /**display: flex;
        justify-content: center;
        align-items: center;
        height: 50px;
        background: #9bac87;
        border-radius: 5px;
        font-size: 1.11em;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 100%;
        color: #FFFFFF;**/
        width: 75%;
    }

    #lesson > ul > li:nth-child(2) > div.btn a:nth-child(2) {
        width: 20%;
        height: auto;
        padding: 2%;
    }

    #lesson > ul > li:nth-child(2) > div.btn a:nth-child(2) > img {
        width: 100%;
        height: auto;
    }
    /** ▲▲▲▲▲ LESSON ▲▲▲▲▲ **/

    /** ▼▼▼▼▼ MAIN COACH ▼▼▼▼▼ **/
    #main_coach {
        /**display: flex;
        justify-content: center;**/
        /**margin-top: 100px;**/
    }

    #main_coach h2 {
        width: 90%;
        /**margin: 0 auto;
        text-align: center;**/
    }

    #main_coach > ul {
        /**display: flex;
        justify-content: space-between;
        margin: 60px auto 0 auto;**/
        width: 90%;
        flex-direction: column;
    }

    #main_coach > ul > li {
        width: 100%;
    }

    #main_coach > ul > li > span {
        /**display: block;
        background: #9bac87;**/
        width: 95%;
        height: auto;
    }

    #main_coach > ul > li:nth-child(1) > span {
        position: relative;
        top: 5%;
        left: 5%;
    }

    #main_coach > ul > li:nth-child(1) > span > img {
        position: relative;
        /**top: -5%;**/
        left: -5%;
    }

    #main_coach > ul > li:nth-child(2) {
        margin-top: 50px;
    }

    #main_coach > ul > li:nth-child(2) > span {
        position: relative;
        top: 0;
        left: 5%;
    }

    #main_coach > ul > li:nth-child(2) > span > img {
        position: relative;
        /**top: 5%;**/
        left: -5%;
    }

    /**#main_coach > ul > li > img {
        width: 450px;
    }**/

    /**#main_coach > ul > li > h3 {
        margin-top: 50px;
        text-align: center;
    }**/

    /**#main_coach > ul > li > p {
        margin-top: 30px;
    }**/
    /** ▲▲▲▲▲ MAIN COACH ▲▲▲▲▲ **/

    /** ▼▼▼▼▼ COACH ▼▼▼▼▼ **/
    /**#coach {
        margin-top: 100px;
    }**/

    #coach h2 {
        width: 90%;
        /**margin: 0 auto;
        text-align: center;**/
    }

    #coach > ul {
        /**display: flex;
        justify-content: space-between;
        align-items: center;
        width: 1000px;
        margin: 60px auto 0 auto;**/
        flex-direction: column;
        width: 90%;
    }

    #coach > ul > li:nth-child(1) {
        width: 100%;
    }

    #coach > ul > li:nth-child(2) {
        width: 100%;
        margin-top: 20px;
    }

    #coach > ul > li:nth-child(2) > h3 {
        margin-top: 30px;
        text-align: center;
    }

    #coach > ul > li:nth-child(2) > p {
        margin-top: 30px;
    }

    #coach > a {
        /**display: flex;
        justify-content: center;
        align-items: center;
        height: 80px;
        background: #9bac87;
        border-radius: 15px;
        font-weight: 700;
        letter-spacing: 0.05em;
        color: #FFFFFF;**/
        width: 90%;
        margin: 50px auto 0 auto;
        font-size: 1.15em;
        line-height: 150%;
        text-align: center;
    }
    /** ▲▲▲▲▲ COACH ▲▲▲▲▲ **/
}