@charset "UTF-8";

:root {
  --speech-main-color: #21c8ff;
  --speech-sub-color: #e0f7ff;
  --speech-arrow-icon: url(/zemi/challengeschool/online-speech/kaiin/assets/img/icon_arrow_orange.png);
  --speech-plus-icon: url(/zemi/challengeschool/online-speech/kaiin/assets/img/offer_icon_01.png);
  --speech-minus-icon: url(/zemi/challengeschool/online-speech/kaiin/assets/img/offer_icon_02.png);
  --speech-pc-bg: url(/zemi/challengeschool/online-speech/kaiin/assets/img/offer_main_bg_01_pc.png);
  --speech-sp-bg: url(/zemi/challengeschool/online-speech/kaiin/assets/img/offer_main_bg_01.png);
}

/*========================================
  01.index
========================================*/
/* ==================================
breadcrumb
================================== */

/* pc */
@media(min-width:769px){
  .breadcrumb{
    /* max-width: 960px; */
    width: 100%;
    margin: 0 auto;
    padding: 16px 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    color: #000;
    position: relative;
    z-index: 2;
    background-color: #fff;
  }
  .breadcrumb__list{
    margin-right: 30px;
    position: relative;
    font-size: 16px;
  }
  .breadcrumb__list:not(:last-of-type)::after{
    content: "";
    width: 8px;
    height: 8px;
    border-top: solid 1px #000;
    border-right: solid 1px #000;
    -webkit-transform: rotate(45deg) translateY(-50%);
        -ms-transform: rotate(45deg) translateY(-50%);
            transform: rotate(45deg) translateY(-50%);
    position: absolute;
    right: -15px;
    top: 50%;
    margin-top: -1px;
  }
  .breadcrumb__list-link{
    text-decoration: none;
    color: #000;
  }
  .breadcrumb__list-link:hover{
    opacity: 0.6;
  }
  .sp{
    display: none;
  }
}
/* sp */
@media(max-width:768px){
  .breadcrumb{
    width: 100%;
    margin: 0 auto;
    padding: 10px 3.75vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    position: relative;
    z-index: 3;
    background-color: #fff;
  }
  .breadcrumb__list{
    margin-right: 20px;
    position: relative;
    font-size: 14px;
  }
  .breadcrumb__list:not(:last-of-type)::after{
    content: "";
    width: 8px;
    height: 8px;
    border-top: solid 1px #000;
    border-right: solid 1px #000;
    -webkit-transform: rotate(45deg) translateY(-50%);
        -ms-transform: rotate(45deg) translateY(-50%);
            transform: rotate(45deg) translateY(-50%);
    position: absolute;
    right: -10px;
    top: 50%;
  }
  .breadcrumb__list-link{
    text-decoration: none;
    color: #000;
  }
  .pc{
    display: none;
  }
}

/*====================
  00.common
====================*/
.header__acc-box-item:nth-of-type(2) .header__acc-box-item-tag {
  color: #00B4FF !important;
}
.header__acc-box-item:nth-of-type(3) .header__acc-box-item-tag {
  color: #F5A618 !important;
}
.header__acc-box-item:nth-of-type(4) .header__acc-box-item-tag {
  color: #FC333A;
}
.header__acc-box-item:nth-of-type(5) .header__acc-box-item-tag {
  color: #E5465A;
}
.header__acc-box-item:nth-of-type(6) .header__acc-box-item-tag {
  color: #B016D0;
}
.header__acc-box-item:nth-of-type(7) .header__acc-box-item-tag {
  color: #E5465A;
}
.header__acc-box-item:nth-of-type(2)::after{  
  background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_blue.svg);
}
.header__acc-box-item:nth-of-type(3)::after{  
  background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_orange.svg);
}
.header__acc-box-item:nth-of-type(4)::after{  
  background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_soroban.svg);
}
.header__acc-box-item:nth-of-type(5)::after{  
  background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_shuuji.svg);
}
.header__acc-box-item:nth-of-type(6)::after{  
  background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_programming.svg);
}
.header__acc-box-item:nth-of-type(7)::after{  
  background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_shinrocoaching.svg);
}
.header__acc-box{
  overflow: scroll;
}

/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* 全体 */
  .top-wrap {
    overflow: hidden;
  }
  /* 非表示 */
  .dance-hidden-pc {
    display: none !important;
  }
  /* アコーディオン */
  .js-acc-text {
    cursor: pointer;
  }
  .js-acc-text:hover {
    opacity: 0.7;
  }
  /* cv */
  .cv__top {
    position: relative;
  }
  .cv__cover {
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.9);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 10;
    transform: translateX(-50%);
  }
  .cv__cover-text {
    font-size: 28px;
    font-weight: 500;
    text-align: center;
    color: #ffffff;
    line-height: 1.6;
    letter-spacing: 0.05em;
  }
  .cv__wrap {
    width: 720px;
    margin-right: auto;
    margin-left: auto;
  }
  .cv__balloon {
    font-size: 24px;
    font-weight: 600;
    color: #222222;
    text-align: center;
    line-height: 1.7;
    letter-spacing: 0.05em;
    position: relative;
  }
  .cv__balloon::before {
    content: "";
    background-image: url(/online-dance/assets/img/210506/cv_icon_01_pc.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 24px;
    height: 41px;
    position: absolute;
    top: 8px;
    left: -14px;
  }
  .cv__balloon::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/cv_icon_02_pc.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 23px;
    height: 41px;
    position: absolute;
    top: 8px;
    right: -6px;
  }
  .cv__balloon-strong {
    font-size: 30px;
  }
  .cv__text {
    font-size: 20px;
    font-weight: 600;
    color: #ea070d;
    text-align: center;
    line-height: 1.7;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
  }
  .cv__text-border {
    background: linear-gradient(transparent 60%, #fff773 60%);
  }
  .cv__text--blue{
    color: #004fa8;
  }
  .cv__btn {
    margin-bottom: 25px;
    margin-right: auto;
    margin-left: auto;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .cv__btn-link {
    display: block;
    border-radius: 6px;
    background-color: #ea070d;
    font-size: 0;
    text-align: center;
    line-height: 1.0;
    padding: 24px 68px;
    position: relative;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .cv__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 12px;
    height: 20px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
  }
  .cv__btn:hover .cv__btn-link {
    transform: translateY(4px);
  }
  .cv__btn--open {
    border-radius: 6px;
    box-shadow: 0px 4px 0px 0px #e2e2e2;
    width: 420px;
  }
  .cv__btn--open:hover {
    opacity: 0.7;
    box-shadow: 0px 0px 0px 0px #e2e2e2;
  }
  .cv__btn--close {
    width: 480px;
  }
  .cv__offer {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .cv__offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .cv__offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .cv__offer-link {
    color: #0083d3;
    text-decoration: underline;
  }
  .cv__offer-link:hover {
    opacity: 0.7;
    text-decoration: none;
  }
  .cv__offer-strong {
    color: #ea070d;
  }
  noscript + img {
    display: none;
  }
  .info-main__text-ttl{
    margin-top: 20px;
    font-weight: bold;
  }
  .info-main__text-num{
    padding-left: 35px;
    position: relative;
  }
  .info-main__text-num::after{
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    width: 30px;
    height: 30px;
    background-color: var(--speech-main-color);
    color: #ffffff;
    text-align: center;
    border-radius: 15px;
  }
  .info-main__text-num01::after{
    content: "1";
  }
  .info-main__text-num02::after{
    content: "2";
  }
  .info-main__text-num03::after{
    content: "3";
  }

}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* 非表示 */
  .dance-hidden-sp {
    display: none !important;
  }

  /* アコーディオン */
  .js-acc-text {
    cursor: pointer;
  }
  /* cv */
  .cv__top {
    position: relative;
  }
  .cv__cover {
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.9);
    width: 100%;
    height: 110%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
  }
  .cv__cover-text {
    font-size: 4vw;
    font-weight: 500;
    text-align: center;
    color: #ffffff;
    line-height: 1.6;
    letter-spacing: 0.05em;
  }
  .cv__balloon {
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #222222;
    text-align: center;
    line-height: 1.3;
    letter-spacing: 0.05em;
    margin-bottom: 1.33333333vw;
    position: relative;
  }
  .cv__balloon::before {
    content: "";
    background-image: url(/online-dance/assets/img/210506/cv_icon_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 5.33333333vw;
    height: 9.6vw;
    position: absolute;
    top: 1.6vw;
    left: 5.86666666vw;
  }
  .cv__balloon::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/cv_icon_02.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 5.33333333vw;
    height: 9.6vw;
    position: absolute;
    top: 1.6vw;
    right: 5.86666666vw;
  }
  .cv__balloon-strong {
    font-size: 5.33333333vw;
  }
  .cv__text {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #ea070d;
    text-align: center;
    line-height: 1.5;
    letter-spacing: 0.05em;
    margin-bottom: 2.66666666vw;
  }
  .cv__text-border {
    background: linear-gradient(transparent 60%, #fff773 60%);
  }
  .cv__text--blue{
    color: #004fa8;
  }
  .cv__btn {
    margin-bottom: 4vw;
    margin-right: 4vw;
    margin-left: 4vw;
  }
  .cv__btn-link {
    display: block;
    border-radius: 4px;
    background-color: #ea070d;
    font-size: 0;
    text-align: center;
    line-height: 1.0;
    padding-top: 4vw;
    padding-bottom: 4vw;
    position: relative;
  }
  .cv__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 2.13333333vw;
    height: 3.73333333vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2.66666666vw;
  }
  .cv__btn--open {
    border-radius: 4px;
    box-shadow: 0 0.53333333vw 0 0 #e2e2e2;
  }
  .cv__offer {
    text-align: center;
  }
  .cv__offer-item {
    display: inline-block;
    font-size: 2.66666666vw;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.05em;
    padding-left: 1.2em;
    position: relative;
  }
  .cv__offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .cv__offer-link {
    color: #0083d3;
    text-decoration: underline;
  }
  .cv__offer-strong {
    color: #ea070d;
  }
  noscript + img {
    display: none;
  }
  .info-main__text-ttl{
    font-weight: bold;
    margin: 4vw 0;
  }
  .info-main__text-num{
    padding-left: 7vw;
    position: relative;
  }
  .info-main__text-num::after{
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    width: 6vw;
    height: 6vw;
    background-color: var(--speech-main-color);
    color: #ffffff;
    text-align: center;
    border-radius: 3vw;
  }
  .info-main__text-num01::after{
    content: "1";
  }
  .info-main__text-num02::after{
    content: "2";
  }
  .info-main__text-num03::after{
    content: "3";
  }
  .info-main__calendar{
    margin-top: 6vw;
  }

}



/*====================
  01.kv
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* main */
  .kv__main {
    overflow: hidden;
    background-image: url(/online-dance/assets/img/210420/kv_bg_01_pc.jpg);
    background-position: center;
    background-repeat: no-repeat;
    height: 692px;
    position: relative;
  }
  .kv__main-wrap {
    width: 1000px;
    height: 692px;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
  .kv__main-heading {
    width: 481px;
    position: absolute;
    top: 235px;
    left: 20px;
  }
  .kv__main-text {
    width: 483px;
    position: absolute;
    top: 465px;
    left: 20px;
  }
  .kv__main-copy {
    width: 481px;
    position: absolute;
    top: 530px;
    left: 20px;
  }
  .kv__main-balloon {
    width: 244px;
    position: absolute;
    top: 140px;
    left: 20px;
  }
  .kv__main-badge {
    width: 414px;
    position: absolute;
    top: 140px;
    right: -25px;
  }
  /* cv */
  .kv__cv {
    background-color: #ffffff;
  }
  .kv__cv-wrap {
    padding-top: 30px;
    padding-bottom: 40px;
  }
  .kv__cv .cv__cover {
    width: 100vw;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* main */
  .kv__main {
    overflow: hidden;
    background-image: url(/online-dance/assets/img/210420/kv_bg_01.jpg);
    background-repeat: no-repeat;
    background-size: 100% auto;
    height: 80vw;
    position: relative;
  }
  .kv__main-wrap {
    padding-right: 4vw;
    padding-left: 4vw;
  }
  .kv__main-heading {
    padding-top: 25.33333333vw;
  }
  .kv__main-text {
    padding-top: 2.66666666vw;
  }
  .kv__main-copy {
    padding-top: 4vw;
  }
  .kv__main-balloon {
    width: 33.33333333vw;
    position: absolute;
    top: 3.2vw;
    left: 45.86666666vw;
    z-index: 2;
  }
  .kv__main-badge {
    width: 37.33333333vw;
    position: absolute;
    top: 8vw;
    right: 15.46666666vw;
  }
  
  .kv-small{
    width: 60%;
    margin: 10px 0 10px 0;
  }
  /* cv */
  .kv__cv {
    background-color: #ffffff;
  }
  .kv__cv-wrap {
    padding: 5.33333333vw 4vw;
  }
  .kv__cv .cv__cover {
    width: 100vw;
    margin-left: -4vw;
  }
}



/*====================
  02.about
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .about {
    background-color: #004ea2;
    background-image: url(/online-dance/assets/img/210420/about_bg_01_pc.jpg);
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
  }
  .about__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 60px;
    padding-bottom: 80px;
  }
  /* heading */
  .about__heading02 {
    width: 769px;
    margin-bottom: 40px;
    margin-right: auto;
    margin-left: auto;
  }
  /* main */
  .about__main-text {
    font-size: 18px;
    font-weight: 400;
    color: #ffffff;
    text-align: center;
    line-height: 2.0;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
  }
  .about__main-btn-list {
    display: flex;
    margin-bottom: 45px;
  }
  .about__main-btn {
    box-shadow: 0px 6px 0px 0px #001866;
    border-radius: 6px;
    width: 460px;
    line-height: 1.0;
    position: relative;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .about__main-btn + .about__main-btn {
    margin-left: 40px;
  }
  .about__main-btn-link {
    display: block;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .about__main-btn:hover {
    box-shadow: 0px 0px 0px 0px #001866;
  }
  .about__main-btn:hover .about__main-btn-link {
    opacity: 0.7;
    transform: translateY(6px);
  }
  .about__main-offer {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 40px;
  }
  .about__main-offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #ffffff;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .about__main-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .about {
    background-color: #004ea2;
    background-image: url(/online-dance/assets/img/210420/about_bg_01.jpg);
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: 100% auto;
  }
  .about__wrap {
    padding: 8vw 4vw;
  }
  /* heading */
  .about__heading02 {
    margin-bottom: 4vw;
  }
  /* main */
  .about__main-text {
    font-size: 3.2vw;
    font-weight: 400;
    color: #ffffff;
    line-height: 2.0;
    letter-spacing: 0.05em;
    margin-bottom: 2.66666666vw;
  }
  .about__main-btn-list {
    margin-bottom: 5.33333333vw;
  }
  .about__main-btn {
    box-shadow: 0px 3px 0px 0px #001866;
    border-radius: 6px;
  }
  .about__main-btn + .about__main-btn {
    margin-top: 4vw;
  }
  .about__main-offer {
    margin-bottom: 5.33333333vw;
  }
  .about__main-offer-item {
    font-size: 2.66666666vw;
    font-weight: 400;
    color: #ffffff;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .about__main-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
}



/*====================
  03.point
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .point {
    background-color: #ffffff;
  }
  .point__wrap {
    width: 1200px;
    padding-top: 80px;
    padding-bottom: 150px;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
  /* heading */
  .point__heading02 {
    width: 229px;
    margin-bottom: 80px;
    margin-right: auto;
    margin-left: auto;
  }
  /* main */
  .point__section {
    display: flex;
  }
  .point__section + .point__section {
    margin-top: 90px;
  }
  .point__section-thumb {
    position: relative;
  }
  .point__section-thumb::after {
    content: "";
    background-color: #ffffff;
    width: 640px;
    height: 640px;
    margin: auto;
    position: absolute;
    top: 50%;
    left: -50%;
    transform: rotate(-45deg) translate(0px, 0px);
    transform-origin: top left;
    z-index: 2;
  }
  .point__section-thumb-item {
    position: relative;
    z-index: 3;
  }
  .point__section-thumb-item--new{
    top: -10px;
    left: 5px;
  }
  .point__section-content {
    width: 540px;
    position: relative;
    z-index: 6;
  }
  .point__section-title {
    display: flex;
    align-items: center;
    margin-bottom: 65px;
  }
  .point__section-title-icon {
    display: block;
    width: 100px;
    margin-right: 24px;
  }
  .point__section-title-main {
    display: block;
  }
  .point__section-text {
    font-size: 18px;
    font-weight: 200;
    color: #000000;
    line-height: 1.7;
    margin-bottom: 30px;
  }
  .point__section-offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .point__section-offer-item + .point__section-offer-item {
    margin-top: 5px;
  }
  .point__section-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* 01 */
  .point__section--01 {
    padding-left: 120px;
    flex-direction: row-reverse;
  }
  .point__section--01 .point__section-title-main {
    width: 389px;
  }
  .point__section--01 .point__section-thumb {
    width: 480px;
    margin-left: 60px;
    position: relative;
    z-index: 1;
  }
  .point__section--01 .point__section-thumb::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/point_bg_01_pc.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 560px;
    height: 410px;
    position: absolute;
    top: -25px;
    left: -55px;
    z-index: 1;
  }
  .point__section--01 .point__section-thumb-item:nth-child(1) {
    width: 330px;
    margin: auto;
    position: absolute;
    top: -50px;
    right: 0;
    left: 0;
    z-index: 4;
  }
  .point__section--01 .point__section-thumb-item:nth-child(2) {
    width: 480px;
    z-index: 3;
  }
  /* 02 */
  .point__section--02 {
    padding-right: 120px;
  }
  .point__section--02 .point__section-title-main {
    width: 357px;
  }
  .point__section--02 .point__section-thumb {
    width: 420px;
    margin-right: 120px;
    position: relative;
    z-index: 1;
  }
  .point__section--02 .point__section-thumb::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/point_bg_02_pc.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 459px;
    height: 539px;
    position: absolute;
    top: 20px;
    left: -40px;
    z-index: 1;
  }
  .point__section--02 .point__section-thumb-item:nth-child(1) {
    width: 380px;
    margin-top: 70px;
  }
  .point__section--02 .point__section-thumb-item:nth-child(2) {
    width: 186px;
    position: absolute;
    top: 280px;
    right: -71px;
  }
  .point__section--02 .point__section-thumb-item:nth-child(3) {
    width: 224px;
    position: absolute;
    top: 200px;
    right: -90px;
  }
  .point__section--02 .point__section-thumb-item:nth-child(4) {
    width: 284px;
    position: absolute;
    bottom: -10px;
    left: 35px;
  }
  /* 03 */
  .point__section--03 {
    padding-left: 120px;
    flex-direction: row-reverse;
  }
  .point__section--03 .point__section-thumb {
    width: 480px;
    margin-left: 110px;
    position: relative;
  }
  .point__section--03 .point__section-thumb::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/point_bg_03_pc.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 576px;
    height: 254px;
    position: absolute;
    top: -50px;
    left: -60px;
    z-index: 1;
  }
  .point__section--03 .point__section-title-main {
    width: 419px;
  }
  .point__section--03 .point__section-thumb-item:nth-child(1) {
    width: 460px;
  }
  .point__section--03 .point__section-thumb-item:nth-child(2) {
    width: 140px;
    position: absolute;
    top: 20px;
    left: -65px;
    z-index: 4;
  }
  .point__section--03 .point__section-thumb-item:nth-child(3) {
    width: 100px;
    position: absolute;
    top: 154px;
    left: -90px;
    z-index: 5;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .point {
    overflow: hidden;
    background-color: #ffffff;
  }
  .point__wrap {
    padding: 10.66666666vw 4vw;
  }
  /* heading */
  .point__heading02 {
    margin-bottom: 13.33333333vw;
    position: relative;
    z-index: 6;
  }
  /* main */
  .point__section + .point__section {
    margin-top: 8vw;
  }
  .point__section-title {
    margin-bottom: 5.33333333vw;
    position: relative;
  }
  .point__section-title-icon {
    display: block;
    width: 17.06666666vw;
    position: absolute;
    top: -29.33333333vw;
    left: 0;
    z-index: 5;
  }
  .point__section-thumb {
    position: relative;
    margin-bottom: 8vw;
  }
  .point__section-thumb-item {
    position: relative;
    z-index: 3;
  }
  .point__section-thumb-item--new{
    left: 0;
    top: 8vw;
  }
  .point__section-content {
    position: relative;
    z-index: 6;
  }
  .point__section-text {
    font-size: 3.2vw;
    font-weight: 200;
    color: #000000;
    line-height: 1.7;
    letter-spacing: 0.1em;
    margin-bottom: 2.13333333vw;
  }
  .point__section-offer-item {
    font-size: 2.66666666vw;
    font-weight: 400;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .point__section-offer-item + .point__section-offer-item {
    margin-top: 0.8vw;
  }
  .point__section-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* 01 */
  .point__section--01 .point__section-thumb {
    position: relative;
  }
  .point__section--01 .point__section-thumb::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/point_bg_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 88vw;
    height: 44.8vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
  }
  .point__section-thumb::after {
    content: "";
    background-color: #ffffff;
    width: 100vw;
    height: 100vw;
    margin: auto;
    position: absolute;
    top: 26.66666666vw;
    left: -26.66666666vw;
    transform: rotate(-45deg) translate(0px, 0px);
    transform-origin: top left;
    z-index: 2;
  }
  .point__section--01 .point__section-thumb-item:nth-child(1) {
    width: 53.33333333vw;
    margin: auto;
    position: absolute;
    top: -7.46666666vw;
    right: 0;
    left: 0;
    z-index: 4;
  }
  .point__section--01 .point__section-thumb-item:nth-child(2) {
    width: 58.66666666vw;
    margin-right: auto;
    margin-left: auto;
  }
  /* 02 */
  .point__section--02 .point__section-thumb {
    position: relative;
    margin-bottom: 20vw;
  }
  .point__section--02 .point__section-thumb::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/point_bg_02.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 64vw;
    height: 51.8vw;
    margin: auto;
    position: absolute;
    top: -5.86666666vw;
    right: 5.33333333vw;
    left: 0;
  }
  .point__section--02 .point__section-thumb-item:nth-child(1) {
    width: 48vw;
    margin-left: 18.66666666vw;
  }
  .point__section--02 .point__section-thumb-item:nth-child(2) {
    width: 22.93333333vw;
    position: absolute;
    top: 26.66666666vw;
    right: 12vw;
    z-index: 4;
  }
  .point__section--02 .point__section-thumb-item:nth-child(3) {
    width: 28vw;
    position: absolute;
    top: 16vw;
    right: 10vw;
    z-index: 4;
  }
  .point__section--02 .point__section-thumb-item:nth-child(4) {
    width: 61.33333333vw;
    position: absolute;
    bottom: -13.33333333vw;
    left: 24vw;
  }
  /* 03 */
  .point__section--03 .point__section-thumb {
    position: relative;
  }
  .point__section--03 .point__section-thumb::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/point_bg_03.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 90vw;
    height: 34.13333333vw;
    margin: auto;
    position: absolute;
    top: -8vw;
    left: 0;
  }
  .point__section--03 .point__section-thumb-item:nth-child(1) {
    width: 76vw;
    margin-right: auto;
    margin-left: auto;
  }
  .point__section--03 .point__section-thumb-item:nth-child(2) {
    width: 25vw;
    position: absolute;
    top: 2vw;
    right: 0;
    z-index: 4;
  }
  .point__section--03 .point__section-thumb-item:nth-child(3) {
    width: 12.8vw;
    position: absolute;
    top: 26.4vw;
    right: 24vw;
    z-index: 5;
  }
  .point__section-title-icon--03{
    top: -39vw;
  }
}



/*====================
  04.schedule
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .schedule {
    background-color: #d7ecfa;
    position: relative;
    z-index: 1;
  }
  .schedule::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/schedule_bg_01_pc.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 970px;
    height: 288px;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
  }
  .schedule__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 80px;
    padding-bottom: 150px;
  }
  /* heading */
  .schedule__heading02 {
    width: 335px;
    margin-bottom: 80px;
    margin-right: auto;
    margin-left: auto;
  }
  /* main */
  .schedule__main {
    position: relative;
    z-index: 2;
  }
  .schedule__section-list {
    display: flex;
    background-color: #ffffff;
    padding: 30px;
  }
  .schedule__section {
    width: 420px;
    position: relative;
  }
  .schedule__section + .schedule__section {
    margin-left: 60px;
  }
  .schedule__section:nth-child(2)::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/schedule_dot_01_pc.png);
    background-repeat: repeat-y;
    background-size: 4px;
    width: 4px;
    height: 100%;
    position: absolute;
    top: 0;
    left: -32px;
  }
  .schedule__section-head {
    margin-bottom: 20px;
  }
  .schedule__section-column + .schedule__section-column {
    margin-top: 40px;
  }
  .schedule__section-column-title {
    font-size: 20px;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
    margin-bottom: 20px;
    padding-left: 38px;
    position: relative;
  }
  .schedule__section-column-title::before {
    content: "";
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 28px;
    height: 28px;
    position: absolute;
    top: 4px;
    left: 0;
  }
  .schedule__section-column--class .schedule__section-column-title::before{
    background-image: url(/online-dance/assets/img/211216/class_icon_pc.png);
  }
  .schedule__section-column--time .schedule__section-column-title::before {
    background-image: url(/online-dance/assets/img/210420/schedule_icon_01.png);
  }
  .schedule__section-column--cost .schedule__section-column-title::before {
    background-image: url(/online-dance/assets/img/210420/schedule_icon_02.png);
  }
  .schedule__section-column-thumb {
    margin-bottom: 20px;
    margin-right: auto;
    margin-left: auto;
  }
  .schedule__section-column-text {
    font-size: 18px;
    font-weight: 400;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
  }
  .schedule__section-column-acc-text {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    margin-bottom: 5px;
  }
  .schedule__section-column-offer {
    margin-bottom: 20px;
  }
  .schedule__section-column-offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .schedule__section-column-offer-item + .schedule__section-column-offer-item {
    margin-top: 5px;
  }
  .schedule__section-column-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .schedule__section-column-offer-text {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .schedule__section-column-offer-text + .schedule__section-column-offer-text {
    margin-top: 15px;
  }
  .schedule__section-column-dot {
    margin-bottom: 20px;
  }
  .schedule__section-column-dot-item {
    font-size: 18px;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
    padding-left: 1.0em;
    position: relative;
  }
  .schedule__section-column-dot-item::before {
    content: "";
    border-radius: 50%;
    background-color: #0083d3;
    width: 10px;
    height: 10px;
    position: absolute;
    top: 10px;
    left: 0;
  }
  /* cv */
  .schedule__section-column-cv {
    margin-top: 50px;
  }
  .schedule__section-column-cv .cv__cover {
    width: 960px;
  }
  .schedule__section-column-cv-thumb {
    width: 551px;
    margin-bottom: 15px;
    margin-right: auto;
    margin-left: auto;
  }
  .schedule__section-column-cv-btn {
    width: 420px;
    margin-right: auto;
    margin-left: auto;
  }
  .schedule__section-column-cv-btn-link {
    pointer-events: none;
    display: block;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .schedule__section-column-cv-btn-link:hover {
    opacity: 0.7;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .schedule {
    background-color: #d7ecfa;
    position: relative;
  }
  .schedule::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/schedule_bg_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 100%;
    height: 46.66666666vw;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
  }
  .schedule__wrap {
    padding: 10.66666666vw 4vw 4vw;
  }
  /* heading */
  .schedule__heading02 {
    margin-bottom: 8vw;
  }
  /* main */
  .schedule__section {
    background-color: #ffffff;
    padding: 2.66666666vw;
    position: relative;
  }
  .schedule__section:nth-child(1) {
    padding-bottom: 8vw;
  }
  .schedule__section:nth-child(2) {
    padding-top: 8vw;
  }
  .schedule__section:nth-child(2)::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/schedule_dot_01.png);
    background-repeat: repeat-x;
    background-size: 1.6vw;
    width: 95%;
    height: 0.8vw;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
  }
  .schedule__section-head {
    margin-bottom: 4vw;
  }
  .schedule__section-column + .schedule__section-column {
    margin-top: 8vw;
  }
  .schedule__section-column-title {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
    margin-bottom: 4vw;
    padding-left: 6.4vw;
    position: relative;
  }
  .schedule__section-column-title::before {
    content: "";
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 4.8vw;
    height: 4.8vw;
    position: absolute;
    top: 0.53333333vw;
    left: 0;
  }
  .schedule__section-column--class .schedule__section-column-title::before{
    background-image: url(/online-dance/assets/img/211216/class_icon_pc.png);
  }
  .schedule__section-column--time .schedule__section-column-title::before {
    background-image: url(/online-dance/assets/img/210420/schedule_icon_01.png);
  }
  .schedule__section-column--cost .schedule__section-column-title::before {
    background-image: url(/online-dance/assets/img/210420/schedule_icon_02.png);
  }
  .schedule__section-column-thumb {
    margin-bottom: 4vw;
  }
  .schedule__section-column-text {
    font-size: 3.2vw;
    font-weight: 400;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.1em;
    margin-bottom: 4vw;
  }
  .schedule__section-column-acc-text {
    font-size: 2.66666666vw;
    font-weight: 400;
    color: #808080;
    margin-bottom: 5px;
  }
  .schedule__section-column-offer {
    margin-bottom: 2.66666666vw;
  }
  .schedule__section-column-offer-item {
    font-size: 2.66666666vw;
    font-weight: 400;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .schedule__section-column-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .schedule__section-column-offer-text {
    font-size: 2.66666666vw;
    font-weight: 400;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .schedule__section-column-offer-text + .schedule__section-column-offer-text {
    margin-top: 4vw;
  }
  .schedule__section-column-dot {
    margin-bottom: 4vw;
  }
  .schedule__section-column-dot-item {
    font-size: 3.2vw;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
    padding-left: 0.8em;
    position: relative;
  }
  .schedule__section-column-dot-item::before {
    content: "";
    border-radius: 50%;
    background-color: #0083d3;
    width: 1.6vw;
    height: 1.6vw;
    position: absolute;
    top: 2.13333333vw;
    left: 0;
  }
  /* cv */
  .schedule__section-column-cv {
    margin-top: 8vw;
  }
  .schedule__section-column-cv .cv__cover {
    width: 100vw;
    margin-left: -6.66666666vw;
  }
  .schedule__section-column-cv-thumb {
    margin-bottom: 4vw;
  }
  .schedule__section-column-cv-btn {
    padding-right: 2.66666666vw;
    padding-left: 2.66666666vw;
  }
  .schedule__section-column-cv-btn-link {
    pointer-events: none;
    display: block;
  }
}



/*====================
  05.flow
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .flow {
    background-color: #ffffff;
  }
  .flow__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 80px;
    padding-bottom: 150px;
  }
  /* heading */
  .flow__heading02 {
    width: 388px;
    margin-bottom: 80px;
    margin-right: auto;
    margin-left: auto;
  }
  .flow__section-list {
    display: flex;
  }
  .flow__section {
    width: 300px;
  }
  .flow__section + .flow__section {
    margin-left: 30px;
  }
  .flow__section:nth-child(1) .flow__section-title {
    width: 265px;
  }
  .flow__section:nth-child(2) .flow__section-title {
    width: 295px;
  }
  .flow__section:nth-child(3) .flow__section-title {
    width: 236px;
  }
  .flow__section-title {
    margin-bottom: 30px;
    position: relative;
    z-index: 2;
  }
  .flow__section:nth-child(2) .flow__section-title::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/flow_dot_01_pc.png);
    background-repeat: repeat-x;
    width: 45px;
    height: 4px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: -50px;
    z-index: 1;
  }
  .flow__section:nth-child(3) .flow__section-title::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/flow_dot_01_pc.png);
    background-repeat: repeat-x;
    width: 20px;
    height: 4px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: -25px;
    z-index: 1;
  }
  .flow__section-thumb {
    background-color: #f3f3f3;
    background-image: url(/online-dance/assets/img/210420/flow_thumb_bg_01.png);
    background-position: center;
    background-size: 100% auto;
    width: 230px;
    height: 230px;
    margin-bottom: 30px;
    margin-right: auto;
    margin-left: auto;
    position: relative;
  }
  .flow__section-thumb img {
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
  }
  .flow__section-text {
    font-size: 18px;
    font-weight: 200;
    color: #222222;
    line-height: 1.7;
    letter-spacing: 0.1em;
    word-break: break-all;
  }
  .flow__section-text + .flow__section-text {
    margin-top: 20px;
  }
  .flow__section-offer {
    margin-top: 20px;
  }
  .flow__section-offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    word-break: break-all;
    padding-left: 1.2em;
    position: relative;
  }
  .flow__section-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* cv */
  .flow__cv {
    margin-top: 50px;
  }
  .flow__cv .cv__cover {
    width: 960px;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .flow {
    background-color: #ffffff;
  }
  .flow__wrap {
    padding: 10.66666666vw 4vw;
  }
  /* heading */
  .flow__heading02 {
    margin-bottom: 8vw;
  }
  /* main */
  .flow__section-list {
    position: relative;
  }
  .flow__section-list::before {
    content: "";
    background-image: url(/online-dance/assets/img/210420/flow_dot_01.png);
    background-repeat: repeat-y;
    background-size: 100% auto;
    width: 0.8vw;
    height: 70%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
  }
  .flow__section + .flow__section {
    margin-top: 10.66666666vw;
  }
  .flow__section-title {
    margin-bottom: 2.66666666vw;
    position: relative;
    z-index: 2;
  }
  .flow__section-thumb {
    background-color: #f3f3f3;
    background-image: url(/online-dance/assets/img/210420/flow_thumb_bg_01.png);
    background-position: center;
    background-size: 100% auto;
    width: 61.33333333vw;
    height: 61.33333333vw;
    margin-bottom: 5.33333333vw;
    margin-right: auto;
    margin-left: auto;
    position: relative;
  }
  .flow__section-thumb img {
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
  }
  .flow__section-text {
    font-size: 3.2vw;
    font-weight: 200;
    color: #222222;
    line-height: 1.7;
    padding-right: 4vw;
    padding-left: 4vw;
  }
  .flow__section-text + .flow__section-text {
    margin-top: 20px;
  }
  .flow__section-offer {
    margin-top: 20px;
    padding-right: 4vw;
    padding-left: 4vw;
  }
  .flow__section-offer-item {
    font-size: 2.66666666vw;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    word-break: break-all;
    padding-left: 1.2em;
    position: relative;
  }
  .flow__section-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* cv */
  .flow__cv {
    margin-top: 8vw;
  }
  .flow__cv .cv__cover {
    width: 100vw;
    margin-left: -4vw;
  }
}

/*====================
  06.faq
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .faq {
    background-color: #f1f1f1;
  }
  .faq__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 80px;
    padding-bottom: 100px;
  }
  /* link */
  .faq__link-box {
    border: solid 4px #004ea2;
    background-color: #ffffff;
    padding: 30px 40px;
    margin-bottom: 40px;
  }
  .faq__link-wrap {
    text-align: center;
    color: #004fa8;
    font-weight: bold;
    font-size: 24px;
  }
  .faq__link {
    color: #004fa8;
  }
  .faq__link:hover {
    text-decoration: none;
  }
  /* heading */
  .faq__heading02 {
    width: 154px;
    margin-bottom: 40px;
    margin-right: auto;
    margin-left: auto;
  }
  /* main */
  .faq__section {
    box-shadow: 0px 2px 0px 0px #d9d9d9;
    background-color: #ffffff;
    padding: 40px;
    position: relative;
  }
  .faq__section:hover {
    opacity: 0.7;
  }
  .faq__section::after {
    content: "";
    background-image: var( --speech-arrow-icon);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 10px;
    height: 16px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 25px;
  }
  .faq__section + .faq__section {
    margin-top: 30px;
  }
  .faq__section-title {
    font-size: 24px;
    font-weight: 600;
    color: var(--speech-main-color);
    line-height: 1.7;
    padding-left: 1.2em;
    position: relative;
  }
  .faq__section-title::before {
    content: "Q.";
    position: absolute;
    top: 0;
    left: 0;
  }
  .faq__section-text {
    font-size: 18px;
    font-weight: 600;
    color: #000000;
    line-height: 1.7;
    padding-left: 1.2em;
    position: relative;
  }
  .faq__section-text::before {
    content: "A.";
    position: absolute;
    top: 0;
    left: 0;
  }
  .faq__section-box {
    background-color: #e7f5fe;
    margin-top: 20px;
    padding: 25px;
  }
  .faq__section-box-title {
    font-size: 18px;
    font-weight: 600;
    color: #000000;
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .faq__section-box-text {
    font-size: 18px;
    font-weight: 200;
    color: #000000;
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .faq__section-box-tel {
    font-size: 24px;
    font-weight: 600;
    color: #004ea2;
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .faq__section-box-tel-small {
    font-size: 14px;
  }
  .faq__section-box-offer {
    margin-top: 5px;
  }
  .faq__section-box-offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .faq__section-box-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* bottom */
  .faq__bottom {
    margin-top: 30px;
  }
  .faq__bottom-acc {
    margin-bottom: 15px;
  }
  .faq__bottom-acc-text {
    display: inline-block;
    font-size: 16px;
    font-weight: 200;
    color: #808080;
    line-height: 1.5;
  }
  .faq__bottom-acc-body {
    padding: 10px 0 20px;
  }
  .faq__bottom-contact {
    border: solid 4px var(--speech-main-color);
    background-color: #ffffff;
    padding: 30px 40px;
  }
  .faq__bottom-contact-title {
    font-size: 18px;
    font-weight: 600;
    color: #000000;
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .faq__bottom-contact-tel {
    font-size: 32px;
    font-weight: 600;
    color: var(--speech-main-color);
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .faq__bottom-contact-tel-link {
    color: var(--speech-main-color);
    text-decoration: none;
    pointer-events: none;
  }
  .faq__bottom-contact-tel-small {
    font-size: 14px;
  }
  .faq__bottom-contact-offer {
    margin-top: 10px
  }
  .faq__bottom-contact-offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .faq__bottom-contact-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .faq__bottom-text {
    font-size: 18px;
    font-weight: 400;
    color: #000000;
    line-height: 1.5;
    margin-top: 20px;
  }
  .faq__bottom-text-link {
    color: var(--speech-main-color);
    text-decoration: underline;
  }
  .faq__bottom-text-link:hover {
    text-decoration: none;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .faq {
    background-color: #f1f1f1;
  }
  .faq__wrap {
    padding: 10.66666666vw 4vw 13.33333333vw;
  }
  /* link */
  .faq__link-box {
    border: solid 2px #004ea2;
    background-color: #ffffff;
    padding: 4vw;
    margin-bottom: 8vw;
  }
  .faq__link-wrap {
    text-align: center;
    color: #004fa8;
    font-weight: bold;
  }
  .faq__link {
    color: #004fa8;
  }
  /* heading */
  .faq__heading02 {
    margin-bottom: 8vw;
  }
  /* main */
  .faq__section {
    box-shadow: 0px 2px 0px 0px #d9d9d9;
    background-color: #ffffff;
    padding: 5.33333333vw 4vw;
    position: relative;
  }
  .faq__section:hover {
    opacity: 0.7;
  }
  .faq__section::after {
    content: "";
    background-image: var( --speech-arrow-icon);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 10px;
    height: 16px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 25px;
  }
  .faq__section + .faq__section {
    margin-top: 5.33333333vw;
  }
  .faq__section-title {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: var(--speech-main-color);
    line-height: 1.7;
    padding-left: 1.2em;
    padding-right: 25px;
    position: relative;
  }
  .faq__section-title::before {
    content: "Q.";
    position: absolute;
    top: 0;
    left: 0;
  }
  .faq__section-text {
    font-size: 3.2vw;
    font-weight: 600;
    color: #000000;
    line-height: 1.7;
    padding-left: 1.2em;
    position: relative;
  }
  .faq__section-text::before {
    content: "A.";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* bottom */
  .faq__bottom {
    margin-top: 4vw;
  }
  .faq__bottom-acc {
    margin-bottom: 2.66666666vw;
  }
  .faq__bottom-acc-text {
    display: inline-block;
    font-size: 3.2vw;
    font-weight: 400;
    color: #808080;
    line-height: 1.5;
  }
  .faq__bottom-acc-body {
    padding: 2.66666666vw 0 4vw;
  }
  .faq__bottom-contact {
    border: solid 2px var(--speech-main-color);
    background-color: #ffffff;
    padding: 4vw;
  }
  .faq__bottom-contact-title {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #000000;
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .faq__bottom-contact-tel {
    font-size: 4.26666666vw;
    font-weight: 600;
    color: var(--speech-main-color);
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .faq__bottom-contact-tel-link {
    color: var(--speech-main-color);
    text-decoration: none;
  }
  .faq__bottom-contact-tel-small {
    font-size: 3.2vw;
  }
  .faq__bottom-contact-offer {
    margin-top: 2.66666666vw;
  }
  .faq__bottom-contact-offer-item {
    font-size: 2.66666666vw;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .faq__bottom-contact-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .faq__bottom-text {
    font-size: 3.2vw;
    font-weight: 400;
    color: #000000;
    line-height: 1.5;
    margin-top: 20px;
  }
  .faq__bottom-text-link {
    color: var(--speech-main-color);
    text-decoration: underline;
  }
}



/*====================
  07.lead
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .lead {
    background-color: #d7ecfa;
    padding-top: 2.66666666vw;
    padding-bottom: 2.66666666vw;
  }
  /* btn */
  .lead__btn-link {
    display: block;
    box-sizing: border-box;
    box-shadow: 0px 2px 0px 0px #becfda;
    border-radius: 3px;
    background-color: #004ea2;
    text-align: center;
    line-height: 1.0;
    width: 80vw;
    margin-right: auto;
    margin-left: auto;
    padding: 2.4vw 6.4vw 2.4vw 4vw;
    position: relative;
  }
  .lead__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 1.6vw;
    height: 2.66666666vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2.66666666vw;
  }
}



/*====================
  08.program
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .program {
    background-color: #f1f1f1;
  }
  .program__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 80px;
    padding-bottom: 80px;
  }
  /* heading */
  .program__heading02 {
    width: 319px;
    margin-bottom: 40px;
    margin-right: auto;
    margin-left: auto;
  }
  /* main */
  .program__section {
    position: relative;
  }
  .program__section:not(:last-child)::before {
    content: "";
    background-image: url(/online-dance/assets/img/210506/program_icon_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 107px;
    height: 53px;
    margin: auto;
    position: absolute;
    bottom: -82px;
    right: 0;
    left: 0;
  }
  .program__section + .program__section {
    margin-top: 110px;
  }
  .program__section-title {
    background-color: #004ea2;
    font-size: 28px;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.0;
    letter-spacing: 0.2em;
    padding: 20px;
  }
  .program__section-body {
    background-color: #ffffff;
    padding: 30px;
  }
  .program__section-lead {
    font-size: 20px;
    font-weight: 600;
    color: #000000;
    text-align: center;
    line-height: 1.7;
    margin-bottom: 25px;
  }
  .program__section-thumb {
    margin-bottom: 30px;
    position: relative;
  }
  .program__section-thumb-badge {
    position: absolute;
    top: 0;
  }
  .program__section-text {
    font-size: 16px;
    font-weight: 400;
    color: #000000;
    line-height: 1.7;
  }
  /* 01 */
  .program__section--01 .program__section-thumb-badge {
    width: 139px;
    top: -20px;
    left: 280px;
  }
  /* 02 */
  .program__section--02 .program__section-thumb {
    width: 540px;
    margin-right: auto;
    margin-left: auto;
  }
  .program__section--02 .program__section-thumb-badge {
    width: 139px;
    top: -20px;
    right: 20px;
  }
  /* 03 */
  .program__section--03 .program__section-thumb {
    width: 540px;
    margin-right: auto;
    margin-left: auto;
  }
  .program__section--03 .program__section-thumb-badge {
    width: 139px;
    top: -20px;
    right: 20px;
  }
  /* 04 */
  .program__section--04 .program__section-thumb {
    width: 540px;
    margin-right: auto;
    margin-left: auto;
  }
  .program__section--04 .program__section-thumb-badge {
    width: 139px;
    top: -20px;
    right: 20px;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .program {
    background-color: #f1f1f1;
  }
  .program__wrap {
    padding: 10.66666666vw 4vw 4vw;
  }
  /* heading */
  .program__heading02 {
    margin-bottom: 5.33333333vw;
  }
  /* main */
  .program__section {
    position: relative;
  }
  .program__section:not(:last-child):before {
    content: "";
    background-image: url(/online-dance/assets/img/210506/program_icon_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 16vw;
    height: 8vw;
    margin: auto;
    position: absolute;
    bottom: -12vw;
    right: 0;
    left: 0;
  }
  .program__section + .program__section {
    margin-top: 16vw;
  }
  .program__section-title {
    background-color: #004ea2;
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.0;
    letter-spacing: 0.2em;
    padding: 2.66666666vw;
  }
  .program__section-body {
    background-color: #ffffff;
    padding: 4vw 2.66666666vw;
  }
  .program__section-lead {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #000000;
    line-height: 1.7;
    margin-bottom: 4vw;
  }
  .program__section-thumb {
    margin-bottom: 4vw;
    position: relative;
  }
  .program__section-thumb-badge {
    width: 24vw;
    position: absolute;
    top: -2.66666666vw;
    right: 2.66666666vw;
  }
  .program__section-text {
    font-size: 3.73333333vw;
    font-weight: 400;
    color: #000000;
    line-height: 1.7;
  }
}



/*====================
  09.contact
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .contact {
    background-color: var(--speech-sub-color);
  }
  .contact__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 40px;
    padding-bottom: 40px;
  }
  /* main */
  .contact__main-list {
    display: flex;
  }
  .contact__main-list-item {
    width: 50%;
  }
  .contact__main-list-title {
    font-size: 14px;
    font-weight: 600;
    color: #000000;
    line-height: 1.5;
    letter-spacing: 0.1em;
  }
  .contact__main-list-text {
    font-size: 14px;
    font-weight: 400;
    color: #000000;
    line-height: 1.5;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
/* base */
  .contact {
    background-color: var(--speech-sub-color);
  }
  .contact__wrap {
    padding: 4vw;
  }
  /* main */
  .contact__main-list-item + .contact__main-list-item {
    margin-top: 2.66666666vw;
  }
  .contact__main-list-title {
    font-size: 3.2vw;
    font-weight: 600;
    color: #000000;
    line-height: 1.5;
    letter-spacing: 0.1em;
  }
  .contact__main-list-text {
    font-size: 3.2vw;
    font-weight: 400;
    color: #000000;
    line-height: 1.5;
  }
}



/*====================
  10.pagetop
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .pagetop {
    background-color: #ffffff;
  }
  .pagetop {
    background-color: #ffffff;
  }
  .pagetop__wrap {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .pagetop__btn {
    display: block;
    box-sizing: border-box;
    border-radius: 30px;
    border: solid 2px var(--speech-main-color);
    background-color: #ffffff;
    font-size: 18px;
    font-weight: 600;
    color: var(--speech-main-color);
    text-align: center;
    text-decoration: none;
    line-height: 1.0;
    letter-spacing: 0.1em;
    width: 240px;
    margin-right: auto;
    margin-left: auto;
    padding: 18px 16px 18px 28px;
    position: relative;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .pagetop__btn::after {
    content: "";
    background-image: var( --speech-arrow-icon);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 10px;
    height: 16px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 25px;
    transform: rotate(-90deg);
  }
  .pagetop__btn:hover {
    opacity: 0.7;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .pagetop {
    background-color: #ffffff;
  }
  .pagetop__wrap {
    padding: 4vw 20vw;
  }
  .pagetop__btn {
    display: block;
    border-radius: 30px;
    border: solid 2px var(--speech-main-color);
    background-color: #ffffff;
    font-size: 4.73333333vw;
    font-weight: 600;
    color: var(--speech-main-color);
    text-align: center;
    text-decoration: none;
    line-height: 1.0;
    padding: 3.73333333vw 3.73333333vw 3.73333333vw 4vw;
    position: relative;
  }
  .pagetop__btn::after {
    content: "";
    background-image: var( --speech-arrow-icon);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 2.13333333vw;
    height: 3.73333333vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 6vw;
    transform: rotate(-90deg);
  }
}



/*====================
  11.modal
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .modal {
    display: none;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
  }
  .modal__bg {
    background-color: rgba(183, 183, 183, 0.9);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  .modal__wrap {
    max-width: 660px;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .modal__close {
    width: 50px;
    margin-bottom: 20px;
    cursor: pointer;
    position: absolute;
    top: -55px;
    right: 0;
  }
  .modal__close-icon {
    font-size: 0px;
    width: 30px;
    margin-bottom: 5px;
    margin-right: auto;
    margin-left: auto;
  }
  .modal__close-text {
    font-size: 12px;
    font-weight: 400;
    color: #ffffff;
    text-align: center;
  }
  .modal__content {
    border-radius: 5px;
    background-color: #ffffff;
    width: 100%;
    max-height: 100%;
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .modal__title {
    font-size: 24px;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 30px;
  }
  .modal__btn {
    display: flex;
    flex-wrap: wrap;
    width: 660px;
    margin-right: auto;
    margin-left: auto;
  }
  .modal__btn-item {
    border-radius: 6px;
    box-shadow: 0px 4px 0px 0px #e2e2e2;
    width: 320px;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .modal__btn-item:nth-child(2n) {
    margin-left: 20px;
  }
  .modal__btn-item:nth-child(n+3) {
    margin-top: 24px;
  }
  .modal__btn-link {
    display: block;
    border-radius: 6px;
    background-color: #004ea2;
    font-size: 19px;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.0;
    letter-spacing: 0.1em;
    text-decoration: none;
    padding: 24px;
    position: relative;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .modal__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 12px;
    height: 20px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 20px;
  }
  .modal__btn-item-strong {
    font-size: 24px;
  }
  .modal__btn-item:hover {
    box-shadow: 0px 0px 0px 0px #e2e2e2;
  }
  .modal__btn-item:hover .modal__btn-link {
    opacity: 0.7;
    transform: translateY(4px);
  }
  .modal__btn--youji{
    width: 300px;
  padding: 10px 30px;
  margin: 10px auto;
  border-radius: 3px;
  color: #fff;
  font-weight: bold;
  border: 1px solid #0083d3;
  background-color: #0083d3;

  }
  .modal__btn--sho{
    width: 300px;
  padding: 10px 30px;
  margin: 10px auto;
  border-radius: 3px;
  color: #fff;
  font-weight: bold;
  border: 1px solid #00d435;
  background-color: #00d435;
  }
  .modal__content--list{
    margin: 10px auto;
    max-width: 350px;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .modal {
    display: none;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding: 8vw;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
  }
  .modal__bg {
    background-color: rgba(183, 183, 183, 0.9);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  .modal__wrap {
    width: 90%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .modal__close {
    width: 13.33333333vw;
    cursor: pointer;
    position: absolute;
    top: -12vw;
    right: 0;
  }
  .modal__close-icon {
    font-size: 0;
    width: 6.4vw;
    margin-bottom: 2vw;
    margin-right: auto;
    margin-left: auto;
  }
  .modal__close-text {
    font-size: 3.2vw;
    font-weight: 400;
    color: #ffffff;
    text-align: center;
    line-height: 1.0;
  }
  .modal__content {
    overflow: auto;
    border-radius: 1.33333333vw;
    background-color: #ffffff;
    width: 100%;
    max-height: 100%;
    padding-top: 5.33333333vw;
    padding-bottom: 5.33333333vw;
  }
  .modal__title {
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 5.33333333vw;
  }
  .modal__btn {
    display: flex;
    flex-wrap: wrap;
    padding-right: 4vw;
    padding-left: 4vw;
  }
  .modal__btn-item {
    border-radius: 4px;
    box-shadow: 0 0.53333333vw 0 0 #e2e2e2;
    width: 100%;
  }
  .modal__btn-item + .modal__btn-item {
    margin-top: 3.2vw;
  }
  .modal__btn-link {
    display: block;
    border-radius: 4px;
    background-color: #004ea2;
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.0;
    letter-spacing: 0.1em;
    text-decoration: none;
    padding: 4vw;
    position: relative;
  }
  .modal__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 1.86666666vw;
    height: 3.2vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2.66666666vw;
  }
  .modal__btn-item-strong {
    font-size: 4.53333333vw;
  }
  .modal__btn--youji{
  padding: 10px 30px;
  margin: 10px 20px;
  border-radius: 3px;
  color: #fff;
  font-weight: bold;
  border: 1px solid #0083d3;
  background-color: #0083d3;

  }
  .modal__btn--sho{
  padding: 10px 30px;
  margin: 10px 20px;
  border-radius: 3px;
  color: #fff;
  font-weight: bold;
  border: 1px solid #00d435;
  background-color: #00d435;
  }
  .modal__content--list{
    margin: 10px 30px;
  }
  .offer-main__dot-list .modal__content--list-item{
    font-size: 3.8vw;
  }
}





/*========================================
  02.offer
========================================*/
/*====================
  00.header
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .header {
    background-color: #ffffff;
    -webkit-box-shadow: 0 0 10px 0 rgba(0,0,0,0.3);
            box-shadow: 0 0 10px 0 rgba(0,0,0,0.3);
    width: 100%;
    z-index: 3;
    position: fixed;
    top: 0;
  }
  .header.menu-open{
    z-index: 15;
  }
  .header-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
    padding: 10px 20px;
    box-sizing: border-box;
  }
  .header-logo-link {
    display: block;
    width: 130px;
  }
  .header-logo-img {
    width: 110px;
  }
  .header-logo-link + .header-logo-link .header-logo-img {
    width: 246px;
    margin-top: 5px;
  }
  .header__acc {
    display: flex;
  }
  .header__acc-btn{
    margin-right: 10px;
  }
  .header__acc-btn-link{
    background-color: #5A5A5A;
    font-weight: 900;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 174px;
    font-size: 17px;
    cursor: pointer;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 12px;
    padding: 12px 0;
    color: #fff;
    text-decoration: none;
  }
  .header__acc-btn-link::after{
    content: "";
    background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_bottom.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: 13px;
    height: 8px;
    margin-left: 5px;
  }
  .header__acc-btn-link:hover {
    opacity: 0.7;
  }
  .header__acc-btn-link--blue{
    width: 100px;
    background-color: #003CAA;
  }
  .header__acc-btn-link--blue::after{
    content: none;
  }
  .header__acc-btn-link{
    padding: 18px 0;
  }
  .header__acc-box{
    position: fixed;
    width: 100vw;
    height: calc(100vh - 69px);
    background-color: #fff;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    left: 50%;
    top: 0;
    margin-top: 90px;
    background-color: #fafbfb;
    opacity: 0;
  }
  .header__acc-box-item{
    display: block;
    width: 525px;
    margin: 0 auto;
    text-decoration: none;
    position: relative;
    border-bottom: 1.4px solid #d6e0e1;
    padding: 25px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .header__acc-box-item::after{
    content: "";
    background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_blue.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: 30px;
    height: 30px;
    position: absolute;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    right: 25px;
    top: 50%;
  }
  .header__acc-box-item-tag{
    font-size: 16px;
    color: #00B4FF;
    display: block;
  }
  .header__acc-box-item-txt{
    font-size: 26px;
    color: #333333;
    font-weight: 900;
    display: block;
  }

  .header__acc-box-item:nth-of-type(2) .header__acc-box-item-tag{
    color: #F5A618;
  }
  .header__acc-box-item:nth-of-type(2)::after{
    background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_orange.svg);
  }

  .header__acc-box .header__acc-box-item--top .header__acc-box-item-tag{
    color: #333333;
  }
  .header__acc-box .header__acc-box-item--top::after{
    background-image: url(/zemi/challengeschool/_shared/img/icon_arrow_black.svg);
  }
  .header__acc-box .header__acc-box-item--dance .header__acc-box-item-tag{
    color: #00B4FF;
  }
  .header__acc-box .header__acc-box-item--dance::after{
    background-image: url(/zemi/challengeschool/_shared/img/icon_arrow_blue.svg);
  }
  .header__acc-box .header__acc-box-item--art .header__acc-box-item-tag{
    color: #F5A618;
  }
  .header__acc-box .header__acc-box-item--art::after{
    background-image: url(/zemi/challengeschool/_shared/img/icon_arrow_orange.svg);
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .header {
    background-color: #ffffff;
    -webkit-box-shadow: 0 -2px 10px 0 rgba(0,0,0,0.3);
            box-shadow: 0 -2px 10px 0 rgba(0,0,0,0.3);
    z-index: 4;
    position: fixed;
    top: 0;
    width: 100%;
  }
  .header.menu-open{
    z-index: 15;
  }
  .header-inner {
    width: 100%;
    padding: 10px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .header-logo-link {
    display: block;
    width: 30vw;
  }
  .header-logo-img {
    width: 20vw;
  }
  .header-logo-link + .header-logo-link .header-logo-img {
    width: 38vw;
    margin-top: 0.4vw;
  }
  .header__acc {
    display: flex;
  }
  .header__acc-btn{
    margin-right: 0.8vw;
  }
  .header__acc-btn-link{
    background-color: #5A5A5A;
    font-weight: 900;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 120px;
    font-size: 12px;
    cursor: pointer;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 8px;
    padding: 12px 0;
    color: #fff;
    text-decoration: none;
  }
  .header__acc-btn-link::after{
    content: "";
    background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_bottom.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: 7px;
    height: 5px;
    margin-left: 5px;
  }
  .header__acc-btn-link:hover {
    opacity: 0.7;
  }
  .header__acc-btn-link--blue{
    width: 62px;
    background-color: #003CAA;
  }
  .header__acc-btn-link--blue::after{
    content: none;
  }
  .header__acc-btn-link{
    width: auto;
    height: 100%;
    font-size: 3.2vw;
    padding: 2.5vw 1.3vw;
    text-align: center;
  }
  .header__acc-box{
    position: fixed;
    width: 100vw;
    height: calc(100vh - 62px);
    background-color: #fff;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    left: 50%;
    top: 0;
    margin-top: 78px;
    background-color: #fafbfb;
  }
  .header__acc-box-item{
    display: block;
    margin: 0 auto;
    text-decoration: none;
    position: relative;
    border-bottom: 1px solid #d6e0e1;
    padding: 15px 18px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .header__acc-box-item::after{
    content: "";
    background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_blue.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: 17px;
    height: 17px;
    position: absolute;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    right: 18px;
    top: 50%;
  }
  .header__acc-box-item-tag{
    font-size: 12px;
    color: #00B4FF;
    width: 100%;
    display: block;
  }
  .header__acc-box-item-txt{
    font-size: 18px;
    color: #333333;
    width: 100%;
    font-weight: 900;
    display: block;
  }

  .header__acc-box-item:nth-of-type(2) .header__acc-box-item-tag{
    color: #F5A618;
  }
  .header__acc-box-item:nth-of-type(2)::after{
    background-image: url(/zemi/challengeschool/_assets/img/icon_arrow_orange.svg);
  }

  .header__acc-box .header__acc-box-item--top .header__acc-box-item-tag{
    color: #333333;
  }
  .header__acc-box .header__acc-box-item--top::after{
    background-image: url(/zemi/challengeschool/_shared/img/icon_arrow_black.svg);
  }
  .header__acc-box .header__acc-box-item--dance .header__acc-box-item-tag{
    color: #00B4FF;
  }
  .header__acc-box .header__acc-box-item--dance::after{
    background-image: url(/zemi/challengeschool/_shared/img/icon_arrow_blue.svg);
  }
  .header__acc-box .header__acc-box-item--art .header__acc-box-item-tag{
    color: #F5A618;
  }
  .header__acc-box .header__acc-box-item--art::after{
    background-image: url(/zemi/challengeschool/_shared/img/icon_arrow_orange.svg);
  }
}
.header__acc-box{
  opacity: 0;
  -webkit-transition: opacity .6s ease, visibility .6s ease;
  -o-transition: opacity .6s ease, visibility .6s ease;
  transition: opacity .6s ease, visibility .6s ease;
  z-index: -1;
  visibility: hidden;
}
.header__acc-box.is-open{
  visibility: visible;
  opacity: 1;
  z-index: 15;
}
/*
==================================
header--fixed
==================================
*/
/* pc */
@media(min-width:769px){
  .header--fixed{
    display: none;
  }
  .header--fixed.fixed{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
  }
  .header-logo-img--v2{
    width: 246px;
    height: 39px;
  }
}
/* sp */
@media(max-width:768px){
  .header--fixed{
    display: none;
  }
  .header--fixed.fixed{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
  }

  .header-logo-img--v2{
    width: 100%;
  }
}


/*====================
  01.head
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .offer-head {
    background-color: #004ea2;
    background-image: url(/online-dance/assets/img/210506/offer_head_bg_01_pc.jpg);
    background-position: bottom right;
    background-repeat: no-repeat;
    background-size: cover;
  }
  .offer-head__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 50px;
    padding-bottom: 60px;
  }
  .offer-head__title {
    font-size: 30px;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.3;
    margin-bottom: 30px;
  }
  .offer-head__title-strong {
    font-size: 40px;
  }
  .offer-head__text {
    font-size: 18px;
    font-weight: 200;
    color: #ffffff;
    text-align: center;
    line-height: 1.7;
    margin-bottom: 30px;
  }
  .offer-head__btn {
    border-radius: 6px;
    box-shadow: 0px 4px 0px 0px #001867;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .offer-head__btn-link {
    display: block;
    border-radius: 6px;
    background-color: #ececec;
    font-size: 24px;
    font-weight: 600;
    color: #004ea2;
    text-align: center;
    line-height: 1.0;
    text-decoration: none;
    padding: 24px 68px;
    position: relative;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .offer-head__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_blue.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 12px;
    height: 20px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
  }
  .offer-head__btn:hover {
    box-shadow: 0px 0px 0px 0px #001867;
  }
  .offer-head__btn:hover .offer-head__btn-link {
    transform: translateY(4px);
  }
  .offer-head__text--sub{
    margin-top: 10px;
  }
  .offer-head__text--link{
    color: #fff;
  }
  .offer-head__text--link:hover{
    opacity: 0.7;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .offer-head {
    background-color: #004ea2;
    background-image: url(/online-dance/assets/img/210506/offer_head_bg_01.jpg);
    background-position: bottom right;
    background-repeat: no-repeat;
    background-size: cover;
  }
  .offer-head__wrap {
    padding: 8vw 4vw ;
  }
  .offer-head__title {
    font-size: 4.8vw;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 2.66666666vw;
  }
  .offer-head__title-strong {
    font-size: 5.86666666vw;
  }
  .offer-head__text {
    font-size: 3.73333333vw;
    font-weight: 200;
    color: #ffffff;
    line-height: 1.7;
    margin-bottom: 5.33333333vw;
  }
  .offer-head__btn {
    border-radius: 4px;
    box-shadow: 0 0.53333333vw 0 0 #001867;
  }
  .offer-head__btn-link {
    display: block;
    border-radius: 4px;
    background-color: #ececec;
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #004ea2;
    text-align: center;
    line-height: 1.5;
    text-decoration: none;
    padding: 2.66666666vw;
    position: relative;
  }
  .offer-head__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_blue.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 2.13333333vw;
    height: 3.73333333vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2.66666666vw;
  }
  .offer-head__text--sub{
    margin-top: 10px;
  }
  .offer-head__text--link{
    color: #fff;
  }
  .offer-head__text--link:hover{
    opacity: 0.7;
  }
}



/*====================
  02.main
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .offer-main {
    background-color: #d7ecfa;
    position: relative;
    z-index: 1;
  }
  .offer-main::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/offer_main_bg_01_pc.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 970px;
    height: 288px;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
  }
  .offer-main__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 80px;
    padding-bottom: 100px;
  }
  /* heading */
  .offer-main__heading02 {
    font-size: 40px;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.3;
    margin-bottom: 40px;
    position: relative;
    z-index: 2;
  }
  .offer-main__section-list {
    position: relative;
    z-index: 2;
  }
  .offer-main__acc-list {
    background-color: #ffffff;
  }
  .offer-main__section-title {
    background-color: #004fa8;
    font-size: 28px;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.0;
    padding: 20px;
  }
  /* acc */
  .offer-main__acc-list {
    padding: 4px;
  }
  .offer-main__acc + .offer-main__acc {
    margin-top: 4px;
  }
  .offer-main__acc-title {
    background-color: #ececec;
    font-size: 28px;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.0;
    padding: 20px;
    position: relative;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .offer-main__acc-title::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/offer_icon_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 34px;
    height: 34px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
  }
  .offer-main__acc-title.active::after {
    background-image: url(/online-dance/assets/img/210506/offer_icon_02.png);
  }
  .offer-main__acc-title:hover {
    opacity: 0.7;
  }
  .offer-main__acc-body {
    padding: 40px 30px;
  }
  .offer-main__dot-list-item {
    font-size: 18px;
    font-weight: 400;
    color: #000000;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.0em;
    position: relative;
  }
  .offer-main__dot-list-item + .offer-main__dot-list-item {
    margin-top: 10px;
  }
  .offer-main__dot-list-item::before {
    content: "";
    border-radius: 50%;
    background-color: var(--speech-main-color);
    width: 10px;
    height: 10px;
    position: absolute;
    top: 10px;
    left: 0;
  }
  .offer-main__dot-list-column {
    margin-bottom: 35px;
  }
  .offer-main__dot-list-title {
    font-weight: 600;
    margin-top: 20px;
  }
  .offer-main__dot-list-text {
    font-weight: 200;
  }
  .offer-main__dot-list-text + .offer-main__dot-list-text {
    margin-top: 10px;
  }
  .offer-main__dot-list-offer {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    padding-left: 1.2em;
    position: relative;
  }
  .offer-main__dot-list-offer::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .offer-main__dot-list-blue {
    color: var(--speech-main-color);
  }
  /* title */
  .offer-main__title {
    font-size: 20px;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
    margin-bottom: 20px;
    padding-left: 38px;
    position: relative;
  }
  .offer-main__title::before {
    content: "";
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 28px;
    height: 28px;
    position: absolute;
    top: 4px;
    left: 0;
  }
  .offer-main__title--time::before {
    background-image: url(/online-dance/assets/img/210506/offer_icon_03.png);
  }
  .offer-main__title--cost::before {
    background-image: url(/online-dance/assets/img/210506/offer_icon_04.png);
  }
  /* head */
  .offer-main__head {
    margin-bottom: 30px;
  }
  /* bottom */
  .offer-main__bottom {
    margin-top: 40px;
  }
  /* col */
  .offer-main__col {
    display: flex;
  }
  .offer-main__col-item {
    width: 48%;
  }
  .offer-main__col-item + .offer-main__col-item {
    margin-left: 4%;
  }
  /* cv */
  .offer-main__cv {
    position: relative;
  }
  .offer-main__cv-cover {
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.9);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
  }
  .offer-main__cv-cover-text {
    font-size: 28px;
    font-weight: 500;
    text-align: center;
    color: #ffffff;
    line-height: 1.6;
    letter-spacing: 0.05em;
  }
  .offer-main__cv-offer {
    display: flex;
    flex-wrap: wrap;
    flex-flow: column;
    align-items: center;
    margin-top: 25px;
  }
  .offer-main__cv-offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.2em;
    position: relative;
  }
  .offer-main__cv-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* btn */
  .offer-main__btn {
    margin-top: 60px;
    margin-right: auto;
    margin-left: auto;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .offer-main__btn-link {
    display: block;
    border-radius: 6px;
    background-color: #ea070d;
    font-size: 0;
    text-align: center;
    line-height: 1.0;
    text-decoration: none;
    padding: 24px 53px 24px 30px;
    position: relative;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .offer-main__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 12px;
    height: 20px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
  }
  .offer-main__btn:hover .offer-main__btn-link {
    transform: translateY(4px);
  }
  .offer-main__btn--open {
    border-radius: 6px;
    box-shadow: 0px 4px 0px 0px #becfda;
    width: 420px;
  }
  .offer-main__btn--open:hover {
    opacity: 0.7;
    box-shadow: 0px 0px 0px 0px #becfda;
  }
  .offer-main__btn--close {
    width: 480px;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .offer-main {
    background-color: #d7ecfa;
    position: relative;
    z-index: 1;
  }
  .offer-main::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/offer_main_bg_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 100%;
    height: 46.66666666vw;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
  }
  .offer-main__wrap {
    padding: 10.66666666vw 6.66666666vw;
  }
  /* heading */
  .offer-main__heading02 {
    font-size: 5.33333333vw;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.3;
    margin-bottom: 4vw;
    position: relative;
    z-index: 2;
  }
  .offer-main__section-list {
    position: relative;
    z-index: 2;
  }
  .offer-main__acc-list {
    background-color: #ffffff;
  }
  .offer-main__section-title {
    background-color: #004fa8;
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.3;
    padding: 2.66666666vw;
  }
  /* acc */
  .offer-main__acc-list {
    padding: 0.53333333vw;
  }
  .offer-main__acc + .offer-main__acc {
    margin-top: 0.53333333vw;
  }
  .offer-main__acc-title {
    background-color: #ececec;
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.5;
    padding: 2.66666666vw 10.13333333vw 2.66666666vw 5.33333333vw;
    position: relative;
    cursor: pointer;
  }
  .offer-main__acc-title::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/offer_icon_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 5.33333333vw;
    height: 5.33333333vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2.66666666vw;
  }
  .offer-main__acc-title.active::after {
    background-image: url(/online-dance/assets/img/210506/offer_icon_02.png);
  }
  .offer-main__acc-body {
    padding: 4vw;
  }
  .offer-main__dot-list-item {
    font-size: 3.2vw;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
    padding-left: 0.8em;
    position: relative;
  }
  .offer-main__dot-list-item + .offer-main__dot-list-item {
    margin-top: 2.66666666vw;
  }
  .offer-main__dot-list-item::before {
    content: "";
    border-radius: 50%;
    background-color: var(--speech-main-color);
    width: 1.6vw;
    height: 1.6vw;
    position: absolute;
    top: 2.13333333vw;
    left: 0;
  }
  .offer-main__dot-list-column {
    margin-bottom: 5.33333333vw;
  }
  .offer-main__dot-list-title {
    font-weight: 600;
    margin-top: 4vw;
  }
  .offer-main__dot-list-text {
    font-weight: 200;
  }
  .offer-main__dot-list-text + .offer-main__dot-list-text {
    margin-top: 2.66666666vw;
  }
  .offer-main__dot-list-offer {
    font-size: 2.66666666vw;
    font-weight: 200;
    color: #808080;
    padding-left: 1.2em;
    position: relative;
  }
  .offer-main__dot-list-offer::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .offer-main__dot-list-blue {
    color: var(--speech-main-color);
  }
  /* title */
  .offer-main__title {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
    margin-bottom: 4vw;
    padding-left: 6.4vw;
    position: relative;
  }
  .offer-main__title::before {
    content: "";
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 4.8vw;
    height: 4.8vw;
    position: absolute;
    top: 0.53333333vw;
    left: 0;
  }
  .offer-main__title--time::before {
    background-image: url(/online-dance/assets/img/210506/offer_icon_03.png);
  }
  .offer-main__title--cost::before {
    background-image: url(/online-dance/assets/img/210506/offer_icon_04.png);
  }
  /* head */
  .offer-main__head {
    margin-bottom: 5.33333333vw;
  }
  /* bottom */
  .offer-main__bottom {
    margin-top: 8vw;
  }
  /* col */
  .offer-main__col-item + .offer-main__col-item {
    margin-top: 8vw;
  }
  /* cv */
  .offer-main__cv {
    position: relative;
  }
  .offer-main__cv-cover {
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.9);
    width: 100vw;
    height: 100%;
    margin-left: -6.66666666vw;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
  }
  .offer-main__cv-cover-text {
    font-size: 4.8vw;
    font-weight: 500;
    text-align: center;
    color: #ffffff;
    line-height: 1.8;
    letter-spacing: 0.05em;
  }
  .offer-main__cv-offer {
    text-align: center;
    margin-top: 4vw;
  }
  .offer-main__cv-offer-item {
    display: inline-block;
    font-size: 2.66666666vw;
    font-weight: 200;
    color: #808080;
    line-height: 1.7;
    letter-spacing: 0.05em;
    padding-left: 1.2em;
    position: relative;
  }
  .offer-main__cv-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* btn */
  .offer-main__btn {
    margin-top: 8vw;
    margin-right: 4vw;
    margin-left: 4vw;
  }
  .offer-main__btn-link {
    display: block;
    border-radius: 4px;
    background-color: #ea070d;
    font-size: 0;
    text-align: center;
    line-height: 1.0;
    text-decoration: none;
    padding-top: 4vw;
    padding-bottom: 4vw;
    position: relative;
  }
  .offer-main__btn-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 2.13333333vw;
    height: 3.73333333vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2.66666666vw;
  }
  .offer-main__btn--open {
    border-radius: 4px;
    box-shadow: 0 0.53333333vw 0 0 #becfda;
  }
}

/*====================
  03.btn
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
.offer__main-box--heading{
  font-size: 28px;
  margin-top: 40px;
  margin-bottom: 20px;
}
.offer__main-box{
  padding: 20px 0;
  border: 2px solid #fff;
  margin: 25px 0px;
  background-color: #fff;
}
.offer__main-text{
  margin-bottom: 20px;
  font-size: 28px;
  font-weight: bold;
  color: #004fa8;
  text-align: center;
}
.offer__contents{
  text-align: center;
  margin: 0 10px;
}
.offer__contents--text{
  font-size: 18px;
  font-weight: 400;
}
.offer__flex{
  display: flex;
  justify-content: center;
}
.offer__btn{
  border: 1px solid #000;
  width: 300px;
  padding: 10px 30px;
  margin: 10px auto;
  border-radius: 3px;
  color: #fff;
  font-weight: bold;
  box-shadow: 0px 4px 0px 0px #e2e2e2;
}
.offer__btn:hover{
  opacity: 0.7;
  box-shadow: 0px 0px 0px 0px #e2e2e2;
  transform: translateY(4px);
}

.offer__btn--youji1{
  border: 1px solid #004ea2;
  background-color: #004ea2;
}
.offer__btn--youji2{
  border: 1px solid #fc5d5d;
  background-color: #fc5d5d;
}
.offer__btn--sho1{
  border: 1px solid #00a329;
  background-color: #00a329;
}
.offer__btn--sho2{
  border: 1px solid #f78c00;
  background-color: #f78c00;
}
.offer__btn--modal-link{
  border: 1px solid #004fa8;
  background-color: #004fa8;
}
.offer__btn--link{
  text-decoration: none;
}
}

/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .offer__main-box--heading{
    font-size: 4.26666666vw;
    margin-top: 40px;
    margin-bottom: 20px;
  }
  .offer__main-box{
    border: 2px solid #fff;
    margin: 3.5vw 0;
    background-color: #fff;
  }
  .offer__main-text{
    margin:3.5vw 0 0 0;
    font-size: 4.95vw;
    font-weight: bold;
    color: #004fa8;
    text-align: center;
  }
  .offer__contents{
    text-align: center;
    margin-top: 0.5vw;
  }
  .offer__contents--top{
    margin-bottom: 7vw;
  }
  .offer__contents--text{
    font-size: 3.2vw;
    font-weight: 600;
  }
  .offer__btn{
    border: 1px solid #000;
    padding: 5px 20px;
    margin: 10px 10px;
    border-radius: 3px;
    color: #fff;
    font-weight: bold;
    box-shadow: 0px 4px 0px 0px #e2e2e2;
  }
  .offer__btn:hover{
    opacity: 0.7;
    box-shadow: 0px 0px 0px 0px #e2e2e2;
  }
  .offer__btn--youji1{
    border: 1px solid #004ea2;
    background-color: #004ea2;
  }
  .offer__btn--youji2{
    border: 1px solid #fc5d5d;
    background-color: #fc5d5d;
  }
  .offer__btn--sho1{
    border: 1px solid #00a329;
    background-color: #00a329;
  }
  .offer__btn--sho2{
    border: 1px solid #f78c00;
    background-color: #f78c00;
  }
  .offer__btn--modal-link{
    border: 1px solid #004fa8;
    background-color: #004fa8;
  }
  .offer__btn--link{
    text-decoration: none;
  }
}

/*========================================
  03.term
========================================*/
/*====================
  01.main
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .term-main {
    background-color: #ffffff;
  }
  .term-main__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 60px;
    padding-bottom: 60px;
  }
  /* acc */
  .term-main__acc + .term-main__acc {
    margin-top: 10px;
  }
  .term-main__acc-title {
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .term-main__acc-title::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/term_icon_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 34px;
    height: 34px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
  }
  .term-main__acc-title.active::after {
    background-image: url(/online-dance/assets/img/210506/term_icon_02.png);
  }
  .term-main__acc:nth-child(1) .term-main__acc-title {
    border-radius: 6px;
    box-shadow: 0px 2px 0px 0px #e2e2e2;
    background-color: #004ea2;
    font-size: 28px;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.0;
    padding: 20px;
    position: relative;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .term-main__acc:nth-child(2) .term-main__acc-title {
    border-radius: 6px;
    box-shadow: 0px 2px 0px 0px #e2e2e2;
    background-color: #ececec;
    font-size: 28px;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.0;
    padding: 20px;
    position: relative;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .term-main__acc-title:hover {
    opacity: 0.7;
  }
  .term-main__acc-body {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .term-main__heading {
    font-size: 24px;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.3;
    margin-bottom: 50px;
  }
  .term-main__section-title03 {
    font-size: 20px;
    font-weight: 600;
    color: #002222;
    line-height: 1.2;
    margin-top: 45px;
    margin-bottom: 25px;
    padding-left: 1.0em;
    position: relative;
  }
  .term-main__section-title03::before {
    content: "";
    border-radius: 6px;
    background-color: #004fa8;
    width: 6px;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  .term-main__section-title04 {
    font-size: 16px;
    font-weight: 600;
    color: #002222;
    line-height: 1.7;
    margin-top: 25px;
    margin-bottom: 10px;
  }
  .term-main__section-text {
    font-size: 16px;
    font-weight: 400;
    color: #002222;
    line-height: 1.7;
    margin-top: 15px;
    margin-bottom: 15px;
    padding-left: 1.2em;
  }
  .term-main__section-bottom-text {
    font-size: 16px;
    font-weight: 400;
    color: #002222;
    text-align: right;
    line-height: 1.7;
    margin-top: 15px;
  }
  .term-main__section-number-item {
    font-size: 16px;
    font-weight: 400;
    color: #002222;
    line-height: 1.7;
    padding-left: 1.2em;
    position: relative;
  }
  .term-main__section-number-item + .term-main__section-number-item {
    margin-top: 10px;
  }
  .term-main__section-number-item::before {
    position: absolute;
    top: 0;
    left: 0;
  }
  .term-main__section-number-item:nth-child(1)::before {
    content: "1.";
  }
  .term-main__section-number-item:nth-child(2)::before {
    content: "2.";
  }
  .term-main__section-number-item:nth-child(3)::before {
    content: "3.";
  }
  .term-main__section-number-item:nth-child(4)::before {
    content: "4.";
  }
  .term-main__section-number-item:nth-child(5)::before {
    content: "5.";
  }
  .term-main__section-number-item:nth-child(6)::before {
    content: "6.";
  }
  .term-main__section-number-item:nth-child(7)::before {
    content: "7.";
  }
  .term-main__section-number-item:nth-child(8)::before {
    content: "8.";
  }
  .term-main__section-number-item:nth-child(9)::before {
    content: "9.";
  }
  .term-main__section-number-item:nth-child(10)::before {
    content: "10.";
  }
  .term-main__section-offer {
    margin-top: 20px;
  }
  .term-main__section-offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    padding-left: 1.2em;
    position: relative;
  }
  .term-main__section-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .term-main {
    background-color: #ffffff;
  }
  .term-main__wrap {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }
  /* acc */
  .term-main__acc + .term-main__acc {
    margin-top: 2.66666666vw;
  }
  .term-main__acc-title {
    margin-right: 4vw;
    margin-left: 4vw;
  }
  .term-main__acc-title::after {
    content: "";
    background-image: url(/online-dance/assets/img/210506/term_icon_01.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 5.33333333vw;
    height: 5.33333333vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2.66666666vw;
  }
  .term-main__acc-title.active::after {
    background-image: url(/online-dance/assets/img/210506/term_icon_02.png);
  }
  .term-main__acc:nth-child(1) .term-main__acc-title {
    border-radius: 6px;
    box-shadow: 0px 2px 0px 0px #e2e2e2;
    background-color: #004ea2;
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.3;
    padding: 2.66666666vw 10.13333333vw 2.66666666vw 5.33333333vw;
    position: relative;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .term-main__acc:nth-child(2) .term-main__acc-title {
    border-radius: 6px;
    box-shadow: 0px 2px 0px 0px #e2e2e2;
    background-color: #ececec;
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.3;
    padding: 4vw 10.13333333vw 4vw 5.33333333vw;
    position: relative;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .term-main__acc-body {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }
  .term-main__heading {
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.3;
    margin-bottom: 4vw;
  }
  .term-main__section-title03 {
    background-color: #d7ecfa;
    font-size: 3.2vw;
    font-weight: 600;
    color: #002222;
    line-height: 1.2;
    margin-top: 8vw;
    margin-bottom: 2.66666666vw;
    padding-top: 1.6vw;
    padding-bottom: 1.6vw;
    padding-left: 8vw;
    position: relative;
  }
  .term-main__section-title03::before {
    content: "";
    background-color: #004fa8;
    width: 1.6vw;
    height: 70%;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 4vw;
  }
  .term-main__section-title04 {
    font-size: 3.2vw;
    font-weight: 600;
    color: #002222;
    line-height: 1.7;
    margin-top: 2.66666666vw;
    margin-bottom: 2.66666666vw;
    padding-right: 4vw;
    padding-left: 4vw;
  }
  .term-main__section-text {
    font-size: 3.2vw;
    font-weight: 400;
    color: #002222;
    line-height: 1.7;
    margin-top: 4vw;
    margin-bottom: 4vw;
    padding-right: 4vw;
    padding-left: 4vw;
  }
  .term-main__section-bottom-text {
    font-size: 3.2vw;
    font-weight: 400;
    color: #002222;
    text-align: right;
    line-height: 1.7;
    margin-top: 4vw;
    padding-right: 4vw;
    padding-left: 4vw;
  }
  .term-main__section-number-item {
    font-size: 3.2vw;
    font-weight: 400;
    color: #002222;
    line-height: 1.7;
    padding-right: 4vw;
    padding-left: 8vw;
    position: relative;
  }
  .term-main__section-number-item + .term-main__section-number-item {
    margin-top: 2.66666666vw;
  }
  .term-main__section-number-item::before {
    position: absolute;
    top: 0;
    left: 4vw;
  }
  .term-main__section-number-item:nth-child(1)::before {
    content: "1.";
  }
  .term-main__section-number-item:nth-child(2)::before {
    content: "2.";
  }
  .term-main__section-number-item:nth-child(3)::before {
    content: "3.";
  }
  .term-main__section-number-item:nth-child(4)::before {
    content: "4.";
  }
  .term-main__section-number-item:nth-child(5)::before {
    content: "5.";
  }
  .term-main__section-number-item:nth-child(6)::before {
    content: "6.";
  }
  .term-main__section-number-item:nth-child(7)::before {
    content: "7.";
  }
  .term-main__section-number-item:nth-child(8)::before {
    content: "8.";
  }
  .term-main__section-number-item:nth-child(9)::before {
    content: "9.";
  }
  .term-main__section-number-item:nth-child(10)::before {
    content: "10.";
  }
  .term-main__section-offer {
    margin-top: 4vw;
  }
  .term-main__section-offer-item {
    font-size: 2.66666666vw;
    font-weight: 200;
    color: #808080;
    padding-right: 8vw;
    padding-left: 8vw;
    position: relative;
  }
  .term-main__section-offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 4vw;
  }
}





/*========================================
  04.info
========================================*/
/*====================
  01.head
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .info-head {
    background-color: #E5465A;
    background-position: bottom right;
    background-repeat: no-repeat;
    background-size: cover;
  }
  .info-head__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 50px;
    padding-bottom: 50px;
    margin-top: 90px;
  }
  .info-head__title {
    font-size: 30px;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.3;
    margin-bottom: 30px;
  }
  .info-head__title-strong {
    font-size: 40px;
  }
  .info-head__text {
    font-size: 18px;
    font-weight: 200;
    color: #ffffff;
    text-align: center;
    line-height: 1.7;
  }
  .info-head__offer {
    text-align: center;
    margin-top: 20px;
  }
  .info-head__offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #ffffff;
    display: inline-block;
    text-align: center;
    line-height: 1.7;
    padding-left: 1.2em;
    position: relative;
    text-decoration: underline;
  }
  .info-head__offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .info-head {
    background-color: #E5465A;
    background-position: bottom right;
    background-repeat: no-repeat;
    background-size: cover;
  }
  .info-head__wrap {
    margin-top: 60px;
    padding: 8vw 4vw;
  }
  .info-head__title {
    font-size: 4.8vw;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 2.66666666vw;
  }
  .info-head__title-strong {
    font-size: 5.86666666vw;
  }
  .info-head__text {
    font-size: 3.73333333vw;
    font-weight: 200;
    color: #ffffff;
    line-height: 1.7;
  }
  .info-head__offer {
    margin-top: 4vw;
  }
  .info-head__offer-item {
    font-size: 3.2vw;
    font-weight: 200;
    color: #ffffff;
    line-height: 1.7;
    padding-left: 1.2em;
    position: relative;
    text-decoration: underline;
  }
  .info-head__offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
}



/*====================
  02.main
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .info-main {
    background-color: var(--speech-sub-color);
  }
  .info-main__wrap {
    width: 960px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 40px;
    padding-bottom: 80px;
  }
  /* emergency */
  .info-main__emergency {
    margin-bottom: 30px;
  }
  .info-main__emergency-text {
    font-size: 14px;
    font-weight: 600;
    color: #ea070d;
    line-height: 1.5;
    letter-spacing: 0.05em;
  }
  .info-main__emergency-link {
    color: #0082d2;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .info-main__emergency-link:hover {
    opacity: 0.7;
    text-decoration: none;
  }
  /* nav */
  .info-main__nav {
    border: solid 4px var(--speech-main-color);
    background-color: #ffffff;
    margin-bottom: 60px;
    padding: 30px 40px;
  }
  .info-main__nav-title {
    font-size: 18px;
    font-weight: 400;
    color: #000000;
    text-align: center;
    letter-spacing: 0.1em;
    margin-bottom: 15px;
  }
  .info-main__nav-list {
    display: flex;
    flex-wrap: wrap;
  }
  .info-main__nav-item {
    box-sizing: border-box;
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 0.1em;
    width: 50%;
    padding-left: 16px;
    position: relative;
  }
  .info-main__nav-item:nth-child(n+3) {
    margin-top: 8px;
  }
  .info-main__nav-item::before {
    content: "";
    display: block;
    border-radius: 50%;
    background-color: var(--speech-main-color);
    width: 9px;
    height: 9px;
    position: absolute;
    top: 8px;
    left: 0;
  }
  .info-main__nav-link {
    color: var(--speech-main-color);
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .info-main__nav-link:hover {
    opacity: 0.7;
    text-decoration: none;
  }
  /* section */
  .info-main__section-title {
    background-color: var(--speech-main-color);
    font-size: 28px;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.0;
    padding: 20px;
  }
  .info-main__section-content {
    background-color: #ffffff;
  }
  .info-main__section-content--acc {
    padding: 4px;
  }
  .info-main__section-content--top {
    padding: 40px 40px 60px;
  }
  .info-main__thumb {
    width: 650px;
    margin-right: auto;
    margin-left: auto;
  }
  .info-main__thumb + .offer-main__dot-list{
    margin-top: 20px;
  }
  .info-main__thumb-way{
    width: 450px;
  }
  .info-main__thumb-link {
    display: block;
  }
  .info-main__thumb-link:hover {
    opacity: 0.7;
  }
  .info-main__sub-title {
    font-size: 28px;
    font-weight: 600;
    color: #222222;
    text-align: center;
    line-height: 1.5;
    margin-top: 20px;
    margin-bottom: 5px;
  }
  .info-main__sub-offer {
    font-size: 20px;
    font-weight: 400;
    color: #808080;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 30px;
  }
  .info-main__text {
    font-size: 18px;
    font-weight: 400;
    color: #000000;
    line-height: 1.7;
    letter-spacing: 0.1em;
  }
  .info-main__text + .info-main__text {
    margin-top: 20px;
  }
  .info-main__thumb + .info-main__text {
    margin-top: 50px;
  }
  .info-main__text + .info-main__thumb {
    margin-top: 50px;
  }
  .mt50-pc {
    margin-top: 50px;
  }
  .info-main__marker {
    background:linear-gradient(transparent 60%, #fff100 60%);
  }
  /* calendar */
  .info-main__calendar {
    width: 650px;
    margin-right: auto;
    margin-left: auto;
    margin-top: 30px;
  }
  .info-main__calendar-link {
    display: block;
    position: relative;
  }
  .info-main__calendar-link:hover {
    opacity: 0.7;
  }
  .js-calendar__prev,
  .js-calendar__next {
    border-radius: 50%;
    background-color: rgba(127,127,127,0.5);
    width: 66px;
    height: 66px;
    margin-top: auto;
    margin-bottom: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 2;
    cursor: pointer;
  }
  .js-calendar__prev {
    left: -120px;
  }
  .js-calendar__next {
    right: -120px;
  }
  .js-calendar__prev::before {
    content: "";
    background-image: url(/online-dance/assets/img/210601/info_icon_03.png);
    width: 13px;
    height: 21px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 5px;
    left: 0;
    transform: rotate(180deg);
  }
  .js-calendar__next::before {
    content: "";
    background-image: url(/online-dance/assets/img/210601/info_icon_03.png);
    width: 13px;
    height: 21px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 5px;
  }
  .js-calendar__prev:hover,
  .js-calendar__next:hover {
    opacity: 0.7;
  }
  .js-calendar__dots {
    display: flex;
    justify-content: center;
    margin-top: 40px;
  }
  .js-calendar__dots li button {
    display: block;
    box-sizing: border-box;
    border-radius: 50%;
    border: solid 1px var(--speech-main-color);
    background-color: #ffffff;
    font-size: 0;
    line-height: 0;
    width: 14px;
    height: 14px;
    cursor: pointer;
  }
  .js-calendar__dots li.slick-active button {
    background-color: var(--speech-main-color);
  }
  .js-calendar__dots li button:hover {
    opacity: 0.7;
  }
  .js-calendar__dots li + li {
    margin-left: 20px;
  }
  /* acc */
  .info-main__acc + .info-main__acc {
    margin-top: 4px;
  }
  .info-main__acc-title {
    background-color: #ececec;
    font-size: 28px;
    font-weight: 600;
    color: var(--speech-main-color);
    text-align: center;
    line-height: 1.3;
    padding: 20px;
    position: relative;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  }
  .info-main__acc-title:hover {
    opacity: 0.7;
  }
  .info-main__acc-title::after {
    content: "";
    background-image: var( --speech-plus-icon);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 34px;
    height: 34px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
  }
  .info-main__acc-title.active::after {
    background-image: var( --speech-minus-icon);
  }
  .info-main__acc-body {
    padding: 40px 30px;
  }
  .section04_flex{
    display: flex;
    justify-content: space-between;
  }
  .section04_flex .info-main__thumb{
    margin-top: 20px;
    width: 50%;
  }
  .section04_flex p{
    margin-top: 20px;
    width: 50%;
  }
  /* dot */
  .info-main__dot-list-item {
    font-size: 18px;
    font-weight: 400;
    color: #000000;
    line-height: 1.7;
    letter-spacing: 0.1em;
    padding-left: 1.0em;
    position: relative;
  }
  .info-main__dot-list-item + .info-main__dot-list-item {
    margin-top: 10px;
  }
  .info-main__dot-list-item::before {
    content: "";
    border-radius: 50%;
    background-color: var(--speech-main-color);
    width: 10px;
    height: 10px;
    position: absolute;
    top: 10px;
    left: 0;
  }
  .info-main__dot-list-column {
    margin-bottom: 35px;
  }
  .info-main__dot-list-blue {
    color: #E5465A;
  }
  .info-main__dot-list-title {
    font-weight: 600;
    margin-top: 20px;
  }
  .info-main__dot-list-text {
    font-weight: 200;
  }
  /* offer */
  .info-main__offer {
    margin-top: 20px;
  }
  .info-main__offer-item {
    font-size: 14px;
    font-weight: 200;
    color: #808080;
    word-break: break-all;
    padding-left: 1.2em;
    position: relative;
  }
  .info-main__offer-item + .info-main__offer-item {
    margin-top: 10px;
  }
  .info-main__offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .info-main__offer--large .info-main__offer-item {
    font-size: 16px;
  }
  .info-main__offer--mb {
    margin-bottom: 20px;
  }
  .info-main__offer + .info-main__dot-list {
    margin-top: 20px;
  }
  .info-main__offer-item a {
    color: #808080;
  }
  /* example */
  .info-main__example {
    background-color: var(--speech-sub-color);
    font-size: 18px;
    font-weight: 200;
    color: #222222;
    line-height: 1.5;
    margin-top: 25px;
    margin-bottom: 25px;
    padding: 14px 25px;
  }
  /* link */
  .info-main__text-link {
    color: var(--speech-main-color);
  }
  .info-main__text-link:hover {
    opacity: 0.7;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .info-main {
    background-color: var(--speech-sub-color);
  }
  .info-main__wrap {
    padding: 5.33333333vw 6.66666666vw 10.66666666vw;
  }
  /* emergency */
  .info-main__emergency {
    margin-bottom: 5.33333333vw;
  }
  .info-main__emergency-text {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #ea070d;
    line-height: 1.5;
    letter-spacing: 0.1em;
  }
  .info-main__emergency-link {
    color: #E5465A;
  }
  /* nav */
  .info-main__nav {
    border: solid 2px var(--speech-main-color);
    background-color: #ffffff;
    margin-bottom: 5.33333333vw;
    padding: 4vw;
  }
  .info-main__nav-title {
    font-size: 3.73333333vw;
    font-weight: 400;
    color: #000000;
    text-align: center;
    letter-spacing: 0.1em;

    margin-bottom: 2.66666666vw;
  }
  .info-main__nav-item {
    box-sizing: border-box;
    font-size: 3.73333333vw;
    font-weight: 400;
    letter-spacing: 0.1em;
    padding-left: 3.73333333vw;
    position: relative;
  }
  .info-main__nav-item + .info-main__nav-item {
    margin-top: 1.33333333vw;
  }
  .info-main__nav-item::before {
    content: "";
    display: block;
    border-radius: 50%;
    background-color: var(--speech-main-color);
    width: 1.6vw;
    height: 1.6vw;
    position: absolute;
    top: 8px;
    left: 0;
  }
  .info-main__nav-link {
    color: var(--speech-main-color);
  }
  /* section */
  .info-main__section-content {
    background-color: #ffffff;
  }
  .info-main__section-content--acc {
    padding: 0.53333333vw;
  }
  .info-main__section-content--top {
    padding: 4vw 4vw 8vw;
  }
  .info-main__acc + .info-main__acc {
    margin-top: 0.53333333vw;
  }
  .info-main__section-title {
    background-color: var(--speech-main-color);
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    line-height: 1.3;
    padding: 2.66666666vw;
  }
  .info-main__text {
    font-size: 3.73333333vw;
    font-weight: 400;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
  }
  .info-main__thumb-way{
    padding: 0 10vw;
  }
  .info-main__thumb-link {
    display: block;
  }
  .info-main__text + .info-main__text {
    margin-top: 4vw;
  }
  .info-main__thumb + .info-main__text {
    margin-top: 4vw;
  }
  .info-main__text + .info-main__thumb {
    margin-top: 4vw;
  }
  .info-main__thumb + .offer-main__dot-list{
    margin-top: 5.33333333vw; 
  }
  .info-main__sub-title {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    text-align: center;
    letter-spacing: 0.05em;
    margin-top: 4vw;
  }
  .info-main__sub-offer {
    font-size: 3.73333333vw;
    font-weight: 400;
    color: #808080;
    line-height: 1.7;
    text-align: center;
    letter-spacing: 0.05em;
    margin-bottom: 3.2vw;
  }
  .info-main__marker {
    background:linear-gradient(transparent 60%, #fff100 60%);
  }
  /* calendar */
  .info-main__calendar{
    margin-bottom: 30px;
  }
  .info-main__calendar-link {
    display: block;
    position: relative;
  }
  .info-main__calendar-link::after {
    content: "";
    background-image: url(/online-dance/assets/img/210601/info_icon_04.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 10.13333333vw;
    height: 10.13333333vw;
    position: absolute;
    bottom: 2.66666666vw;
    right: 2.66666666vw;
  }
  .js-calendar__prev,
  .js-calendar__next {
    border-radius: 50%;
    background-color: rgba(127,127,127,0.5);
    width: 8.8vw;
    height: 8.8vw;
    margin-top: auto;
    margin-bottom: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 2;
    cursor: pointer;
  }
  .js-calendar__prev {
    left: -9.6vw;
  }
  .js-calendar__next {
    right: -9.6vw;
  }
  .js-calendar__prev::before {
    content: "";
    background-image: url(/online-dance/assets/img/210601/info_icon_03.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 1.6vw;
    height: 2.66666666vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0.8vw;
    left: 0;
    transform: rotate(180deg);
  }
  .js-calendar__next::before {
    content: "";
    background-image: url(/online-dance/assets/img/210601/info_icon_03.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 1.6vw;
    height: 2.66666666vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0.8vw;
  }
  .js-calendar__dots {
    display: flex;
    justify-content: center;
    margin-top: 5.33333333vw;
  }
  .js-calendar__dots li button {
    display: block;
    box-sizing: border-box;
    border-radius: 50%;
    border: solid 0.26666666vw var(--speech-main-color);
    background-color: #ffffff;
    font-size: 0;
    line-height: 0;
    width: 3.73333333vw;
    height: 3.73333333vw;
    cursor: pointer;
  }
  .js-calendar__dots li.slick-active button {
    background-color: var(--speech-main-color);
  }
  .js-calendar__dots li + li {
    margin-left: 3vw;
  }
  /* acc */
  .info-main__acc-title {
    background-color: #ececec;
    font-size: 4.26666666vw;
    font-weight: 600;
    color: var(--speech-main-color);
    text-align: center;
    line-height: 1.5;
    padding: 2.66666666vw 10.13333333vw 2.66666666vw 5.33333333vw;
    position: relative;
    cursor: pointer;
  }
  .info-main__acc-title::after {
    content: "";
    background-image: var( --speech-plus-icon);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 5.33333333vw;
    height: 5.33333333vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2.66666666vw;
  }
  .info-main__acc-title.active::after {
    background-image: var( --speech-minus-icon);
  }
  .info-main__acc-body {
    padding: 4vw;
  }
  /* dot */
  .info-main__dot-list-item {
    font-size: 3.73333333vw;
    font-weight: 600;
    color: #333333;
    line-height: 1.7;
    letter-spacing: 0.05em;
    padding-left: 0.8em;
    position: relative;
  }
  .info-main__dot-list-item + .info-main__dot-list-item {
    margin-top: 2.66666666vw;
  }
  .info-main__dot-list-item::before {
    content: "";
    border-radius: 50%;
    background-color: var(--speech-main-color);
    width: 1.6vw;
    height: 1.6vw;
    position: absolute;
    top: 2.13333333vw;
    left: 0;
  }
  .info-main__dot-list-column {
    margin-bottom: 5.33333333vw;
  }
  .info-main__dot-list-title {
    font-weight: 600;
    margin-top: 4vw;
  }
  .info-main__dot-list-blue {
    color: #E5465A;
  }
  .info-main__dot-list-text {
    font-weight: 200;
  }
  .info-main__dot-list-offer {
    font-size: 2.66666666vw;
    font-weight: 200;
    color: #808080;
    padding-left: 1.2em;
    position: relative;
  }
  .info-main__dot-list-offer::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* offer */
  .info-main__offer {
    margin-top: 5.33333333vw;
  }
  .info-main__offer-item {
    font-size: 2.66666666vw;
    font-weight: 200;
    color: #808080;
    word-break: break-all;
    padding-left: 1.2em;
    position: relative;
  }
  .info-main__offer-item + .info-main__offer-item {
    margin-top: 2.66666666vw;
  }
  .info-main__offer-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .info-main__offer--large .info-main__offer-item {
    font-size: 3.2vw;
  }
  .info-main__offer--mb {
    margin-bottom: 5.33333333vw;
  }
  .info-main__offer + .info-main__dot-list {
    margin-top: 5.33333333vw;
  }
  .info-main__offer-item a {
    color: #808080;
  }
  /* example */
  .info-main__example {
    background-color: var(--speech-sub-color);
    font-size: 3.73333333vw;
    font-weight: 200;
    color: #222222;
    line-height: 1.5;
    margin-top: 5.33333333vw;
    margin-bottom: 5.33333333vw;
    padding: 2.66666666vw;
  }
  /* link */
  .info-main__text-link {
    color: var(--speech-main-color);
  }
}


/*====================
  03.bottom
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* base */
  .info-bottom {
    background-image: var( --speech-pc-bg);
    background-position: center;
    background-repeat: no-repeat;
  }
  .info-bottom__wrap {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .info-bottom__text {
    font-size: 32px;
    font-weight: 600;
    color: var(--speech-main-color);
    text-align: center;
    line-height: 1.5;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* base */
  .info-bottom {
    background-image: var( --speech-sp-bg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
  }
  .info-bottom__wrap {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }
  .info-bottom__text {
    font-size: 5vw;
    font-weight: 600;
    color: var(--speech-main-color);
    text-align: center;
    line-height: 1.5;
  }
}





/*========================================
  05.animation
========================================*/
/*====================
  01.kv
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* アニメーション前 */
  .kv__main::before {
    content: "";
    background-image: linear-gradient(135deg, transparent, transparent 20%,#ffffff 0,#ffffff);
    width: 200vw;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 5;
  }
  .kv__main-heading,
  .kv__main-text,
  .kv__main-copy,
  .kv__main-balloon {
    opacity: 0;
    transform: translateY(30px);
  }
  /* アニメーション */
  .kv[data-emergence=visible] .kv__main::before {
    animation-name: kv01_pc;
    animation-duration: 1.2s;
    animation-timing-function: cubic-bezier(.67, 0, .11, 1);
    animation-fill-mode: forwards;
  }
  .kv[data-emergence=visible] .kv__main-heading,
  .kv[data-emergence=visible] .kv__main-text,
  .kv[data-emergence=visible] .kv__main-copy,
  .kv[data-emergence=visible] .kv__main-balloon {
    animation-name: kv02_sp;
    animation-duration: 0.6s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  .kv[data-emergence=visible] .kv__main-heading {
    animation-delay: 0.6s;
  }
  .kv[data-emergence=visible] .kv__main-text {
    animation-delay: 0.8s;
  }
  .kv[data-emergence=visible] .kv__main-copy {
    animation-delay: 1.0s;
  }
  .kv[data-emergence=visible] .kv__main-balloon {
    animation-delay: 0.4s;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* アニメーション前 */
  .kv__main::before {
    content: "";
    background-image: linear-gradient(135deg, transparent, transparent 20%,#ffffff 0,#ffffff);
    width: 300vw;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 5;
  }
  .kv__main-heading,
  .kv__main-text,
  .kv__main-copy {
    opacity: 0;
    transform: translateY(30px);
  }
  /* アニメーション */
  .kv[data-emergence=visible] .kv__main::before {
    animation-name: kv01_sp;
    animation-duration: 1.2s;
    animation-timing-function: cubic-bezier(.67, 0, .11, 1);
    animation-fill-mode: forwards;
  }
  .kv[data-emergence=visible] .kv__main-heading,
  .kv[data-emergence=visible] .kv__main-text,
  .kv[data-emergence=visible] .kv__main-copy {
    animation-name: kv02_sp;
    animation-duration: 0.6s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  .kv[data-emergence=visible] .kv__main-heading {
    animation-delay: 0.6s;
  }
  .kv[data-emergence=visible] .kv__main-text {
    animation-delay: 0.9s;
  }
  .kv[data-emergence=visible] .kv__main-copy {
    animation-delay: 1.2s;
  }
}



/*====================
  02.about
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* アニメーション前 */
  .about__heading02,
  .about__main-text,
  .about__main-offer,
  .about__main-btn-list {
    opacity: 0;
  }
  /* アニメーション */
  .about[data-emergence=visible] .about__heading02,
  .about[data-emergence=visible] .about__main-text,
  .about[data-emergence=visible] .about__main-offer,
  .about[data-emergence=visible] .about__main-btn-list {
    animation-name: fadein;
    animation-duration: 0.6s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  .about[data-emergence=visible] .about__heading02 {
    animation-delay: 0.2s;
  }
  .about[data-emergence=visible] .about__main-text,
  .about[data-emergence=visible] .about__main-offer {
    animation-delay: 0.4s;
  }
  .about[data-emergence=visible] .about__main-btn-list {
    animation-delay: 0.6s;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* アニメーション前 */
  .about__heading02,
  .about__main-text,
  .about__main-offer,
  .about__main-btn-list {
    opacity: 0;
  }
  /* アニメーション */
  .about[data-emergence=visible] .about__heading02,
  .about[data-emergence=visible] .about__main-text,
  .about[data-emergence=visible] .about__main-offer,
  .about[data-emergence=visible] .about__main-btn-list {
    animation-name: fadein;
    animation-duration: 0.6s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  .about[data-emergence=visible] .about__heading02 {
    animation-delay: 0.3s;
  }
  .about[data-emergence=visible] .about__main-text,
  .about[data-emergence=visible] .about__main-offer {
    animation-delay: 0.6s;
  }
  .about[data-emergence=visible] .about__main-btn-list {
    animation-delay: 0.9s;
  }
}



/*====================
  03.point
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* アニメーション前 */
  .point__section--01 .point__section-thumb-item:nth-child(2),
  .point__section--02 .point__section-thumb-item:nth-child(1),
  .point__section--02 .point__section-thumb-item:nth-child(2),
  .point__section--03 .point__section-thumb-item:nth-child(1),
  .point__section--03 .point__section-thumb-item:nth-child(2) {
    opacity: 0;
    transform: translateY(100px);
  }
  .point__section--01 .point__section-thumb-item:nth-child(1),
  .point__section--02 .point__section-thumb-item:nth-child(3),
  .point__section--03 .point__section-thumb-item:nth-child(3) {
    opacity: 0;
  }
  .point__section-thumb::after {
    transform: rotate(-45deg) translate(0px, 0px);
  }
  /* アニメーション */
  .point__section[data-emergence=visible] .point__section-thumb-item {
    animation-duration: 0.6s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  .point__section[data-emergence=visible] .point__section-thumb::after {
    animation-name: point02_pc;
    animation-duration: 1.2s;
    animation-delay: 0.0s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  /* 01 */
  .point__section--01[data-emergence=visible] .point__section-thumb-item:nth-child(1) {
    animation-name: fadein;
    animation-delay: 0.8s;
  }
  .point__section--01[data-emergence=visible] .point__section-thumb-item:nth-child(2) {
    animation-name: point01_pc;
    animation-delay: 0.4s;
  }
  /* 02 */
  .point__section--02[data-emergence=visible] .point__section-thumb-item:nth-child(1) {
    animation-name: point01_pc;
    animation-delay: 0.4s;
  }
  .point__section--02[data-emergence=visible] .point__section-thumb-item:nth-child(2) {
    animation-name: point01_pc;
    animation-delay: 0.6s;
  }
  .point__section--02[data-emergence=visible] .point__section-thumb-item:nth-child(3) {
    animation-name: fadein;
    animation-delay: 1.0s;
  }
  /* 03 */
  .point__section--03[data-emergence=visible] .point__section-thumb-item:nth-child(1) {
    animation-name: point01_pc;
    animation-delay: 0.4s;
  }
  .point__section--03[data-emergence=visible] .point__section-thumb-item:nth-child(2) {
    animation-name: point01_pc;
    animation-delay: 0.6s;
  }
  .point__section--03[data-emergence=visible] .point__section-thumb-item:nth-child(3) {
    animation-name: fadein;
    animation-delay: 1.0s;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* アニメーション前 */
  .point__section--01 .point__section-thumb-item:nth-child(2),
  .point__section--02 .point__section-thumb-item:nth-child(1),
  .point__section--02 .point__section-thumb-item:nth-child(2),
  .point__section--03 .point__section-thumb-item:nth-child(1),
  .point__section--03 .point__section-thumb-item:nth-child(2) {
    opacity: 0;
    transform: translateY(100px);
  }
  .point__section--01 .point__section-thumb-item:nth-child(1),
  .point__section--02 .point__section-thumb-item:nth-child(3),
  .point__section--03 .point__section-thumb-item:nth-child(3) {
    opacity: 0;
  }
  .point__section-thumb::after {
    transform: rotate(-45deg) translate(0px, 0px);
  }
  /* アニメーション */
  .point__section[data-emergence=visible] .point__section-thumb-item {
    animation-duration: 0.6s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  .point__section[data-emergence=visible] .point__section-thumb::after {
    animation-name: point02_sp;
    animation-duration: 1.0s;
    animation-delay: 0.0s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  /* 01 */
  .point__section--01[data-emergence=visible] .point__section-thumb-item:nth-child(1) {
    animation-name: fadein;
    animation-delay: 0.6s;
  }
  .point__section--01[data-emergence=visible] .point__section-thumb-item:nth-child(2) {
    animation-name: point01_sp;
    animation-delay: 0.2s;
  }
  /* 02 */
  .point__section--02[data-emergence=visible] .point__section-thumb-item:nth-child(1) {
    animation-name: point01_sp;
    animation-delay: 0.2s;
  }
  .point__section--02[data-emergence=visible] .point__section-thumb-item:nth-child(2) {
    animation-name: point01_sp;
    animation-delay: 0.4s;
  }
  .point__section--02[data-emergence=visible] .point__section-thumb-item:nth-child(3) {
    animation-name: fadein;
    animation-delay: 0.8s;
  }
  /* 03 */
  .point__section--03[data-emergence=visible] .point__section-thumb-item:nth-child(1) {
    animation-name: point01_sp;
    animation-delay: 0.2s;
  }
  .point__section--03[data-emergence=visible] .point__section-thumb-item:nth-child(2) {
    animation-name: point01_sp;
    animation-delay: 0.4s;
  }
  .point__section--03[data-emergence=visible] .point__section-thumb-item:nth-child(3) {
    animation-name: fadein;
    animation-delay: 0.8s;
  }
}



/*====================
  05.flow
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* アニメーション前 */
  .flow__section-thumb-item img {
    opacity: 0;
    transform: scale(0.4, 0.4);
  }
  /* アニメーション */
  .flow__section-list[data-emergence=visible] .flow__section-thumb-item img {
    animation-name: bound;
    animation-duration: 0.4s;
    animation-timing-function: cubic-bezier(0.3, 0.9, 0.62, 1.2);
    animation-fill-mode: forwards;
  }
  .flow__section-list[data-emergence=visible] .flow__section:nth-child(1) .flow__section-thumb-item img {
    animation-delay: 0.0s;
  }
  .flow__section-list[data-emergence=visible] .flow__section:nth-child(2) .flow__section-thumb-item img {
    animation-delay: 0.3s;
  }
  .flow__section-list[data-emergence=visible] .flow__section:nth-child(3) .flow__section-thumb-item img {
    animation-delay: 0.6s;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* アニメーション前 */
  .flow__section-thumb-item img {
    opacity: 0;
    transform: scale(0.4, 0.4);
  }
  /* アニメーション */
  .flow__section[data-emergence=visible] .flow__section-thumb-item img {
    animation-name: bound;
    animation-duration: 0.4s;
    animation-timing-function: cubic-bezier(0.3, 0.9, 0.62, 1.2);
    animation-fill-mode: forwards;
  }
}



/*====================
  06.faq
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* アニメーション前 */
  .faq__section {
    opacity: 0;
    display: block;
    text-decoration: none;
  }
  /* アニメーション */
  .faq__section-list[data-emergence=visible] .faq__section {
    animation-name: fadein;
    animation-duration: 0.6s;
    animation-delay: 0.0s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(1) {
    animation-delay: 0.0s;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(2) {
    animation-delay: 0.2s;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(3) {
    animation-delay: 0.4s;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(4) {
    animation-delay: 0.6s;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(5) {
    animation-delay: 0.8s;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* アニメーション前 */
  .faq__section {
    opacity: 0;
    display: block;
    text-decoration: none;
  }
  /* アニメーション */
  .faq__section-list[data-emergence=visible] .faq__section {
    animation-name: fadein;
    animation-duration: 0.6s;
    animation-delay: 0.0s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
    display: block;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(1) {
    animation-delay: 0.0s;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(2) {
    animation-delay: 0.2s;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(3) {
    animation-delay: 0.4s;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(4) {
    animation-delay: 0.6s;
  }
  .faq__section-list[data-emergence=visible] .faq__section:nth-child(5) {
    animation-delay: 0.8s;
  }
}


/*====================
  08.program
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  /* アニメーション前 */
  .program__section {
    opacity: 0;
  }
  .program__section::before {
    opacity: 0;
  }
  /* アニメーション */
  .program__section[data-emergence=visible] {
    animation-name: fadein;
    animation-duration: 0.4s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
    animation-delay: 0.0s;
  }
  .program__section[data-emergence=visible]:before {
    animation-name: fadein;
    animation-duration: 0.4s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
    animation-delay: 0.4s;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  /* アニメーション前 */
  .program__section {
    opacity: 0;
  }
  .program__section::before {
    opacity: 0;
  }
  /* アニメーション */
  .program__section[data-emergence=visible] {
    animation-name: fadein;
    animation-duration: 0.4s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
    animation-delay: 0.0s;
  }
  .program__section[data-emergence=visible]:before {
    animation-name: fadein;
    animation-duration: 0.4s;
    animation-timing-function: ease;
    animation-fill-mode: forwards;
    animation-delay: 0.4s;
  }
}


/* kv */
@keyframes kv01_pc {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(220vw);
  }
}
@keyframes kv01_sp {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(320vw);
  }
}
@keyframes kv02_pc {
  0% {
    opacity: 0;
    transform: translateY(100px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes kv02_sp {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
/* point */
@keyframes point01_pc {
  0% {
    opacity: 0;
    transform: translateY(100px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes point01_sp {
  0% {
    opacity: 0;
    transform: translateY(50px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes point02_pc {
  0% {
    transform: rotate(-45deg) translate(0px, 0px);
    z-index: 1;
  }
  99% {
    transform: rotate(-45deg) translate(0px, 640px);
    z-index: 1;
  }
  100% {
    transform: rotate(-45deg) translate(0px, 640px);
    z-index: -1;
  }
}
@keyframes point02_sp {
  0% {
    transform: rotate(-45deg) translate(0px, 0px);
    z-index: 1;
  }
  99% {
    transform: rotate(-45deg) translate(0px, 90vw);
    z-index: 1;
  }
  100% {
    transform: rotate(-45deg) translate(0px, 90vw);
    z-index: -1;
  }
}
/* bound */
@keyframes bound {
  0% {
    opacity: 0;
    transform: scale(0.4, 0.4);
  }
  100% {
    opacity: 1;
    transform: scale(1.0, 1.0);
  }
}
/* fadein */
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}



/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .schoollogo-img{
    width: auto;
    margin: 0 auto 10px;
    display: block;
  }
  .lesson_thame_area{
    margin-top: 20px;
    text-align: center;
  }
  .lesson_thame_img{
    margin-right: 20px;
  }
  .lesson_thame_img:last-child{
    margin-right: 0px;
  }
  .info-main__section{
    padding-top: 70px;
    margin-top: -70px;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .schoollogo-img{
    width: 50vw;
    margin: 0 auto 10px;
    display: block;
  }
  .lesson_thame_img{
    margin-top: 10px;
  }
  .info-main__section{
    padding-top: 10px;
    margin-top: -10px;
  }
}

/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .kyouzai-img {
    width: 60%;
    height: auto;
    vertical-align: bottom;
  }
}
/* 手順 */
/* PC */
@media only screen and (min-width: 769px), print, tv {
  .info-main__ybk {
    background-color: #FEE9FB;
    text-align: center;
    margin: 0 auto;
    width: 80%;
    font-size: 23px;
    font-weight: 600;
    margin-top: 30px;
    margin-bottom: 20px;
    padding: 10px 0;
}
.info-main__thumb-way__ex {
  width: 100% ;
  text-align: center;
}
.ex-img{
  width: 80%;
}
.ex-img2{
  width: 50%;
}
}
/* SP */
@media only screen and (max-width: 768px) {
  .info-main__ybk {
    background-color: #FEE9FB;
    text-align: center;
    font-size: 4vw;
    font-weight: 600;
    margin-top: 7vw;
    margin-bottom: 3vw;
    padding-top: 1vw;
    padding: 10px 0;
}
.info-main__thumb-way__ex {
  width: 100%;
  text-align: center;
  padding: 0;
}
.ex-img {
  width: 90%;
}
}

/*====================
  2023/1/10追記
====================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .info-main__text.info-main__text--center {
    text-align: center;
    margin-top: 40px;
  }
  .info-main__mov-area {
    background-color: var(--speech-sub-color);
    border-radius: 10px;
    margin: 40px 0;
  }
  .info-main__mov-area .info-main__text {
    width: 850px;
    margin: 0 auto;
  }
  .info-main__mov-area .info-main__text--center {
    text-align: center;
    color: var(--speech-main-color);
    font-weight: bold;
    padding-top: 30px;
  }
  .info-main__mov {
    aspect-ratio: 16 / 9;
    width: 70%;
    max-width: 70%;
    margin: 0 auto;
  }
  .info-main__mov-frame {
    width: 100%;
    margin: 20px auto;
  }
  .info-main__offer--mb20 {
    margin-bottom: 20px;
  }
  .info-head {
    background-color: var(--speech-main-color);
    /* background-image: url(/zemi/challengeschool/online-tankyu/kaiin/assets/img/offer_head_bg_01_pc.jpg); */
  }
  .header__acc-box-item {
    padding: 30px;
  }
  .header__acc-box-item-txt--dance {
    color: #006CFF;
  }
  .header__acc-box-item-txt--art {
    color: #E8A02D;
  }
  .header__acc-box-item-txt--soroban {
    color: #FC333A;
  }
  .header__acc-box-item-txt--shuuji {
    color: #86C43E;
  }
  .header__acc-box-item-txt--programming {
    color: #a91bc6;
  }
  .header__acc-box-item-txt--tankyu {
    color: #E6465A;
  }
  .header__acc-box-item-txt--creator {
    color: #FD862E;
  }

  .info-main__nav-title {
    font-weight: bold;
  }
  .info-main__offer--mb20 {
    margin-bottom: 20px;
  }

  /* info-head__new */
  .info-head__new {
    background-color: #ffffff;
    padding: 6px 0;
    margin-top: 50px;
  }
  .info-head__new-inr {
    width: 880px;
    margin: 0 auto;
    padding: 30px;
    border: solid 4px var(--speech-main-color);
  }
  .info-head__new-ttl {
    text-align: center;
    color: var(--speech-main-color);
    font-size: 22px;
    font-weight: bold;
    margin-bottom: 10px;
  }
  .info-head__new-sub-ttl {
    text-align: center;
    font-size: 18px;
    padding-bottom: 20px;
  }
  .info-head__new-list {
    display: flex;
    flex-direction: column;
    font-size: 18px;
    margin-top: 26px;
  }
  .info-head__new-list-txt {
    width: auto;
    padding-left: 40px;
    line-height: 2;
    display: flex;
  }
  .info-head__new-list-txt-day {
    color: var(--speech-main-color);
    margin-right: 35px;
  }
  .info-head__new-list-more {
    display: none;
  }
  .info-head__new-list-more.js-active {
    display: block;
    text-align: center;
    margin: 10px auto;
    cursor: pointer;
  }

  /* modal */
  .modalid .modal {
    display: none;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
  }
  .modalid .modal__bg {
    background-color: rgba(183, 183, 183, 0.9);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  .modalid .modal__wrap {
    max-width: 960px;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .modalid .modal__content {
    border-radius: 5px;
    background-color: #ffffff;
    max-height: 100%;
    padding: 60px;
    width: auto;
  }
  .modalid .modal__close {
    cursor: pointer;
    position: absolute;
    top: 10px;
    right: 10px;
  }
  .modalid .modal__close-icon {
    font-size: 0px;
    width: 30px;
    margin-bottom: 5px;
    margin-right: auto;
    margin-left: auto;
  }
  .modalid .modal__title {
    font-size: 24px;
    font-weight: 600;
    color: var(--speech-main-color);
    text-align: center;
    line-height: 1.5;
    margin-bottom: 30px;
  }
  .modal__text{
    padding: 19px 25px 4px;
    font-size: 16px;
    line-height: 33px;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .info-main__text--center {
    text-align: center;
  }
  .info-main__mov-area {
    background-color: var(--speech-sub-color);
    border-radius: 10px;
    margin: 4vw 0;
  }
  .info-main__mov-area .info-main__text {
    width: 90%;
    margin-right: auto;
    margin-left: auto;
  }
  .info-main__mov-area .info-main__text--center {
    text-align: center;
    color: var(--speech-main-color);
    font-weight: bold;
    padding-top: 3vw;
  }
  .info-main__mov {
    aspect-ratio: 16 / 9;
    width: 70vw;
    margin: 0 auto;
  }
  .info-main__mov-frame {
    width: 70vw;
    margin: 4vw auto;
  }
  .info-main__offer--mb20 {
    margin-bottom: 5.33333333vw;
  }
  .info-head {
    background-color: var(--speech-main-color);
    /* background-image: url(/zemi/challengeschool/online-tankyu/kaiin/assets/img/offer_head_bg_01_sp.jpg); */
  }
  .js-calendar__dots {
    margin-top: 3.33333333vw;
    flex-wrap: wrap;
  }
  .js-calendar__dots li button {
    margin-top: 2vw;
  }
  .header__acc-box-item {
    padding: 20px 18px;
  }
  .header__acc-box-item-txt--dance {
    color: #006CFF;
  }
  .header__acc-box-item-txt--art {
    color: #E8A02D;
  }
  .header__acc-box-item-txt--soroban {
    color: #FC333A;
  }
  .header__acc-box-item-txt--shuuji {
    color: #86C43E;
  }
  .header__acc-box-item-txt--programming {
    color: #a91bc6;
  }
  .header__acc-box-item-txt--tankyu {
    color: #E6465A;
  }
  .header__acc-box-item-txt--creator {
    color: #FD862E;
  }

  .info-main__nav-title {
    font-weight: bold;
  }
  .info-main__offer--mb20 {
    margin-bottom: 2.66666666vw;
  }

  /* info-head__new */
  .info-head__new {
    background-color: #ffffff;
    padding: 1.5vw 0;
    margin-top: 20px;
  }
  .info-head__new-inr {
    width: 83vw;
    margin: 0 auto;
    padding: 10px;
    border: solid 2px var(--speech-main-color);
  }
  .info-head__new-ttl {
    text-align: center;
    color: var(--speech-main-color);
    font-size: 5vw;
    font-weight: bold;
    margin-bottom: 10px;
  }
  .info-head__new-sub-ttl {
    text-align: left;
    font-size: 3.5vw;
    padding-bottom: 20px;
  }
  .info-head__new-list {
    font-size: 3.73333333vw;
    margin-top: 26px;
  }
  .info-head__new-list-txt {
    padding-left: 3vw;
    line-height: 2;
    display: flex;
  }
  .info-head__new-list-txt-day {
    color: var(--speech-main-color);
    margin-right: 7vw;
  }
  .info-head__new-list-more {
    display: none;
  }
  .info-head__new-list-more.js-active {
    display: block;
    text-align: center;
    margin: 2vw auto;
  }

  /* modal */
  .modalid .modal {
    display: none;
    box-sizing: border-box;
    width: 100%;
    height: 100vh;
    padding: 8vw;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
    overflow-y: scroll;
  }
  .modalid .modal__bg {
    background-color: rgba(183, 183, 183, 0.9);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  .modalid .modal__wrap {
    width: 90%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .modalid .modal__content {
    overflow: auto;
    border-radius: 1.33333333vw;
    background-color: #ffffff;
    max-height: 70vh;
    padding: 5.33333333vw;
    width: auto;
  }
  .modalid .modal__close {
    width: 4.8vw;
    cursor: pointer;
    position: absolute;
    top: 2.133vw;
    right: 2.133vw;
  }
  .modalid .modal__close-icon {
    width: 4.8vw;
    cursor: pointer;
    position: absolute;
    top: 2.133vw;
    right: 2.133vw;
    font-size: 0;
    margin-bottom: 2vw;
    margin-right: auto;
    margin-left: auto;
  }
  .modalid .modal__title {
    font-size: 5.266667vw;
    font-weight: 600;
    color: var(--speech-main-color);
    text-align: center;
    line-height: 1.5;
    margin-bottom: 5.33333333vw;
  }
}

/* 20230210追加分 */

/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .info-head__new-list{
    overflow-y: scroll;
    height: 155px;
  }
  .info-head__new-bnr{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding-bottom: 20px;
    border-bottom: 1px solid #707070;
  }
  .info-head__new-bnr a{
    text-align: center;
    display: block;
    width: 50%;
  }
  .info-head__new-bnr img{
    width: 95%;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .info-head__new-list{
    overflow-y: scroll;
    height: 252px;
  }
  .info-head__new-bnr{
    border-bottom: 1px solid #707070;
  }
  .info-head__new-bnr a{
    text-align: center;
  }
  .info-head__new-bnr img{
    width: 100%;
    padding-bottom: 20px;
  }
}

/* 20230303追加分 */
/*===== 共通 =====*/
.info-main__text-num04::after {
  content: "4";
}
.info-main__text-num05::after {
  content: "5";
}
.info-main__text-num06::after {
  content: "6";
}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .info-main__acc-body-wrap{
    margin-top: 60px;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .info-main__acc-body-wrap{
    margin-top: 5vw;
  }
}

/* 2023/11/21 フォント関連 */
body {
  font-size: inherit;
  font-family: 'Noto Sans JP', sans-serif;
}

/* 20241220追加分 */
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .modalid .modal__wrap{
    overflow: scroll;
    max-height: 80%;
    height: fit-content;
  }
  .modalid .modal__content{
    max-height: fit-content;
  }
}