@charset "UTF-8";
:root{
  --c-beg-blue: #cce6e5;
  --c-beg-blue2: #e6f4f3;
  --c-beg-blue3: #80b4c0;
  --font-en: "Gilda Display", serif;
  --font-ja: "YakuHanJP","ZenKakuGothicNew",sans-serif;
}

.bg_w{
  background-color: #fff;
}
.beg_sec_ttl{
  font-size: 1em;
  padding: 1em 0;
}
.beg_sec_ttl .en{
  display: block;
  font-size: 5.3em;
  font-weight: 300;
  line-height: 1;
}
.beg_sec_ttl .ja{
  display: block;
  font-size: 1.05em;
  font-weight: 500;
  margin-bottom: 0.8em;
  color: var(--c-beg-blue3);
}
.beg_sec_ttl .ja::before{
  content: "（ ";
}
.beg_sec_ttl .ja::after{
  content: " ）";
}
.beg_sec_desc {
  font-size: 1.55em;
  font-weight: 500;
  line-height: 1.5;
  margin: .4em 0;
}

/* BEGINNER KV ========================= */
.beginner_kv{
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  background-color: var(--c-beg-blue);
  opacity: 0;
}
.reverse .beginner_kv{
  opacity: 1;
  transition: opacity .5s;
}
/* .beginner_kv::before{
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 101%;
  background: linear-gradient( 180deg,rgba(204, 230, 229, 0) 70%, rgba(204, 230, 229, .9) 91% , rgba(204, 230, 229, 1) 95%);

} */
.beg_kv_sec{
  /* background-color: var(--c-beg-blue); */
  width: 100%;
  height: auto;
}
.kv_img {
  height: 100%;
  object-fit: cover;
}

.beginner_kv_spacer{
  height: 70vh;
  max-height: 52em;
}

.beg_intro_wrap{
  position: relative;
  padding: 0 0 5em;
  /* margin-top: 52em; */
  background-color: var(--c-beg-blue);
}
.beg_intro_wrap::before{
  position: absolute;
  bottom: 100%;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  /* height: 101%; */
  height: 40em;
  background: linear-gradient( 180deg,rgba(204, 230, 229, 0) 70%, rgba(204, 230, 229, .9) 91% , rgba(204, 230, 229, 1) 95%);
}
.beg_intro_wrap_inner{
  padding: 0 2.5em;
}
/* .beg_kv_ttl_box{
  position: absolute;
  left: 3em;
  bottom: -9em;
} */
.beg_kv_ttl{
  font-size: 1em;
}
.beg_kv_ttl .en{
  display: block;
  font-size: 6.3em;
  font-weight: 400;
  letter-spacing: -.01em;
  margin-bottom: .05em;
}
.beg_kv_ttl .ja{
  display: block;
  font-size: 1.8em;
  font-weight: 600;
  letter-spacing: .02em;
  line-height: 1.5;
}
.beg_kv_ttl_script {
  width: 6.5em;
  margin: 0 0 -3em -1.6em;
}
.beg_intro_desc {
  font-size: 1.4em;
  font-weight: 500;
  line-height: 2.1;
  padding: 3em 0 1em;
}
.beg_intro_desc p {
  padding: .4em 0;
}

@media (min-width: 769px) {
  body {
    min-width: 960px;
  }
  .beg_intro_wrap {
    background-color: rgba(204,230,229,.95);
  }
  .beg_intro_wrap::before{
    opacity: .95;
  }
  .beg_intro_wrap_inner {
    padding: 0 5em;
  }
  .beginner_kv{
    height: 100vh;
    min-height: 60em;
    min-width: 960px;
  }
  .beginner_kv_spacer {
    height: 100vh;
    max-height: initial;
}
  .beg_intro_wrap {
    width: fit-content;
    font-size: .95em;
    padding: 5em 0 10em;
    margin: -27em 8em 0 auto;
  }
}/*  */

@media (min-width: 1400px) {
  .beg_intro_wrap {
    margin: -27em calc(((100% - 1400px) / 2) + 8em) 0 auto;
  }
}/*  */


/* BEGINNER WORRY ========================= */
.beg_worry_sec{
  position: relative;
  background-color: var(--c-beg-blue2);
  padding-bottom: 2em;
  margin-bottom: 3em;
  overflow: initial;
}
.beg_worry_sec::after{
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin: auto;
  display: block;
  aspect-ratio: 1.666/1;
  width: 4em;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  background-color: var(--c-beg-blue2);
}

.beg_worry_ttl{
  font-size: 2.2em;
  font-weight: 500;
  text-align: center;
  padding: 1em 0 ;
}
.beg_worry_list {
  position: relative;
  padding-bottom: 3.4em;
}
.beg_worry_list::after {
  position: absolute;
  bottom: 1em;
  left: 0;
  right: 0;
  margin: auto;
  content: "";
  display: block;
  width: 2.5em;
  height: 2.5em;
  border-bottom: 2px solid var(--c-beg-blue3);
  border-right: 2px solid var(--c-beg-blue3);
  transform: rotateZ(45deg);
}
.beg_worry_list li{
  position: relative;
  font-size: 1.5em;
  font-weight: 600;
  background-color: #fff;
  padding: 1.5em 1.5em 1.5em 5.4em;
  margin: 1em 0;
  border-radius: .3em;
}
.beg_worry_list li::before{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 1.2em;
  margin: auto;
  display: block;
  width: 3em;
  height: 3em;
  background-image: url(/imgs/beginner/icon_worry.svg);
  background-repeat: no-repeat;
}
.beg_worry_foot_txt{
  font-size: 2em;
  font-weight: 600;
  text-align: center;
  padding: 1em 0;
}
@media (min-width: 769px) {
  .beg_worry_list{
    display: flex;
    justify-content: space-between;
  }
  .beg_worry_list li {
    width: 32%;
    display: flex;
    align-items: center;
  }
}/*  */


/* BEGINNER FEATURE ========================= */
.beg_feat_ttl{
  font-size: 1em;
  text-align: center;
  padding: 1em 0;
}
.beg_feat_ttl .cap{
  display: block;
  font-size: 1.2em;
  font-weight: 500;
  color: var(--c-beg-blue3);
  margin: .2em 0 .8em;
}
.beg_feat_ttl .ja{
  display: block;
  font-size: 2.5em;
  font-weight: 500;
  margin: .2em 0;
  letter-spacing: 0.07em;
}

.beg_feat_list{
  padding: 2em 0;
}
.beg_feat_list_box{
  padding: 2.5em 0;
  border-top: 1px solid var(--c-beg-blue);
}
.beg_feat_list_box:last-child{
  border-bottom: 1px solid var(--c-beg-blue);
}
.beg_feat_list_num{
  font-family: var(--font-en);
  font-size: 1.6em;
  color: var(--c-beg-blue3);
  margin: .3em 0 .5em;
  line-height: 1.4;
}
.beg_feat_list_ttl{
  font-size: 2.5em;
  font-weight: 500;
  line-height: 1.4;
  /* margin: .1em 0; */
}
.beg_feat_list_img_box{
  width: 100%;
  aspect-ratio: 3/2;
  margin: .5em 0;
}
.beg_feat_list_img_box._flex{
  display: flex;
}
.beg_feat_list_img_box._flex img{
  width: 33.3333%;
  height: 100%;
  object-fit: cover;
}
.beg_feat_list_desc{
  font-size: 1.25em;
  padding: 1em 0;
  line-height: 1.7;
}
.beg_feat_list_desc p{
  padding: .3em 0;
}

@media (min-width: 769px) {
  .beg_feat_sec {
    margin-bottom: 3em;
  }
  .beg_feat_ttl .ja {
    font-size: 3em;
  }
  .beg_feat_list_box{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5%;
    padding: 3.5em 4.5em;
  }
  .beg_feat_list_box:nth-child(even){
    flex-direction: row-reverse;
  }
  .beg_feat_detail_box{
    width: fit-content;
    margin: auto;
  }
  /* .beg_feat_list_box:nth-child(3) .beg_feat_detail_box{
    width: fit-content;
    margin: auto;
  }  */
  .beg_feat_list_img_box{
    width: 52%;
  }
  .beg_feat_list_ttl {
    font-size: 2.7em;
  }

}/*  */


/* BEGINNER EFFECT ========================= */
.beg_effect_sec {
  width: 97%;
  position: relative;
  background-color: var(--c-beg-blue2);
  border-radius: 0 2em 2em 0;
  padding: 4.5em 0 5em;
  margin-bottom: 3em;
}
.beg_effect_list {
  padding: 1.5em 0;
}
.beg_effect_list li{
  display: flex;
  font-size: 1.7em;
  font-weight: 500;
  line-height: 1.55;
  padding: .6em 0;
}
.beg_effect_num{
  display: block;
  width: 1.8em;
  font-family: var(--font-en);
  font-size: 1.05em;
  font-weight: 500;
  color: var(--c-beg-blue3);
}
.beg_effect_foot_desc{
  font-size: 1.25em;
  line-height: 1.8;
  padding: .5em 0;
}

.beg_effect_img_wrap{
  width: calc(100% + 2em);
  margin: 4em 0 0 -2em;
}
.beg_effect_img{
  display: block;
}
.beg_effect_img:first-child{
  width: 65%;
  margin-left: auto;
}
.beg_effect_img:last-child{
  width: 68%;
  /* margin-left: 0; */
  margin-top: -2em;
}
@media (min-width: 769px) {
  .beg_effect_sec {
    width: 95%;
    max-width: calc(110em + (100% - 110em) / 2);
    margin-right: 4em;
  }
  .beg_effect_pc_flex{
    display: flex;
    justify-content: space-between;
    max-width: 98em;
    margin-left: auto;
  }
  .beg_effect_detail_wrap {
    margin-left: 2.5em;
  }
  .beg_effect_img_wrap {
    width: 45%;
    margin: 0;
  }
  .beg_effect_list li {
    padding: .5em 0;
  }

}/*  */
@media (min-width: 1400px) {
  .beg_effect_pc_flex {
    margin-right: calc( (100% - 1400px) / 4);
  }
}/*  */


/* BEGINNER CLASS ========================= */
.beg_class_list {
  padding: 2em 0;
  margin: 0 0 1em;
}
.beg_class_list_box {
  padding: 2.5em .5em;
  border-top: 1px solid var(--c-grey-txt);
}
.beg_class_list_box:last-child {
  border-bottom: 1px solid var(--c-grey-txt);
}

.beg_class_list_ttl{
  font-size: 1em;
  padding: .5em 0;
  margin-bottom: .5em;
}
.beg_class_list_ttl .en{
  display: block;
  font-size: 3.8em;
  font-weight: 400;
  line-height: 1.2;
}
.beg_class_list_ttl .ja{
  font-size: 1.4em;
  font-weight: 500;
}
.beg_class_list_desc{
  font-size: 1.2em;
  line-height: 1.9;
  padding: .5em 0;
}
.beg_class_list_img{
  display: block;
  aspect-ratio: 4/3;
  margin: 1em 0;
  /* background-color: #ccc; */
}
.beg_class_list_img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (min-width: 769px) {
  .beg_class_pc_flex{
    display: flex;
    justify-content: space-between;
  }
  .beg_class_left_block{
    width: 30%;
  }
  .beg_class_right_block{
    width: 68%;
  }

  .beg_class_list {
    padding-top: 1em;
  }
  .beg_class_list_box{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 3.5em 0;
  }
  .beg_class_list_detail{
    width: 46%;
    font-size: .9em;
  }
  .beg_class_list_img{
    width: 46%;
    margin: 0;
  }
}/*  */


/* BEGINNER USER VOICE ====================== */
.beg_voice_sec {
  background-color: var(--c-beg-blue2);
  border-radius: 2em 0 0 2em;
  padding: 4.5em 0;
  margin-bottom: 3em;
}
.beg_voice_sec .beg_sec_ttl {
  padding: 1em 1em;
}

.beg_voice_img_box{
  display: block;
  width: 13em;
  aspect-ratio: 3/4;
  margin: 1.5em auto ;
}

.beg_voice_list{
  padding: 0 1.5em;
}
.beg_voice_list li {
  padding: 1em 0;
}
.beg_voice_desc{
  position: relative;
  width: fit-content;
  font-size: 1.5em;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: 1.6;
  padding: 0 .8em;
  margin: .8em 0;
}
.beg_voice_desc::before{
  content: "“";
  position: absolute;
  top: 0;
  left: 0;
  font-size: 1.1em;
}
.beg_voice_desc::after{
  content: "”";
  position: absolute;
  bottom: 0;
  right: 0;
  font-size: 1.1em;
  line-height: 1.5;
}

.beg_voice_name{
  position: relative;
  width: fit-content;
  font-size: 1.3em;
  margin-left: auto;
}
.beg_voice_name::before{
  content: "";
  position: absolute;
  right: 105%;
  top: .1em;
  bottom: 0;
  margin: auto;
  display: block;
  width: 3em;
  height: 1px;
  background-color: currentColor;
}
@media (min-width: 769px) {
  .beg_voice_sec {
    max-width: calc(100em + (100% - 100em) / 2);
    padding: 6em 3em 4.5em 0;
    margin-left: 6em;
    margin-top: 3em;
  }
  .beg_voice_pc_flex {
    max-width: 85em;
    margin: 0 0 0 5vw;
  }
  .beg_voice_detail_box {
    position: relative;
    width: 100%;
    padding-left: 40%;
  }
  .beg_voice_list {
    padding: 1em;
  }
  .beg_voice_desc {
    font-size: 1.6em;
    /* margin: .8em 0; */
  }
  .beg_voice_img_box{
    position: absolute;
    left: 0;
    top: 0;
    width: 20em;
    margin: 0 0 0 3em;
  }
}/*  */
@media (min-width: 1400px) {
  .beg_voice_sec {
    padding-right: 5vw;
    margin-left: auto;
  }
}/*  */


/* Q&A
================================================ */
.qa_block_wrap{
  padding: 1em 0 4em;
}
.qa_block_ttl {
  font-size: 1.6em;
  padding: .5em 0 0;
}
.qa_block{
  /* max-width: 56em; */
  margin: .5em auto;
}
.qa_box{
  border-bottom: 1px solid var(--c-grey-txt);
}
.qa-tab-head,.qa-tab-content{
  padding: 1.3em 0;
  width: 100%;
  /* line-height: 1.7; */
}
.qa-tab-head{
  display: inline-block;
  position: relative;
  font-size: 1.35em;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: .03em;
  cursor: pointer;
  transition: padding .5s;
  padding-right: 3em;
}
.qa-tab-head::before,.qa-tab-head::after{
  content: "";
  position: absolute;
  display: block;
  background-color: var(--c-beg-blue3);
  width: 1.5px;
  height: 1.2em;
  right: 1.2em;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: transform .3s;
}
.qa-tab-head::after{
  transform: rotateZ(90deg);
}
.qa-tab-content{
  display: none;
  font-size: 1.05em;
  line-height: 1.8;
  padding-top: 0;
  padding-right: 3em;
  color: var(--c-black4);
  cursor: pointer;
}
.qa-tab-content p{
  padding: .2em 0;
}
.qa-tab-content a{
  font-weight: 500;
  text-decoration: underline;
}

.qa-tab-head.open::before{
  transform: rotateZ(135deg);
}
.qa-tab-head.open::after{
  transform: rotateZ(225deg);
}
.qa-tab-head-q{
  display: inline-block;
  font-family: var(--font-en);
  font-size: 1.6em;
  font-weight: 500;
  vertical-align: -.08em;
  color: var(--c-gold);
  padding-right: .5em;
}
.tab_head_txt{
  display: block;
  font-weight: 500;
  transition: padding .3s;
}

.qa-tab-head:hover,
.qa-tab-content{
  transition: background-color .3s , padding-left .3s;
}
.qa-tab-head:hover,
.qa-tab-head.open,
.qa-tab-head:hover + .qa-tab-content,
.qa-tab-head.open + .qa-tab-content{
  background-color: #fff;
  padding-left: 1rem;
}
.gu_tel_wrap .qa-tab-head.open + .qa-tab-content{
  padding: 0;
}

@media (min-width: 769px) {
  .beg_qa_sec{
    margin: 5em 0;
  }
  .qa-tab-head{
    padding-right: 5em;
  }
  /* .qa-tab-head br{
    display: none;
  } */
  .qa-tab-head, .qa-tab-content {
    padding: 1.5em 0;
  }
  .qa-tab-content{
    padding-right: 5em;
    padding-top: 0;
  }
  .qa_block {
    font-size: 1.1em;
    max-width: initial;
    margin: 0 0 2em;
  }
  .sec_top_qa .sec_ttl_s {
    width: fit-content;
    margin-left: auto;
  }
  .qa_flex{
    display: flex;
    justify-content: center;
    gap: 10%;
  }
  .qa_flex_child_left {
    width: 15%;
  }
  .qa_flex_child_right {
    width: 60%;
    padding: 0;
  }

}/* 769 */



/* BEGINNER TRIAL 
================================================ */
.beg_trial_block{
  position: relative;
  display: block;
  padding: 3em 2em;
  background-color: var(--c-beg-blue3);
  color: var(--c-white);
  background-image: url(/imgs/beginner/beg_mvimg_sp.jpg);
  background-position: top -1em center;
  background-size: cover;
  margin-bottom: 4em;
}
.beg_trial_block::before,
.beg_trial_block::after{
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  transition: opacity .5s;
}
.beg_trial_block::before{
  background-color: var(--c-beg-blue3);
  mix-blend-mode: screen;
}
.beg_trial_block::after{
  background-color: var(--c-beg-blue3);
  mix-blend-mode: multiply;
}
.beg_trial_block .arrow_circle {
  height: 1em;
  mask-image: url(/imgs/icon_arrow_right.svg);
  background-color: currentColor;
  mask-repeat: no-repeat;
}
.beg_trial_block_inner{
  position: relative;
  z-index: 1;
}
.beg_trial_ttl{
  font-size: 5.1em;
  margin-bottom: 2.6em;
}
.beg_trial_copy {
  font-size: 3.2em;
  font-weight: 500;
  line-height: 1.45;
}
.beg_trial_desc{
  font-size: 1.3em;
  padding: .7em 0;
  margin-bottom: 1em;
}


@media (min-width: 769px) {
  .beg_trial_block:hover::before{
    opacity: .7;
  }
  .beg_trial_block:hover::after{
    opacity: .7;
  }
  .beg_trial_block{
    padding: 3.5em 5em 2.5em;
    background-image: url(/imgs/beginner/beg_trial_img_pc.jpg);
    background-position: center;
    margin-bottom: 5em;
  }
  .beg_trial_ttl {
    margin-bottom: 0;
  }

}/* 769 */


.beg_price_table_wrap{
  margin: 2em 0;
}
.beg_price_table {
  border-collapse:  collapse;
  width:  100%;
  text-align: center;
  margin-top: -1.2em;
}
.beg_price_table th,.beg_price_table td{
  padding: 1.5rem .5rem;
  border: 1px solid var(--c-grey3);
  line-height: 1.6;
  padding: 1.5rem .8rem;
}
.beg_price_table tr th,
.beg_price_table tr td:not(:last-child){
  border: 1px solid var(--c-grey3);
}

.beg_price_table th{
  font-weight: 500;
}
.beg_price_table td{
  font-family: var(--font-comp);
  font-size: 1.25rem;
  font-weight: 500;
}

.beg_th_ttl{
  display: block;
  font-size: 1.35em;
  font-weight: 600;
  line-height: 1.3;
  padding: .1rem 0;
}
.beg_th_sub{
  display: block;
  font-size: 1.1em;
  font-weight: 400;
  line-height: 1.4;
  padding: .2rem 0;
}
.beg_th_caution{
  display: block;
  font-size: .9em;
  font-weight: 400;
  line-height: 1.4;
  color: var(--c-blue);
  padding: .2rem 0;
}
.beg_price {
  font-size: 1.8em;
  font-weight: 400;
  color: var(--c-blue);
  vertical-align: middle;
  padding: 0 0.3rem;
}
.beg_reco {
  display: block;
  width: fit-content;
  background-color: var(--color-blue);
  color: #fff;
  padding: 0.1em 0.4em;
  font-size: 1.1em;
  font-weight: 600;
  margin: 0 auto .2em;
}

/* TRIAL LESSON ========================= */
.beg_trial_lesson_wrap,
.need-ttl{
  background-color: #f9f9f9;
}
.system_table tbody{
  background-color: #fff;
}
