@charset "UTF-8";
/* icon font */
/* ==================================
 * 締切
 * ================================== */
 .simekiri {
  background: #ffed26;
  color: #df2c00;
}
.simekiri p {
  text-align: center;
  font-weight: bold;
  padding: 1rem;
  font-size: 1.7rem;
}
.simekiri p span{
  font-size: 2rem;
}
 @media screen and (max-width: 768px) {
.simekiri p {
  font-size: 1rem;
}
.simekiri p span{
  font-size: 1.3rem;
}
}

/* ==================================
 * COURSE | 講習パーツ
 * ================================== */

 .campaign_info_box
{
  transition: ease 200ms;
  display: block;
    width: 100%;
    max-width: 52.5rem;
    height: auto;
    margin: auto;
}
.campaign_info_box:hover
{
  opacity: 0.7;
}
@media screen and (max-width: 767px){
.campaign_info_box {
    width: 32.5rem;
    margin: 0 auto;
    display: block;
}
}

.coursekv {
  position: relative;
}
.coursekv__img {
  height: 40rem;
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
  z-index: 0;
  will-change: opacity;
  -webkit-transition: opacity ease 600ms;
  transition: opacity ease 600ms;
}
@media screen and (max-width: 767px) {
  .coursekv__img {
    height: auto;
    width: 100%;
  }
}
.coursekv__img picture,
.coursekv__img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  /* object-fit for IE */
  font-family: "object-fit: cover;";
}
@media screen and (min-width: 768px) {
  .coursekv__ttl {
    position: absolute;
    /*left: 13rem;萩原さんの時 */
    left: 5rem;
    width: 52.6rem;
    top: 42%;
    -webkit-transform: translateY(-40%);
            transform: translateY(-40%);
    -webkit-transition: cubic-bezier(0.165, 0.84, 0.44, 1) 1200ms;
    transition: cubic-bezier(0.165, 0.84, 0.44, 1) 1200ms;
  }
}
@media screen and (max-width: 767px) {
  .coursekv__ttl {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    -webkit-transition: cubic-bezier(0.165, 0.84, 0.44, 1) 1200ms;
    transition: cubic-bezier(0.165, 0.84, 0.44, 1) 1200ms;
  }
}
.coursekv__ttl img,
.coursekv__ttl picture {
  display: block;
  position: relative;
  z-index: 10;
  width: 100%;
  margin: 0;
}
@media screen and (min-width: 768px) {
  .coursekv__ttl img,
.coursekv__ttl picture {
    width: calc(100% + 1.2rem);
    margin: 0 -0.5rem 0 -0.7rem;
  }
}
.coursekv__ttl__copy {
font-size: 3.7rem;
  /* line-height: 1.5; */
  font-weight: 700;
  text-align: center;
  padding-top: 1.8rem;
  white-space: nowrap;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
    .coursekv__ttl__copy {
        padding-top: 1.35rem;
        font-size: 2.3rem;
        margin-bottom: 1.8rem;
    }
}
.coursekv__ttl__copy strong {
  color: #D13C18;
}
.coursekv__ttl__copy .cross {
  display: inline-block;
  position: relative;
  width: 1em;
  height: 1em;
  margin: 0 0.2em -0.1em;
}
.coursekv__ttl__copy .cross::before, .coursekv__ttl__copy .cross::after {
  content: "";
  width: 110%;
  height: 4px;
  position: absolute;
  top: calc( 50% - 2px);
  left: -5%;
  background: #D13C18;
}
@media screen and (max-width: 767px) {
  .coursekv__ttl__copy .cross::before, .coursekv__ttl__copy .cross::after {
    height: 2px;
    top: calc(50% - 1px);
  }
}
.coursekv__ttl__copy .cross::before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-animation: crossBarSpin01 3s cubic-bezier(0.165, 0.84, 0.44, 1) 0ms infinite both;
          animation: crossBarSpin01 3s cubic-bezier(0.165, 0.84, 0.44, 1) 0ms infinite both;
}
.coursekv__ttl__copy .cross::after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-animation: crossBarSpin02 3s cubic-bezier(0.165, 0.84, 0.44, 1) 25ms infinite both;
          animation: crossBarSpin02 3s cubic-bezier(0.165, 0.84, 0.44, 1) 25ms infinite both;
}
.coursekv__ttl__copy .yakuhan {
  display: inline-block;
  margin: 0 -0.4em;
}
@media screen and (min-width: 768px) {
  .coursekv__ttl__copy .shadow {
    display: inline-block;
    position: relative;
    z-index: -1;
    -webkit-filter: drop-shadow(0 0 4rem #FFE8DB) drop-shadow(0 0 4rem #FFE8DB) drop-shadow(0 0 4rem #FFE8DB);
            filter: drop-shadow(0 0 4rem #FFE8DB) drop-shadow(0 0 4rem #FFE8DB) drop-shadow(0 0 4rem #FFE8DB);
  }
}
.coursekv__inner {
  z-index: 1;
  width: calc( 100% - 8rem);
  margin: 0 auto;
  border-radius: 3rem;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 767px) {
  .coursekv__inner {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    padding: 0 2.5rem;
  }
}
/* 講習時のKVのフィルター */
@media screen and (min-width: 768px) {
  .coursekv__inner > * {
    -webkit-filter: blur(5px);
            filter: blur(5px);
  }
}
@media screen and (max-width: 767px) {
  .coursekv__inner .coursekv__img {
    overflow: hidden;
    z-index: 1;
    border-radius: 1rem;
    /*padding-top: 21rem; 三浦翔平以外の時 */
  }
  .coursekv__inner .coursekv__img picture {
    -webkit-filter: blur(5px);
            filter: blur(5px);
  }
}
.coursekv--ended__message {
  position: absolute;
  z-index: 10;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  border: 4px solid #D13C18;
  text-align: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #D13C18;
  background: #fff;
  border-radius: 2rem;
  font-size: 2.8rem;
  line-height: 1.5;
  letter-spacing: 0;
  padding: 3rem 4rem;
  font-weight: 600;
  white-space: nowrap;
}
@media screen and (max-width: 1023px) {
  .coursekv--ended__message {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 767px) {
  .coursekv--ended__message {
    font-size: 1.8004rem;
  }
}
@media screen and (max-width: 767px) {
  .coursekv--ended__message {
    padding: 1rem 2rem;
    border-width: 0.2rem;
    top: 75%;
    border-radius: 1rem;
  }
}
.coursekv--ended__message.cfi {
  opacity: 0;
  -webkit-transition: opacity ease 600ms 200ms;
  transition: opacity ease 600ms 200ms;
}
.coursekv--ended__message.cfi.frame-in {
  opacity: 1;
}

.coursecv {
  padding: 5rem 0 0;
}
@media screen and (max-width: 767px) {
  .coursecv {
    padding: 2.5rem 0 0;
  }
}
.coursecv__ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 2.5rem;
}
.coursecv__ttl span {
  position: relative;
  display: block;
  margin: 0 auto;
  line-height: 1;
}
.coursecv__ttl span::before, .coursecv__ttl span::after {
  content: "";
  width: 3px;
  height: 100%;
  display: block;
  background: currentColor;
  position: absolute;
  bottom: 0;
  -webkit-transform-origin: bottom;
          transform-origin: bottom;
  border-radius: 9999px;
}
@media screen and (max-width: 767px) {
  .coursecv__ttl span::before, .coursecv__ttl span::after {
    height: 85%;
    width: 0.3rem;
  }
}
.coursecv__ttl span::before {
  left: -1rem;
  -webkit-transform: rotate(-25deg);
          transform: rotate(-25deg);
}
@media screen and (max-width: 767px) {
  .coursecv__ttl span::before {
    -webkit-transform: rotate(-22.5deg);
            transform: rotate(-22.5deg);
    left: -0.65rem;
  }
}
.coursecv__ttl span::after {
  right: -1rem;
  -webkit-transform: rotate(25deg);
          transform: rotate(25deg);
}
@media screen and (max-width: 767px) {
  .coursecv__ttl span::after {
    -webkit-transform: rotate(22.5deg);
            transform: rotate(22.5deg);
    right: -0.65rem;
  }
}
.coursecv__inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  .coursecv__main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .coursecv__main__img {
    width: 50.3vw;
    margin-right: 3rem;
  }
  .coursecv__main__img picture,
.coursecv__main__img img {
    display: block;
    width: 100%;
  }
  .coursecv__main__detail {
    width: 40.7vw;
  }
  .coursecv__main__detail img {
    display: block;
    width: 100%;
    margin-bottom: 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  .coursecv__main {
    padding: 2.5rem;
  }
  .coursecv__main img {
    display: block;
    width: 100%;
    margin-bottom: 2rem;
  }
  .coursecv__main__img {
    width: 100vw;
    margin: 0 calc( (100% - 100vw) *.5);
  }
}
.coursecv__btn {
  border-radius: 0.6rem;
  width: 100%;
  min-height: 10rem;
  max-width: 100%;
  padding: 1rem 4rem;
  position: relative;
  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;
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.2;
  letter-spacing: 0;
  color: #fff;
  background: #ffb31a;
  font-size: 2.8rem;
}
@media screen and (max-width: 1023px) {
  .coursecv__btn {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .coursecv__btn {
    font-size: 1.296rem;
  }
}
@media screen and (min-width: 768px) {
  .coursecv__btn:hover::after {
    -webkit-transform: translateX(2px);
            transform: translateX(2px);
  }
  .coursecv__btn.back:hover::after {
    -webkit-transform: translateX(-2px);
            transform: translateX(-2px);
  }
}
@media screen and (max-width: 767px) {
  .coursecv__btn {
    width: 100%;
    min-height: 5rem;
    padding-left: 1.5rem;
  }
}
.coursecv__btn::after {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #fff;
  font-size: 0.8em;
  content: "";
  position: absolute;
  right: 2rem;
  -webkit-transition: ease 200ms;
  transition: ease 200ms;
}
.coursecv__btn.back::after {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 0.8em;
  content: "";
  position: absolute;
  right: auto;
  left: 2rem;
}
@media screen and (max-width: 767px) {
  .coursecv__btn.back {
    padding-left: 4rem;
    padding-right: 1.5rem;
  }
}
@media screen and (min-width: 768px) {
  .coursecv__btn {
    -webkit-transition: ease 200ms;
    transition: ease 200ms;
  }
  .coursecv__btn:after {
    -webkit-transition: ease 200ms;
    transition: ease 200ms;
  }
  .coursecv__btn:hover {
    background: #FFD726;
  }
  .coursecv__btn:hover:after {
    -webkit-transform: translateX(2px);
            transform: translateX(2px);
  }
}
.coursecv__bnr {
  display: block;
  margin: 0 auto;
}
.coursecv__bnr picture,
.coursecv__bnr img {
  display: block;
  max-width: 100%;
}
@media screen and (min-width: 768px) {
  .coursecv__bnr {
    -webkit-transition: opacity ease 200ms;
    transition: opacity ease 200ms;
  }
  .coursecv__bnr:hover {
    opacity: 0.7;
  }
}
.coursecv.winter .coursecv__main {
  background: url(/img/specialcourse/bg_stripe_winter.png) repeat;
  background-size: 0.8rem;
}
.coursecv.summer .coursecv__main {
  background: url(/img/specialcourse/bg_stripe_summer.png) repeat;
  background-size: 0.8rem;
}
.coursecv.spring .coursecv__main {
  background: url(/img/specialcourse/bg_stripe_spring.png) repeat;
  background-size: 0.8rem;
}

.coursereason {
  padding: 8rem 0;
  background: url(/img/bg_stripe02.png) repeat;
  background-size: 0.8rem;
}
@media screen and (max-width: 767px) {
  .coursereason {
    padding: 5rem 0;
  }
}
.coursereason__inner {
  max-width: 86rem;
  margin: 0 auto;
  padding: 0 3rem;
}
@media screen and (max-width: 767px) {
  .coursereason__inner {
    padding: 0 2.5rem;
  }
}
.coursereason__ttl__balloon {
  width: 39.5rem;
  line-height: 5.1rem;
  position: relative;
  border-radius: 9999px;
  background: #D13C18;
  color: #fff;
  text-align: center;
  font-size: 2.4rem;
  white-space: normal;
  margin: 0 auto 1.2rem;
  -webkit-transition: cubic-bezier(0.165, 0.84, 0.44, 1) 1200ms;
  transition: cubic-bezier(0.165, 0.84, 0.44, 1) 1200ms;
  -webkit-transform: translateY(3rem);
          transform: translateY(3rem);
}
@media screen and (max-width: 767px) {
  .coursereason__ttl__balloon {
    font-size: 1.6rem;
    line-height: 3.15rem;
    width: 25rem;
  }
}
.coursereason__ttl__balloon:after {
  content: "";
  display: block;
  border-width: 1.2rem 0.85rem 0 0.85rem;
  border-style: solid;
  border-color: #D13C18 transparent transparent;
  position: absolute;
  top: 100%;
  left: calc(50% - 0.85rem);
}
@media screen and (max-width: 767px) {
  .coursereason__ttl__balloon:after {
    border-width: 0.8rem 0.4rem 0 0.4rem;
    left: calc(50% - 0.4rem);
  }
}
.coursereason__ttl.frame-in .coursereason__ttl__balloon {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.coursereason__subttl {
  position: relative;
}
.coursereason__subttl__icon {
  position: absolute;
  right: 0;
  top: 0;
}
.coursereason__subttl__icon.tablet {
  width: 10.5rem;
}
@media screen and (max-width: 767px) {
  .coursereason__subttl__icon.tablet {
    width: 6.5rem;
    top: 1rem;
  }
}
.coursereason__subttl__icon.test {
  width: 7rem;
}
@media screen and (max-width: 767px) {
  .coursereason__subttl__icon.test {
    width: 4.5rem;
    top: 1rem;
  }
}
.coursereason__subttl__icon.guarantee {
  width: 6rem;
}
@media screen and (max-width: 767px) {
  .coursereason__subttl__icon.guarantee {
    width: 3.75rem;
  }
}
.coursereason__subttl__icon.pen {
  width: 3.5rem;
}
@media screen and (max-width: 767px) {
  .coursereason__subttl__icon.pen {
    width: 2.25rem;
  }
}
.coursereason__subttl__icon.check {
  width: 3.75rem;
}
@media screen and (max-width: 767px) {
  .coursereason__subttl__icon.check {
    width: 2.4rem;
  }
}
.coursereason__subttl__icon.balloon {
  width: 3.8rem;
}
@media screen and (max-width: 767px) {
  .coursereason__subttl__icon.balloon {
    width: 2.5rem;
  }
}
.coursereason__subttl__icon.mechanism {
  width: 4.2rem;
}
@media screen and (max-width: 767px) {
  .coursereason__subttl__icon.mechanism {
    width: 2.75rem;
  }
}
@media screen and (max-width: 767px) {
  .coursereason__subttl__icon {
    width: 5rem;
  }
}
.coursereason__desc {
  padding-bottom: 4rem;
  border-bottom: 0.3rem solid #D13C18;
}
@media screen and (min-width: 768px) {
  .coursereason__desc__inner {
    padding: 0 5rem;
  }
}
.coursereason__desc__inner:not(:last-child) {
  margin-bottom: 3rem;
}
.coursereason__desc:not(:last-child) {
  margin-bottom: 4rem;
}
.coursereason__desc__player {
  margin-top: 4rem;
}
.coursereason__desc__btn-container {
  padding-top: 1.8rem;
}
.coursereason__desc__btn-container a {
  margin: 0 auto;
}
.coursereason__pop {
  padding: 4rem 5rem;
  background: #fff;
  border-radius: 1rem;
  -webkit-filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
  margin: 0;
}
@media screen and (max-width: 767px) {
  .coursereason__pop {
    padding: 2rem 2.5rem;
  }
}
.coursereason__pop__ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.coursereason__pop__ttl__icon {
  width: 6.9rem;
  height: 6.9rem;
  border-radius: 9999px;
  background: #D13C18;
  color: #FFD726;
  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;
  text-align: center;
  font-size: 2.4rem;
  margin-right: 1.8rem;
}
@media screen and (max-width: 767px) {
  .coursereason__pop__ttl__icon {
    font-size: 1.65rem;
    width: 4.5rem;
    height: 4.5rem;
    margin-right: 0.9rem;
  }
}
.coursereason__pop__ttl span.yakuhan {
  text-indent: -0.5em;
}
.coursereason__pop__ttl .small {
  font-size: 0.7692em;
}
@media screen and (max-width: 767px) {
  .coursereason__pop__ttl__txt {
    font-size: 1.6rem;
  }
  .coursereason__pop__ttl__txt .small {
    font-size: 1.4rem;
  }
}
.coursereason__morebtn {
  margin: 0 auto;
}
.coursereason__morebtn__container {
  padding-top: 6rem;
}

.courseprogram {
  padding: 8rem 0;
  background: url(/img/bg_stripe01.png) repeat;
  background-size: 0.8rem;
}
@media screen and (max-width: 767px) {
  .courseprogram {
    padding: 5rem 0 0;
  }
}
.courseprogram__inner {
  max-width: 86rem;
  margin: 0 auto;
  padding: 0 3rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__inner {
    padding: 0 2.5rem;
  }
}
.courseprogram__detail {
  background: #fff;
  padding: 6rem 5rem;
  border-radius: 0.6rem;
  -webkit-filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail {
    padding: 3rem 1.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .courseprogram__detail {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail {
    font-size: 1.4rem;
  }
}
.courseprogram__detail section {
  background: #fff;
  -webkit-filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
  border-radius: 1rem;
  padding: 5rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail section {
    padding: 3.5rem 2rem;
  }
}
.courseprogram__detail section + section {
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail section + section {
    margin-top: 2rem;
  }
}
.courseprogram__detail section > *:first-child {
  margin-top: 0;
}
.courseprogram__detail h2 {
  font-size: 2.8rem;
  line-height: 1.5;
  font-weight: 700;
  padding-left: 1.8rem;
  position: relative;
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail h2 {
    font-size: 1.8rem;
    padding-left: 1rem;
    margin-bottom: 2.5rem;
  }
}
.courseprogram__detail h2:not(:first-child) {
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail h2:not(:first-child) {
    margin-top: 3.5rem;
  }
}
.courseprogram__detail h2:before {
  content: "";
  display: block;
  width: 4px;
  border-radius: 99px;
  background: #D13C18;
  height: calc( 100% - .4em);
  position: absolute;
  top: 0.2em;
  left: 0;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail h2:before {
    width: 0.3rem;
  }
}
.courseprogram__detail h3 {
  font-size: 2rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  margin-bottom: 2rem;
}
@media screen and (max-width: 1023px) {
  .courseprogram__detail h3 {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail h3 {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail h3 {
    margin-bottom: 1.5rem;
  }
}
.courseprogram__detail h3:not(:first-child) {
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail h3:not(:first-child) {
    margin-top: 2.5rem;
  }
}
.courseprogram__detail h4 {
  font-weight: 700;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail h4 {
    margin-bottom: 1.5rem;
  }
}
.courseprogram__detail h4:not(:first-child) {
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail h4:not(:first-child) {
    margin-top: 2.5rem;
  }
}
.courseprogram__detail p {
  margin-top: 2rem;
}
.courseprogram__detail ul,
.courseprogram__detail ol {
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail ul,
.courseprogram__detail ol {
    margin-top: 2rem;
  }
}
.courseprogram__detail ol {
  counter-reset: orderlist;
}
.courseprogram__detail ol li {
  padding-left: 1.5em;
  counter-increment: orderlist;
  text-indent: -1.5em;
}
.courseprogram__detail ol li:not(:last-child) {
  margin-bottom: 1rem;
}
.courseprogram__detail ol li:before {
  content: counter(orderlist) ".";
  width: 1.5em;
  display: inline-block;
  text-indent: 0;
}
.courseprogram__detail ul li {
  padding-left: 1em;
  position: relative;
}
.courseprogram__detail ul li:before {
  content: "";
  height: 6px;
  width: 6px;
  border-radius: 9999px;
  position: absolute;
  background: #D13C18;
  left: 0.2em;
  top: calc( 1.75em * 0.5 - 2px);
}
.courseprogram__detail ul li:not(:last-child) {
  margin-bottom: 0.1em;
}
.courseprogram__detail li ul,
.courseprogram__detail li ol {
  margin: 0.1em 0 0.5em;
  padding-left: 1em;
}
.courseprogram__detail a {
  color: #D13C18;
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .courseprogram__detail a {
    -webkit-transition: ease 200ms;
    transition: ease 200ms;
  }
  .courseprogram__detail a:hover {
    opacity: 0.7;
  }
}
.courseprogram__detail table {
  max-width: 100%;
  width: 60rem;
  margin: 1.5rem auto 0;
  border-style: solid;
  border-width: 2px 0 2px;
  border-color: #D13C18;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail table {
    width: 100%;
    border-width: 0.1rem 0 0.1rem;
    margin-top: 2rem;
  }
}
.courseprogram__detail table th {
  width: 14.4rem;
  text-align: center;
  background: rgba(209, 60, 24, 0.25);
  color: #D13C18;
  padding: 0.8rem 1.5rem;
  word-break: keep-all;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail table th {
    width: 7rem;
    padding: 0.6rem 1.5rem;
  }
}
.courseprogram__detail table td {
  padding: 0.6rem 1rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail table td {
    padding: 0.6rem 1.5rem;
  }
}
.courseprogram__detail table tr:not(:last-child) {
  border-bottom: 2px dashed #D13C18;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail table tr:not(:last-child) {
    border-bottom: 0.1rem dashed #D13C18;
  }
}
@media screen and (min-width: 768px) {
  .courseprogram__detail dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .courseprogram__detail dl dt {
    width: 9rem;
  }
  .courseprogram__detail dl dd {
    width: calc( 100% - 9rem);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .courseprogram__detail dl dd > div {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .courseprogram__detail dl dd a {
    display: block;
    min-width: calc( ( 100% - 6em) * .2);
    margin-left: 1.2em;
    position: relative;
  }
  .courseprogram__detail dl dd a:before {
    content: "";
    height: 6px;
    width: 6px;
    border-radius: 9999px;
    position: absolute;
    background: #D13C18;
    right: calc( 100% + 0.4em);
    top: calc( 1.75em * 0.5 - 2px);
  }
  .courseprogram__detail dl dt:nth-child(n+3),
.courseprogram__detail dl dd:nth-child(n+3) {
    margin-top: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail dl dt {
    margin-bottom: 0.3rem;
  }
  .courseprogram__detail dl dd {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-left: -0.2em;
  }
  .courseprogram__detail dl dd > div {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .courseprogram__detail dl dd a {
    display: block;
    min-width: calc( ( 100% - 3.6em) * .3333);
    margin-left: 1.2em;
    position: relative;
  }
  .courseprogram__detail dl dd a:before {
    content: "";
    height: 5px;
    width: 5px;
    border-radius: 9999px;
    position: absolute;
    background: #D13C18;
    right: calc( 100% + 0.3em);
    top: calc( 1.75em * 0.5 - 2.5px);
  }
  .courseprogram__detail dl dt:not(:first-child) {
    margin-top: 2rem;
  }
}
.courseprogram__detail > p:first-child {
  margin-top: 0;
}
.courseprogram__detail .calendar + .calendar {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail .calendar + .calendar {
    margin-top: 5rem;
  }
}
.courseprogram__detail .calendar .calendar__ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 400;
  max-width: 60rem;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.courseprogram__detail .calendar .calendar__ttl__season {
  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;
  margin-right: 2rem;
  height: 5rem;
  width: 12rem;
  font-size: 2.4rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .courseprogram__detail .calendar .calendar__ttl__season {
    font-size: 1.6rem;
    width: 8rem;
    height: 4rem;
  }
}
.courseprogram__detail .calendar .calendar__tbl {
  border: 1px solid #D9D4D4;
}
.courseprogram__detail .calendar .calendar__tbl tr {
  border: none;
}
.courseprogram__detail .calendar .calendar__tbl th,
.courseprogram__detail .calendar .calendar__tbl td {
  border: 1px solid #D9D4D4;
  text-align: center;
  vertical-align: middle;
}
.courseprogram__detail .calendar .calendar__tbl thead td,
.courseprogram__detail .calendar .calendar__tbl thead th {
  padding: 0.25em;
  background: #e2e2e2;
  border: 1px solid #fff;
  color: #000;
  font-size: 2rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 400;
}
@media screen and (max-width: 1023px) {
  .courseprogram__detail .calendar .calendar__tbl thead td,
.courseprogram__detail .calendar .calendar__tbl thead th {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail .calendar .calendar__tbl thead td,
.courseprogram__detail .calendar .calendar__tbl thead th {
    font-size: 1.6rem;
  }
}
.courseprogram__detail .calendar .calendar__tbl thead td.sun,
.courseprogram__detail .calendar .calendar__tbl thead th.sun {
  background: #D13C18;
  color: #fff;
}
.courseprogram__detail .calendar .calendar__tbl thead td.sat,
.courseprogram__detail .calendar .calendar__tbl thead th.sat {
  background: #3F8CC9;
  color: #fff;
}
.courseprogram__detail .calendar .calendar__tbl tbody td {
  height: 6rem;
  font-size: 2rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 400;
  padding: 1rem 0.5rem;
}
@media screen and (max-width: 1023px) {
  .courseprogram__detail .calendar .calendar__tbl tbody td {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail .calendar .calendar__tbl tbody td {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail .calendar .calendar__tbl tbody td {
    height: 2rem;
    padding: 0.5rem;
  }
}
.courseprogram__detail .calendar__notation {
  text-align: center;
  font-size: 2rem;
  line-height: 2.2;
  letter-spacing: 0;
  margin: 5rem auto;
  max-width: 60rem;
}
@media screen and (max-width: 1023px) {
  .courseprogram__detail .calendar__notation {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail .calendar__notation {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail .calendar__notation {
    margin: 2.5rem auto;
  }
}
.courseprogram__detail .calendar.season01 .calendar__ttl__season {
  background: #d6e9de;
}
.courseprogram__detail .calendar.season01 .calendar__tbl .term {
  background: #d6e9de;
}
.courseprogram__detail .calendar.season02 .calendar__ttl__season {
  background: #FEEED0;
}
.courseprogram__detail .calendar.season02 .calendar__tbl .term {
  background: #FEEED0;
}
.courseprogram__detail .wintercourseprogram__detail__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 55rem;
  margin: 0 auto;
  width: 100%;
  height: 9rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 0.6rem;
  background: #ffb31a;
  font-size: 3rem;
  font-weight: 700;
  justify-content: center;
  text-decoration: none;
  color: #fff;
  -webkit-box-shadow: 0 0.4rem 0 #927708;
          box-shadow: 0 0.4rem 0 #927708;
}
@media screen and (min-width: 768px) {
  .courseprogram__detail .wintercourseprogram__detail__btn:hover {
    -webkit-box-shadow: 0 0.1rem 0 #927708;
            box-shadow: 0 0.1rem 0 #927708;
    -webkit-transform: translateY(0.2rem);
            transform: translateY(0.2rem);
  }
}
@media screen and (max-width: 767px) {
  .courseprogram__detail .wintercourseprogram__detail__btn {
    font-size: 1.4rem;
    height: 5rem;
    -webkit-box-shadow: 0 0.2rem 0 #927708;
            box-shadow: 0 0.2rem 0 #927708;
  }
}

/* ==================================
* CONTACT - kv
* ================================== */
.contactkv__campaign {
  position: absolute;
  top: calc(50% - 37rem * .5);
  right: 10rem;
  max-width: 37rem;
}
.contactkv__campaign picture,
.contactkv__campaign img {
  display: block;
  max-width: 100%;
}
@media screen and (max-width: 767px) {
  .contactkv__campaign {
    max-width: 18.5rem;
    right: 2rem;
    top: calc(50% - 18.5rem * .5);
  }
}

/* ==================================
 * TOP - Voices
 * ================================== */
.voices {
  background: url(/img/bg_stripe01.png) repeat;
  background-size: 0.8rem;
}
@media screen and (min-width: 768px) {
  .voices {
    padding: 8rem 0;
  }
}
@media screen and (max-width: 767px) {
  .voices {
    padding: 5rem 0;
  }
}
.voices__balloon {
  max-width: 45rem;
  border-radius: 9999px;
  background: #fff;
  -webkit-filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
  width: calc(100% - 5rem);
  margin: 0 auto;
  position: relative;
  text-align: center;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 600;
  padding: 1.8rem;
  z-index: 1;
}
@media screen and (max-width: 1023px) {
  .voices__balloon {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .voices__balloon {
    font-size: 1.44rem;
  }
}
.voices__balloon:after {
  content: "";
  position: absolute;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.3rem 0;
  background: #fff;
  bottom: -1.2rem;
  left: calc(50% - 1.25rem);
  -webkit-transform: scaleX(0.6) rotate(45deg);
          transform: scaleX(0.6) rotate(45deg);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .voices__balloon:after {
    width: 1.2rem;
    height: 1.2rem;
    bottom: -0.5rem;
    left: calc(50% - .6rem);
    border-radius: 0.3rem 0;
  }
}
.voices__balloon::before {
  content: "";
  display: block;
  width: 5rem;
  height: 4rem;
  background-image: url(../img/top/icon-megafon.svg);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  right: 0;
  bottom: 0;
}
@media screen and (max-width: 767px) {
  .voices__balloon::before {
    width: 4rem;
    height: 3rem;
  }
}
.voices__balloon strong {
  font-weight: 600;
  color: #D13C18;
}
.voices__image {
  display: block;
  margin: -4rem 0 -10rem;
}
@media screen and (min-width: 128rem) {
  .voices__image {
    width: 100vw;
    margin-left: calc( ( 100% - 100vw) * .5);
    margin-right: calc( ( 100% - 100vw) * .5);
  }
}
.voices__image picture,
.voices__image img {
  display: block;
  max-width: 100%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  @supports ((-o-object-fit: cover) or (object-fit: cover)) {
    .voices__image {
      height: 58rem;
    }
    .voices__image picture,
.voices__image img {
      height: 100%;
      width: 100%;
      -o-object-fit: cover;
         object-fit: cover;
    }
  }
}
.voices__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  opacity: 0;
  -webkit-transition: opacity ease 200ms;
  transition: opacity ease 200ms;
  padding: 4rem 0 2.5rem;
}
.voices__list.slick-initialized {
  opacity: 1;
}
.voices__list__item {
  width: 24rem;
  border-radius: 1.6rem;
  background: #fff;
  padding-bottom: 2rem;
  margin: 0 0.8rem 0.5rem;
  -webkit-filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.16));
}
@media screen and (max-width: 767px) {
  .voices__list__item {
    width: 15.75rem;
    padding-bottom: 1.5rem;
  }
}
.voices__list__item .person {
  min-height: 4.6rem;
  width: 100%;
  background: #D13C18;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: 700;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  color: #fff;
  border-radius: 1.6rem 1.6rem 0 0;
  padding: 0.8rem 1rem;
}
@media screen and (max-width: 1023px) {
  .voices__list__item .person {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .voices__list__item .person {
    font-size: 1.2996rem;
  }
}
@media screen and (max-width: 767px) {
  .voices__list__item .person {
    height: 3rem;
  }
}
.voices__list__item .point {
  margin: 1.25rem 0 0.5rem;
  padding-right: 1rem;
  text-align: center;
  font-size: 4.3rem;
  font-weight: 700;
  color: #D13C18;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  position: relative;
}
@media screen and (max-width: 767px) {
  .voices__list__item .point {
    font-size: 3rem;
  }
}
.voices__list__item .point::before {
  content: "";
  display: inline-block;
  display: block;
  width: 2rem;
  height: 2rem;
  background-image: url(../img/icon-plus.svg);
  background-size: contain;
  background-repeat: no-repeat;
  margin-right: 0;
  position: relative;
  bottom: 0;
}
.voices__list__item .point::after {
  content: "";
  width: 3.56rem;
  height: 3.46rem;
  background-image: url(../img/top/icon-up.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  right: 1.6rem;
  bottom: 0.2em;
}
@media screen and (max-width: 767px) {
  .voices__list__item .point::after {
    width: 2.4rem;
    height: 2.3rem;
    right: 1rem;
  }
}
.voices__list__item .point span {
  font-size: 0.419em;
}
.voices__list__item .detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 1023px) {
  .voices__list__item .detail {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .voices__list__item .detail {
    font-size: 1.4rem;
  }
}
.voices__list__item .detail span {
  display: block;
  margin: 0 0.8rem;
}
@media screen and (max-width: 767px) {
  .voices__list__item .detail span {
    margin: 0 0.4rem;
  }
}
.voices__list__item .detail .num {
  font-family: "Barlow", "Noto Sans JP", sans-serif;
  font-weight: 600;
}
.voices__list__item .detail .arrow {
  display: block;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  border-style: solid;
  border-width: 4px 0 4px 5px;
  border-color: transparent transparent transparent #333333;
}
.voices__list .slick-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  overflow: hidden;
}
.voices__list .slick-dots li {
  display: block;
  margin: 0 0.4rem;
}
@media screen and (max-width: 767px) {
  .voices__list .slick-dots li {
    margin: 0;
  }
}
.voices__list .slick-dots li.slick-active button::before {
  background: #D13C18;
}
.voices__list .slick-dots button {
  width: 2rem;
  height: 2rem;
  font-size: 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .voices__list .slick-dots button {
    width: 1.4rem;
    height: 1.4rem;
  }
}
.voices__list .slick-dots button::before {
  content: "";
  display: block;
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  width: 1rem;
  height: 1rem;
  border-radius: 9999px;
  background: #D9D4D4;
  -webkit-transition: ease 200ms;
  transition: ease 200ms;
}
@media screen and (max-width: 767px) {
  .voices__list .slick-dots button::before {
    top: 0.35rem;
    left: 0.35rem;
    width: 0.7rem;
    height: 0.7rem;
  }
}
.voices__list__caption {
  max-width: 106rem;
  margin: 0 auto;
  padding: 0 3rem;
  text-align: right;
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  .voices__list__caption {
    padding: 0 2.5rem;
  }
}
@media screen and (min-width: 768px) {
  .voices__btn {
    width: calc((100% - 2rem) * .5);
  }
}
@media screen and (max-width: 767px) {
  .voices__btn {
    width: calc((100% - 1rem) * .5);
  }
}
.voices__btn__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 106rem;
  margin: 0 auto;
  padding: 4rem 3rem 0;
}
@media screen and (max-width: 767px) {
  .voices__btn__container {
    padding: 2.5rem 2.5rem 0;
  }
}

@media screen and (min-width: 768px) {
  .faq {
    padding: 8rem 3rem;
  }
}
@media screen and (max-width: 767px) {
  .faq {
    padding: 5rem 2.5rem;
  }
}
.faq__btn {
  margin: 0 auto;
}
.faq__btn__container {
  padding-top: 4rem;
}
@media screen and (max-width: 767px) {
  .faq__btn__container {
    padding-top: 2.5rem;
  }
}

/* キャンペーンバナー */
.wintercp_banner{
  padding: 3rem 0;
}