@charset "UTF-8";

/*=========================
  common
=========================*/

.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: #E7A02B;
}
.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: #86C43E;
}
.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;
}
.header__acc-box-item{
  
}

/*===== SP =====*/
@media only screen and (max-width: 768px) {
  body {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "ヒラギノ角ゴ ProN W3", Arial, "メイリオ", Meiryo, sans-serif;
  }
  body.fixed {
    overflow: hidden;
    height: 100vh;
  }

  .tomo {
    background-color: #ffffff;
  }
  .tomo__inner {
    padding-top: 18.667vw;
  }

  .sp-hidden {
    display: none;
  }

  /* offer */
  .tomo__offer-text {
    font-size: 3.2vw;
    font-weight: 200;
    color: #888888;
  }
  .tomo__offer-list-item {
    font-size: 3.2vw;
    font-weight: 200;
    color: #888888;
    padding-left: 1.2em;
    position: relative;
  }
  .tomo__offer-list-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .red_underline{
    color: #e40400;
    text-decoration: underline;
  }
  .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;
    font-family: 'Noto Sans JP', sans-serif;
  }
  .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;
  }
  .text-red{
    color: #e40400;
  }
}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  body {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "ヒラギノ角ゴ ProN W3", Arial, "メイリオ", Meiryo, sans-serif;
  }
  body.fixed {
    overflow: hidden;
    height: 100vh;
  }

  .tomo {
    background-color: #ffffff;
  }
  .tomo__inner {
    width: 970px;
    margin-right: auto;
    margin-left: auto;
    padding-bottom: 80px;
  }

  .pc-hidden {
    display: none;
  }

  /* offer */
  .tomo__offer-text {
    font-size: 14px;
    font-weight: 200;
    color: #888888;
  }
  .tomo__offer-list-item {
    font-size: 14px;
    font-weight: 200;
    color: #888888;
    padding-left: 1.2em;
    position: relative;
  }
  .tomo__offer-list-item::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  .red_underline{
    color: #e40400;
    text-decoration: underline;
  }
  .tomo__kv-text-ttl{
    font-weight: 700;
    color: #0070cb;
    margin-top: 20px;
  }
  .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;
    margin-top: 69px;
    position: relative;
    z-index: 2;
    background-color: #fff;
    font-family: 'Noto Sans JP', sans-serif;
  }
  .breadcrumb__list {
    margin-right: 30px;
    position: relative;
    font-size: 16px;
  }
  .breadcrumb__list-link {
    text-decoration: none;
    color: #000;
  }
  .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%;
  }
  .text-red{
    color: #e40400;
  }

}


/*=========================
  kv
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__kv {
    margin-bottom: 10.667vw;
  }
  .tomo__kv-main {
    padding-top: 8vw;
  }
  .tomo__kv-lead {
    font-size: 4.267vw;
    font-weight: 700;
    color: #0070cb;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 10px;
  }
  .tomo__kv-btn {
    margin-bottom: 20px;
    padding-right: 25px;
    padding-left: 25px;
  }
  .tomo__kv-img img {
    display: block;
    position: relative;
    pointer-events: none;
  }
  .tomo__kv-img img::after {
    content: "";
    border: 0;
    background-image: url(/zemi/challengeschool/tomo/_assets/img/kv_cover.png);
    line-height: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    pointer-events: none;
  }
  .tomo__kv-footer {
    padding: 5.333vw 5.333vw 0;
  }
  .tomo__kv-text {
    font-size: 3.733vw;
    font-weight: 200;
    color: #464646;
    line-height: 1.5;
  }
}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .tomo__kv {
    margin-bottom: 80px;
  }
  .tomo__kv-main {
    margin-bottom: 30px;
    position: relative;
  }
  .tomo__kv-lead {
    width: 312px;
    position: absolute;
    top: 25px;
    left: 20px;
    z-index: 3;
  }
  .tomo__kv-btn {
    width: 380px;
    position: absolute;
    top: 100px;
    left: 20px;
    z-index: 3;
  }
  .tomo__kv-title {
    width: 467px;
    position: absolute;
    top: 180px;
    left: 20px;
    z-index: 3;
  }
  .tomo__kv-img img {
    display: block;
    position: relative;
    pointer-events: none;
  }
  .tomo__kv-img img::after {
    content: "";
    border: 0;
    background-image: url(/zemi/challengeschool/tomo/_assets/img/kv_cover.png);
    line-height: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    pointer-events: none;
  }
  .tomo__kv-text {
    font-size: 16px;
    font-weight: 200;
    color: #464646;
    line-height: 1.5;
    margin-bottom: 25px;
  }
}


/*=========================
  about
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__about {
    margin-bottom: 10.667vw;
    padding-right: 5.333vw;
    padding-left: 5.333vw;
  }
  .tomo__about-title {
    font-size: 4.8vw;
    font-weight: 700;
    margin-bottom: 8vw;
    padding-left: 5.333vw;
    position: relative;
  }
  .tomo__about-title::before {
    content: "";
    border-radius: 4px;
    border-left: 5px solid #0070cb;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
  }
  .tomo__about-text {
    font-size: 3.733vw;
    font-weight: 200;
    color: #464646;
    line-height: 1.5;
    margin-bottom: 5.333vw;
  }
}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .tomo__about {
    margin-bottom: 80px;
  }
  .tomo__about-title {
    border-bottom: 1px solid #e5e5e5;
    font-size: 28px;
    font-weight: 400;
    margin-bottom: 50px;
    padding-bottom: 5px;
    padding-left: 20px;
    position: relative;
  }
  .tomo__about-title::before {
    content: "";
    border-radius: 4px;
    border-left: 6px solid #0070cb;
    margin: auto;
    position: absolute;
    top: 4px;
    bottom: 10px;
    left: 0;
  }
  .tomo__about-text {
    font-size: 16px;
    font-weight: 200;
    color: #464646;
    line-height: 1.5;
    margin-bottom: 25px;
  }
}


/*=========================
  present
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__present {
    margin-bottom: 10.667vw;
    padding-right: 5.333vw;
    padding-left: 5.333vw;
  }
  .tomo__present-head {
    margin-bottom: 5.333vw;
  }
  .tomo__present-title {
    font-size: 4.267vw;
    font-weight: 700;
    color: #0088cc;
  }
  .tomo__present-content-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .tomo__present-content {
    overflow: hidden;
    border-bottom: solid 1px #d9d9d9;
    border-radius: 5px;
    background-color: #f4f2ef;
    width: 100%;
    /* margin-right: 2%; */
  }
  .tomo__present-content:nth-child(2n) {
    margin-right: 0;
  }
  .tomo__present-cover {
    display: block;
    color: #0070cb;
  }
  .tomo__present-body {
    padding: 2.667vw 4vw 9.333vw;
  }
  .tomo__present-text {
    font-size: 3.733vw;
    font-weight: 200;
    /* color: #0070cb; */
    text-align: center;
  }
  .tomo__present-offer {
    margin-top: 5.333vw;
  }
  .tomo__present-offer-item + .tomo__present-offer-item {
    margin-top: 4vw;
  }
  .tomo__present-img {
    border: 3px solid #f4f2ef;
    padding-top: 20px;
  }
  .tomo__present-img img {
    /* border: 3px solid #f4f2ef;
    box-sizing: border-box;
    border-radius: 8px; */
    display: block;
    margin: 0 auto;
    max-width: 250px;
  }
}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .tomo__present {
    margin-bottom: 80px;
  }
  .tomo__present-head {
    margin-bottom: 30px;
  }
  .tomo__present-title {
    font-size: 16px;
    font-weight: 700;
    color: #0088cc;
  }
  .tomo__present-content-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .tomo__present-content {
    overflow: hidden;
    border-bottom: solid 1px #d9d9d9;
    border-radius: 5px;
    background-color: #f4f2ef;
    width: 17%;
    margin-right: 3.75%;
    width: 50%;
  }
  .tomo__present-cover {
    display: block;
    color: #0070cb;
  }
  .tomo__present-body {
    padding: 15px 20px 35px;
  }
  .tomo__present-text {
    font-size: 14px;
    font-weight: 200;
    /* color: #0070cb; */
    text-align: center;
  }
  .tomo__present-offer {
    margin-top: 40px;
  }
  .tomo__present-offer-item + .tomo__present-offer-item {
    margin-top: 20px;
  }
  .tomo__present-img {
    border: 3px solid #f4f2ef;
    padding-top: 20px;
  }
  .tomo__present-img img {
    /* border: 3px solid #f4f2ef;
    box-sizing: border-box;
    border-radius: 3px; */
    max-width: 250px;
    margin: 0 auto;
    display: block;
  }
}


/*=========================
  introduce
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__introduce {
    margin-bottom: 10.667vw;
    padding-right: 5.333vw;
    padding-left: 5.333vw;
  }
  .tomo__introduce-head-title {
    font-size: 4.8vw;
    font-weight: 700;
    margin-bottom: 8vw;
    padding-left: 5.333vw;
    position: relative;
  }
  .tomo__introduce-head-title::before {
    content: "";
    border-radius: 4px;
    border-left: 5px solid #0070cb;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
  }
  .tomo__introduce-text {
    font-size: 3.733vw;
    font-weight: 200;
    color: #464646;
    line-height: 1.5;
    margin-bottom: 5.333vw;
  }
}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .tomo__introduce {
    margin-bottom: 80px;
  }
  .tomo__introduce-head {
    margin-bottom: 30px;
  }
  .tomo__introduce-head-title {
    border-bottom: 1px solid #e5e5e5;
    font-size: 28px;
    font-weight: 400;
    margin-bottom: 50px;
    padding-bottom: 5px;
    padding-left: 20px;
    position: relative;
  }
  .tomo__introduce-head-title::before {
    content: "";
    border-radius: 4px;
    border-left: 6px solid #0070cb;
    margin: auto;
    position: absolute;
    top: 4px;
    bottom: 10px;
    left: 0;
  }
  .tomo__introduce-text {
    font-size: 16px;
    font-weight: 200;
    color: #464646;
    line-height: 1.5;
    margin-bottom: 25px;
  }
}


/*=========================
  flow
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__flow {
    background-color: #f4f2ee;
    padding: 10.667vw 2.667vw;
  }
  .tomo__flow-head {
    margin-bottom: 8vw;
  }
  .tomo__flow-head-title {
    border-bottom: solid 1.067vw #0070cb;
    font-size: 5.867vw;
    font-weight: 500;
    text-align: center;
    width: 53.333vw;
    margin-right: auto;
    margin-left: auto;
    padding-bottom: 1.333vw;
  }
  .tomo__flow-section {
    margin-bottom: 8vw;
  }
  .tomo__flow-section-title {
    font-size: 4.8vw;
    font-weight: 500;
    margin-bottom: 5.333vw;
  }
  .tomo__flow-content {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 1.067vw;
    background-color: #ffffff;
    padding: 13.333vw 5.333vw 5.333vw;
    position: relative;
  }
  .tomo__flow-content + .tomo__flow-content {
    margin-top: 5.333vw;
  }
  .tomo__flow-content-num {
    position: absolute;
    top: -1.867vw;
    left: 5.333vw;
  }
  .tomo__flow-content-img {
    margin-bottom: 4vw;
  }
  .tomo__flow-content-title {
    font-size: 4.8vw;
    font-weight: 400;
    margin-bottom: 4vw;
  }
  .tomo__flow-content-text {
    font-size: 3.733vw;
    font-weight: 200;
  }
}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .tomo__flow {
    background-color: #f4f2ee;
    padding: 80px 10px 40px;
  }
  .tomo__flow-head {
    margin-bottom: 30px;
  }
  .tomo__flow-head-title {
    border-bottom: solid 4px #0070cb;
    font-size: 22px;
    font-weight: 500;
    text-align: center;
    width: 200px;
    margin-right: auto;
    margin-left: auto;
    padding-bottom: 5px;
  }
  .tomo__flow-section {
    margin-bottom: 40px;
  }
  .tomo__flow-section-title {
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 20px;
  }
  .tomo__flow-content-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .tomo__flow-content {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 4px;
    background-color: #ffffff;
    width: 32%;
    padding: 50px 20px 20px;
    position: relative;
  }
  .tomo__flow-content + .tomo__flow-content {
    margin-left: 2%;
  }
  .tomo__flow-content-num {
    position: absolute;
    top: -7px;
    left: 20px;
  }
  .tomo__flow-content-img {
    margin-bottom: 15px;
  }
  .tomo__flow-content-title {
    font-size: 18px;
    font-weight: 400;
    margin-bottom: 15px;
  }
  .tomo__flow-content-text {
    font-size: 14px;
    font-weight: 200;
  }
}

/*=========================
  flow-form
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__flow-form {
    padding: 15px 15px 30px;
    margin-top: 15px;
    background-color: #fff;
    border-radius: 4px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    text-align: center;
  }
  .tomo__flow-form-txt {
    font-size: 14px;
    font-weight: normal;
    margin-bottom: 10px;
  }
  .tomo__flow-form-btn {
    margin-top: 0;
  }
  .tomo__flow-form-btn-link {
    font-size: 107%;
    padding: 12px 45px 12px 45px;
    background: #0070cb;
    color: #fff;
    position: relative;
    display: block;
    border-radius: 3px;
    text-align: center;
    -webkit-box-shadow: 0 1px 3px 0 rgba(0,0,0,0.3);
            box-shadow: 0 1px 3px 0 rgba(0,0,0,0.3);
    font-weight: bold;
    text-decoration: none;
  }
  .tomo__flow-form-btn-link::before{
    position: absolute;
    content: '';
    display: block;
    width: 26px;
    height: 24px;
    background-image: url(/zemi/challengeschool/tomo/_assets/img/_share16_icon_sprite.png);
    background-repeat: no-repeat;
    background-position: 0px -642px;
    background-size: 80px 2783px;
    margin-top: -12px;
    left: 15px;
    top: 50%;
    overflow: hidden;
  }
  .tomo__flow-form-btn-link::after {
    position: absolute;
    content: '';
    display: block;
    width: 7px;
    height: 11px;
    background-image: url(/zemi/challengeschool/tomo/_assets/img/_share16_icon_sprite.png);
    background-repeat: no-repeat;
    background-position: 0px -166px;
    background-size: 80px 2783px;
    margin-top: -5px;
    right: 10px;
    top: 50%;
    overflow: hidden;
  }

  .tomo__flow-form-accbtn-outer{
    text-align: center;
  }
  .tomo__flow-form-accbtn{
    color: #08c;
    cursor: pointer;
    margin: 15px auto 7px;
    font-size: 12px;
    display: none;
  }
  .tomo__flow-form-accbtn.is-active{
    display: block;
  }

  .tomo__flow-form-item{
    height: 0;
    max-height: 0;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    -webkit-transition-duration: 1s;
         -o-transition-duration: 1s;
            transition-duration: 1s;
    position: relative;
  }
  .tomo__flow-form-item.is-active{
    height: 100%;
    max-height: 500px;
    opacity: 1;
    visibility: visible;
    overflow: visible;
    -webkit-transition-duration: 2s;
         -o-transition-duration: 2s;
            transition-duration: 2s;
  }
  .tomo__flow-form-item-list {
    font-size: 12px;
    text-align: left;
    color: #808080;
    list-style: none;
  }
  .tomo__flow-form-item-list li {
    padding-left: 1.1em;
    position: relative;
    line-height: 1.6;
  }
  .tomo__flow-form-item-list li::before {
    content: "※";
    margin-left: 0;
    padding-right: 5px;
    position: absolute;
    left: 0;
  }
  .tomo__flow-form-offer{
    padding: 10px 15px;
  }

}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .tomo__flow-form {
    padding: 30px;
    background-color: #fff;
    border-radius: 6px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    text-align: center;
  }
  .tomo__flow-form-txt {
    font-size: 14px;
    font-weight: 200;
  }
  .tomo__flow-form-btn {
    text-align: center;
    margin-top: 20px;
  }
  .tomo__flow-form-btn-link {
    margin: 0 auto;
    padding: 20px;
    display: block;
    width: 410px;
    max-width: 400px;
    background-color: #0070cb;
    -webkit-box-shadow: 1px 2px 2px 0 rgba(0, 0, 0, 0.25);
            box-shadow: 1px 2px 2px 0 rgba(0, 0, 0, 0.25);
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    text-align: center;
    border: 0;
    cursor: pointer;
    -webkit-transition: background-color .2s,opacity .2s;
    -o-transition: background-color .2s,opacity .2s;
    transition: background-color .2s,opacity .2s;
    position: relative;
    border-radius: 5px;
    color: #fff;
    font-size: 18px;
    text-decoration: none;
  }
  .tomo__flow-form-btn-link::after {
    margin-top: -5px;
    margin: -5px auto auto;
    right: 10px;
    top: 50%;
    bottom: 0;
    overflow: hidden;
    position: absolute;
    content: '';
    display: inline-block;
    vertical-align: middle;
    background-image: url(/zemi/challengeschool/tomo/_assets/img/_share16_sprite.png);
    background-repeat: no-repeat;
    background-size: auto;
    width: 11px;
    min-width: 11px;
    max-width: 11px;
    height: 18px;
    min-height: 18px;
    max-height: 18px;
    background-position: -21px -506px;
  }
  .tomo__flow-form-btn-link-icon {
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 15px;
    width: 30px;
    min-width: 30px;
    max-width: 30px;
    height: 27px;
    min-height: 27px;
    max-height: 27px;
    background-position: -550px -368px;
    display: inline-block;
    vertical-align: middle;
    background-image: url(/zemi/challengeschool/tomo/_assets/img/_share16_sprite.png);
    background-size: auto;
  }

  .tomo__flow-form-accbtn-outer{
    text-align: center;
  }
  .tomo__flow-form-accbtn{
    color: #08c;
    cursor: pointer;
    margin: 15px auto 7px;
    font-size: 12px;
    display: none;
  }
  .tomo__flow-form-accbtn.is-active{
    display: block;
  }

  .tomo__flow-form-item{
    height: 0;
    max-height: 0;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    -webkit-transition-duration: 1s;
         -o-transition-duration: 1s;
            transition-duration: 1s;
    position: relative;
  }
  .tomo__flow-form-item.is-active{
    height: 100%;
    max-height: 500px;
    opacity: 1;
    visibility: visible;
    overflow: visible;
    -webkit-transition-duration: 2s;
         -o-transition-duration: 2s;
            transition-duration: 2s;
  }
  .tomo__flow-form-item-list {
    font-size: 12px;
    text-align: left;
    color: #808080;
    list-style: none;
  }
  .tomo__flow-form-item-list li {
    padding-left: 1.1em;
    position: relative;
    line-height: 1.6;
  }
  .tomo__flow-form-item-list li::before {
    content: "※";
    margin-left: 0;
    padding-right: 3px;
    position: absolute;
    left: 0;
  }
  .tomo__flow-form-offer{
    padding: 10px 0;
  }
}

/*=========================
  qa
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__qa {
    margin-top: 10.667vw;
    margin-bottom: 10.667vw;
    padding-right: 5.333vw;
    padding-left: 5.333vw;
  }
  .tomo__qa-head-title {
    font-size: 4.8vw;
    font-weight: 700;
    margin-bottom: 8vw;
    padding-left: 5.333vw;
    position: relative;
  }
  .tomo__qa-head-title::before {
    content: "";
    border-radius: 4px;
    border-left: 5px solid #0070cb;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
  }
  .qa__inner {
    padding: 24vw 4vw 13.333vw;
  }
  .qa__acc-content {
    border-radius: 5px;
    background-color: #f2e8c3;
  }
  .qa__acc-content:nth-child(2n) {
    background-color: #faf9dd;
  }
  .qa__acc-content + .qa__acc-content {
    margin-top: 4vw;
  }
  .qa__acc-head {
    padding: 4vw 8vw 4vw 13.333vw;
    position: relative;
  }
  .qa__acc-head::before {
    content: "";
    background-image: url(/zemi/challengeschool/test/img/dance/icon-q.svg);
    background-repeat: no-repeat;
    width: 6.933vw;
    height: 6.933vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 3.2vw;
  }
  .qa__acc-head::after {
    content: "";
    background-image: url(/zemi/challengeschool/tomo/_assets/img/qa_icon_02.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 3.467vw;
    height: 3.467vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 3.2vw;
  }
  .qa__acc .qa__acc-head.is_qa-active::after {
    content: "";
    background-image: url(/zemi/challengeschool/tomo/_assets/img/qa_icon_03.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 3.467vw;
    height: 3.467vw;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 3.2vw;
    opacity: 1;
    transition-duration: .3s;
  }

  .qa__acc-title {
    font-size: 4vw;
    font-weight: 700;
    color: #000000;
    line-height: 1.5;
    letter-spacing: 0.04em;
  }
  .qa__acc-text {
    font-size: 3.733vw;
    font-weight: 400;
    color: #000000;
    line-height: 1.8;
    letter-spacing: 0.04em;
    margin: 2.667vw 4.8vw 4.8vw;
  }
  .qa__acc-body {
    line-height: 0;
    height: 0;
    overflow: hidden;
    opacity: 0;
    transition-duration: .3s;
    }
  .qa__acc-body.is_qa-open{
    line-height: normal; 
    height: auto;
    opacity: 1;
    transition-duration: .3s;

  }


}






/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .tomo__qa-head {
    margin-bottom: 30px;
  }
  .tomo__qa-head-title {
    border-bottom: 1px solid #e5e5e5;
    font-size: 28px;
    font-weight: 400;
    margin-bottom: 50px;
    padding-bottom: 5px;
    padding-left: 20px;
    position: relative;
  }
  .tomo__qa-head-title::before {
    content: "";
    border-radius: 4px;
    border-left: 6px solid #0070cb;
    margin: auto;
    position: absolute;
    top: 4px;
    bottom: 10px;
    left: 0;
  }

  .tomo__qa-inner {
    width: 86%;
    margin-right: auto;
    margin-left: auto;
    padding-top: 70px;
    padding-bottom: 120px;
  }
  .qa__acc-content {
    border-radius: 5px;
    background-color: #f2e8c3;
  }
  .qa__acc-head {
    padding: 22px 75px 22px 115px;
    position: relative;
    cursor: pointer;
  }
  .qa__acc-head::before {
    content: "";
    background-image: url(/zemi/challengeschool/test/img/dance/icon-q.svg);
    background-repeat: no-repeat;
    width: 37px;
    height: 36px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 54px;
  }
  .qa__acc-title {
    font-size: 20px;
    font-weight: 700;
    color: #000000;
    line-height: 1.5;
    letter-spacing: 0.04em;
  }
  .qa__acc-head::after {
    content: "";
    background-image: url(/zemi/challengeschool/tomo/_assets/img/qa_icon_02.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    
    width: 27px;
    height: 26px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 40px;
  }
  .qa__acc .qa__acc-head.is_qa-active::after {
    content: "";
    background-image: url(/zemi/challengeschool/tomo/_assets/img/qa_icon_03.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 27px;
    height: 26px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 40px;
    opacity: 1;
    transition-duration: .3s;
  }

  .qa__acc-content + .qa__acc-content {
    margin-top: 16px;
  }
  .qa__acc-content:nth-child(2n) {
    background-color: #faf9dd;
  }
  .qa__acc-title {
    font-size: 20px;
    font-weight: 700;
    color: #000000;
    line-height: 1.5;
    letter-spacing: 0.04em;
  }

  .qa__acc-body {
    line-height: 0;
    height: 0;
    overflow: hidden;
    opacity: 0;
    transition-duration: .3s;
    }
  .qa__acc-body.is_qa-open{
    line-height: normal; 
    height: auto;
    opacity: 1;
    transition-duration: .3s;

  }
  .qa__acc-text {
    font-size: 16px;
    font-weight: 400;
    color: #000000;
    line-height: 1.8;
    letter-spacing: 0.04em;
    margin: 10px 115px 20px;
  }
}

.js_qa-accordion-title.is_qa-active::after{
  opacity: 0;
}









/*=========================
  contact
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .contact{
    color: #fff;
    background-color: #1450C4;
  }
  .contact-inner{
    margin: 0 30px;
    padding: 30px 0;
  }
  .contact__ttl{
    font-size: 16px;
    font-weight: bold;
    position: relative;
    text-align: center;
    margin-bottom: 15px;
  }
  .contact__ttl::before,
  .contact__ttl::after{
    content: "";
    background-repeat: no-repeat;
    background-size: contain;
    width: 9px;
    height: 22px;
    position: absolute;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
  }
  .contact__ttl::before {
    background-image: url(/zemi/challengeschool/_shared/img/line_contact_left.svg);
    left: 0;
  }
  .contact__ttl::after {
    background-image: url(/zemi/challengeschool/_shared/img/line_contact_right.svg);
    right: 0;
  }
  .contact__note{
    font-size: 10px;
    margin-top: 5px;
    margin-bottom: 10px;
  }
  .contact__txt{
    font-size: 11px;
    text-align: center;
  }
  .contact__txt-link{
    text-decoration: underline;
    color: #fff;
  }
}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .contact{
    color: #fff;
    background-color: #1450C4;
  }
  .contact-inner{
    width: 504px;
    margin: 0 auto;
    padding: 60px 0;
  }
  .contact__ttl{
    font-size: 26px;
    font-weight: bold;
    position: relative;
    text-align: center;
    margin-bottom: 20px;
  }
  .contact__ttl::before,
  .contact__ttl::after{
    content: "";
    background-repeat: no-repeat;
    background-size: contain;
    width: 17px;
    height: 40px;
    position: absolute;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
  }
  .contact__ttl::before {
    background-image: url(/zemi/challengeschool/_shared/img/line_contact_left.svg);
    left: 0;
  }
  .contact__ttl::after {
    background-image: url(/zemi/challengeschool/_shared/img/line_contact_right.svg);
    right: 0;
  }
  .contact__note{
    font-size: 16px;
    margin-top: 15px;
    margin-bottom: 20px;
  }
  .contact__txt{
    font-size: 18px;
    text-align: center;
  }
  .contact__txt-link{
    text-decoration: underline;
    color: #fff;
  }
}


/*=========================
  modal
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .modal {
    display: none;
    overflow: scroll;
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
  }
  .modal__cover {
    background: rgba(0, 0, 0, .5);
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
  }
  .modal__content {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 4px;
    background-color: #ffffff;
    width: 90%;
    height: 70vh;
    margin: auto;
    padding: 4vw;
    position: absolute;
    top: 15%;
    right: 0;
    left: 0;
    overflow-x: hidden;
    overflow-y: scroll;
  }
  .modal__close {
    position: absolute;
    top: 2vw;
    right: 2vw;
  }
  .modal-title {
    font-size: 5.333vw;
    font-weight: 400;
    margin-bottom: 5.333vw;
  }
  .modal-text {
    font-size: 3.733vw;
    font-weight: 400;
    margin-bottom: 2.667vw;
  }
  .modal-text--red {
    font-weight: 700;
    color: #ff0000;
    text-decoration: underline;
  }
  .modal-text-strong {
    font-weight: 700;
  }
  .modal__content-item + .modal__content-item {
    margin-top: 4vw;
  }
  .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-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 + .modal__btn-item {
    margin-top: 3.2vw;
  }
  .modal__btn + .modal__btn {
    margin-top: 3.2vw;
  }

}
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .modal {
    display: none;
    overflow: scroll;
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
  }
  .modal__cover {
    background: rgba(0, 0, 0, .5);
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
  }
  .modal__content {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 4px;
    background-color: #ffffff;
    width: 915px;
    margin: auto;
    padding: 70px;
    position: absolute;
    top: 25%;
    right: 0;
    left: 0;
  }
  .modal__close {
    position: absolute;
    top: -15px;
    right: -15px;
  }
  .modal__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .modal__list-item {
    width: 48%;
  }
  .modal__list-item + .modal__list-item {
    margin-left: 4%;
  }
  .modal-title {
    font-size: 24px;
    font-weight: 400;
    margin-bottom: 20px;
  }
  .modal-text {
    font-size: 14px;
    font-weight: 400;
    margin-bottom: 10px;
  }
  .modal-text--red {
    font-weight: 700;
    color: #ff0000;
    text-decoration: underline;
  }
  .modal-text-strong {
    font-weight: 700;
  }
  .modal__content-item + .modal__content-item {
    margin-top: 15px;
  }
  .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;
    margin-top: 20px;
  }
  .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-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--long {
    padding: 17px;
  }
  .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: 18px;
  }
  .modal__btn-link--long .modal__btn-item-strong {
    font-size: 16px;
  }
  .modal__btn-item:nth-child(2) {
    margin-left: 20px;
  }
  .modal__btn-item:hover .modal__btn-link {
    opacity: 0.7;
    transform: translateY(4px);
  } 
}

/*=========================
  2023/1/10追記
=========================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .modal__btn {
    width: 720px;
  }
  .modal__btn-item {
    width: 350px;
  }
  .header-logo-img {
    width: 110px;
  }
  .header-logo-link + .header-logo-link .header-logo-img {
    width: 246px;
    margin-top: 5px;
  }
  .breadcrumb {
    margin-top: 90px;
  }
  .header__acc-box {
    margin-top: 90px;
  }
  .header__acc-btn-link {
    padding: 18px 0;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .header-logo-img {
    width: 20vw;
  }
  .header-logo-link + .header-logo-link .header-logo-img {
    width: 38vw;
    margin-top: 0.4vw;
  }
  .header__acc-box {
    margin-top: 18.667vw;
  }
  .header__acc-btn-link {
    font-size: 3.2vw;
    padding: 4.5vw 1.3vw;
    text-align: center;
  }
}

/*=========================
  2023/3/7追記
=========================*/
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__kv-text {
    margin-bottom: 5.333vw;
  }
}

/*=========================
  2023/8/1追記
=========================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .tomo__present-bnr {
    width: 480px;
  }
  .tomo__present-detail {
    display: block;
    font-size: 11px;
    margin-top: 10px;
    width: max-content;
    color: #000;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .tomo__present-detail {
    display: block;
    font-size: 3vw;
    margin-top: 10px;
    width: max-content;
    color: #000;
  }
}

/*=========================
  2023/10/25追記
=========================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  .modal__content--cv {
    width: auto;
    max-width: 960px;
    max-height: 80vh;
    padding: 60px 40px;
    top: 50%;
    transform: translateY(-50%);
    overflow-y: auto;
    overflow-x: hidden;
  }
  .modal__content--cv .modal__close {
    top: 15px;
    right: 15px;
    cursor: pointer;
  }
  .modal__btn {
    width: auto;
    margin-top: 0px;
    justify-content: center;
    align-items: center;
    gap: 24px 20px;
  }
  .modal__btn-item {
    width: 250px;
  }
  .modal__btn-item-strong {
    font-size: 24px;
  }
  .modal__btn + .modal__btn {
    margin-top: 24px;
  }
  .modal__btn-item:nth-child(2) {
    margin-left: 0;
  }
  .modal__btn-item + .modal__btn-item {
    margin-left: 20px;
  }
  .modal__btn-item:nth-of-type(4) {
    margin-left: 0;
  }
  .js-grade-button {
    cursor: pointer;
  }
  .js-grade-filter li {
    display: none;
  }
  .js-genre-filter li {
    display: none;
  }
  .modal__btn-item--noclick {
    pointer-events: none;
  }
  .modal__btn-item--noclick .modal__btn-link {
    background-color: #aaa;
  }
  .modal__title-two {
    font-size: 24px;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 30px;
  }
  .modal__title-two-offer {
    text-align: center;
    margin-top: 30px;
    margin-bottom: 30px;
  }
  .modal-cost-link-area {
    text-align: center;
    margin: 20px auto auto;
  }
  .modal-cost-link {
    color: #0066C0;
  }
  .modal-cost-txt-area {
    font-size: 14px;
    margin-top: 30px;
  }
  #modal-cv-free .modal__title {
    color: #E5465A;
  }
  #modal-cv-free .modal__title-two {
    color: #E5465A;
  }
  #modal-cv-free .modal__btn-link {
    background-color: #E5465A;
  }

  #modal-cv-free .modal__btn.madal__btn-grade {
    display: grid;
    grid-template-columns: repeat(auto-fit, max(250px));
    justify-content: center;
  }
  #modal-cv-free .modal__btn.madal__btn-grade .modal__btn-item {
    width: 100%;
  }
  #modal-cv .modal__btn.madal__btn-grade {
    display: grid;
    grid-template-columns: repeat(auto-fit, max(250px));
    justify-content: center;
  }
  #modal-cv .modal__btn.madal__btn-grade .modal__btn-item {
    width: 100%;
  }
  #modal-cv-free .modal__btn-item + .modal__btn-item {
    margin: 0;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  .modal__content--cv {
    max-height: 70vh;
    padding: 5.33333vw;
    top: 50%;
    transform: translateY(-50%);
    overflow-y: auto;
    overflow-x: hidden;
  }
  .modal__content--cv .modal__close {
    top: 2vw;
    right: 2vw;
  }
  .modal__title {
    /* font-size: 4.5vw; */
  }
  .modal__btn {
    padding: 0;
    justify-content: space-between;
    align-items: center;
    gap: 3.2vw 2%;
  }
  .modal__btn-item {
    width: 48%;
  }
  .modal__btn-item + .modal__btn-item {
    margin-top: 0;
  }
  .modal__btn-item--center {
    margin: 0 auto;
  }
  .modal__btn-link {
    padding: 4.5vw;
  }
  .js-grade-filter li {
    display: none;
  }
  .js-genre-filter li {
    display: none;
  }
  .modal__btn-item--noclick {
    pointer-events: none;
  }
  .modal__btn-item--noclick .modal__btn-link {
    background-color: #aaa;
  }
  .modal__title-two {
    font-size: 4.26666666vw;
    font-weight: 600;
    color: #004fa8;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 5.33333333vw;
  }
  .modal__title-two-offer {
    font-size: 4vw;
    margin-bottom: 5.33333333vw;
    text-align: center;
  }
  .modal-cost-link-area {
    text-align: center;
    margin: 4vw auto auto;
  }
  .modal-cost-link {
    color: #0066C0;
  }
  .modal-cost-txt-area {
    font-size: 3vw;
    margin-top: 5vw;
  }
  #modal-cv-free .modal__title {
    color: #E5465A;
  }
  #modal-cv-free .modal__title-two {
    color: #E5465A;
  }
  #modal-cv-free .modal__btn-link {
    background-color: #E5465A;
  }
  #modal-cv-free .modal__btn-link {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #E5465A;
    height: 100%;
    box-sizing: border-box;
  }


  #modal-cv-free .modal__btn.madal__btn-grade {
    display: grid;
    grid-template-columns: repeat(auto-fit, max(48%));
    justify-content: center;
    gap: 3.2vw 4%;
    align-items: stretch;
  }
  #modal-cv-free .modal__btn.madal__btn-grade .modal__btn-item {
    width: 100%;
  }
  #modal-cv .modal__btn.madal__btn-grade {
    display: grid;
    grid-template-columns: repeat(auto-fit, max(48%));
    justify-content: center;
    gap: 3.2vw 4%;
    align-items: stretch;
  }
  #modal-cv .modal__btn.madal__btn-grade .modal__btn-item {
    width: 100%;
  }
  #modal-cv .modal__btn.madal__btn-grade .modal__btn-link {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    box-sizing: border-box;
  }
  #modal-cv-free .modal__btn-item + .modal__btn-item {
    margin: 0;
  }
}

/*=========================
  2023/12/21追記
=========================*/
/*===== PC =====*/
@media only screen and (min-width: 769px), print, tv {
  #modal .modal__content {
    padding: 50px;
  }
  #modal .modal__btn-item + .modal__btn-item {
    margin-left: 0;
  }
  #modal .modal__btn-item-strong {
    font-size: 18px;
  }
  #modal .modal__btn-link::after {
    right: 15px;
  }
  .modal .modal__btn-item.no-push__btn {
    box-shadow: 0px 4px 0px 0px #e2e2e2!important;
    pointer-events: none!important;
  }
  .modal .no-push__btn .modal__btn-link{
    pointer-events: none!important;
    background-color: #888888!important;
    opacity: 1!important;
    transform: translateY(0)!important;
  }
}
/*===== SP =====*/
@media only screen and (max-width: 768px) {
  #modal .modal__btn-link {
    line-height: 1.2;
  }
  .modal .modal__btn-item.no-push__btn {
    box-shadow: 0px 4px 0px 0px #e2e2e2!important;
    pointer-events: none!important;
  }
  .modal .no-push__btn .modal__btn-link{
    pointer-events: none!important;
    background-color: #888888!important;
    opacity: 1!important;
    transform: translateY(0)!important;
  }
}