@charset "UTF-8";


@font-face {
  font-family: "NotoSansCJKjp"; font-style: normal; font-display: swap;
  font-weight: 400;
  src:  local('Noto Sans CJK JP'),
  local('NotoSansCJKjp-Regular'),
  local('NotoSansJP-Regular'),
  url('/font/NotoSansCJKJP/NotoSansCJKjp-Regular.woff2') format('woff2');
}
@font-face {
  font-family: "NotoSansCJKjp"; font-style: normal; font-display: swap;
  font-weight: 500;
  src: local('NotoSansCJKjp-Medium'),
  local('NotoSansJP-Medium'),
  url('/font/NotoSansCJKJP/NotoSansCJKjp-Medium.woff2') format('woff2');
}
@font-face {
  font-family: "NotoSansCJKjp"; font-style: normal; font-display: swap;
  font-weight: 700;
  src: local('NotoSansCJKjp-Bold'),
  local('NotoSansJP-Bold'),
  url('/font/NotoSansCJKJP/NotoSansCJKjp-Bold.woff2') format('woff2');
}
@font-face {
  font-family: "YakuHanJP"; font-style: normal; font-display: swap;
  font-weight: 400;
  src: url("/font/YakuHanJP/YakuHanJP-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP"; font-style: normal; font-display: swap;
  font-weight: 500;
  src: url("/font/YakuHanJP/YakuHanJP-Medium.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP"; font-style: normal; font-display: swap;
  font-weight: 600;
  src: url("/font/YakuHanJP/YakuHanJP-Bold.woff2") format("woff2");
}


/* CSS Document */
/*resetcss*/
html{
  /* 320:10px; */
  font-size: clamp(10px,3.125vw,16px);
}
* , *::before ,*::after{
  box-sizing: border-box;
  background-repeat: no-repeat;
}
html,body,h1,h2,h3,h4,h5,h6,p,ul,ol,li,dl,dt,dd,figure,figcaption,svg{
  margin: 0;
  padding: 0;
 /* font-weight: inherit; */
}
body{
  font-family: 'YakuHanJP','NotoSansCJKjp','Noto Sans JP', sans-serif;
  position: relative;
  /* background-color: var(--color-bg); */
  line-height: 1.5;
  transition:  color .6s;
  transition-timing-function: cubic-bezier(.61,.2,.81,.53);
}
body::before{
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--color-bg);
  z-index: -100;
  transition: background-color .6s;
  cursor: pointer;
  background: linear-gradient(-45deg, rgba(109, 188, 183, 1) 0%, rgba(0, 126, 172, 1) 35%, rgba(55, 172, 206, 1) 80%, rgba(109, 188, 183, 1) 100%);
}
ul,li{
list-style: none;
}
a{
text-decoration: none;
color: inherit;
}
a[href^="tel:"] {
  pointer-events: all;
}
a:hover{
	opacity: 0.5;
}
img{
vertical-align: bottom;
border: none;
width: 100%;
max-width:100%;
height:auto;
}
address{
font-style: normal;
}
svg{
  fill: none;
  vertical-align: bottom;
}
table {
  border-collapse: collapse;
}
button{
  appearance: none;
  border: none;
  background-color: transparent;
}
p{
  text-align: justify;
}
.wrapper{
  max-width: 640px;
  margin: auto;
  overflow: hidden;
  background: #fff;
}
@keyframes bound-anim{
  0%{transform:translateY(0px);}
  100%{transform: translateY(24px);}
}
img.easein{
  animation: .5s bound-anim ease-in infinite alternate;
}
.slick-dots li{
	display: none;
}
.wide{
	width: 90%;
	margin: auto;
}
.db{
	display: block;
}
.pc{
  display: none;
}
.center{
  text-align: center;
}
.left-center{
  text-align: left;
}
.center-left{
  text-align: center;
}
.left{
  text-align: left;
}
.small{
  font-size: 0.9em;
}
.asterisk{
  position: relative;
  display: block;
  padding-left: 1.2em;
  margin-top: 0.2em;
  font-weight: 300;
}
.asterisk::before{
  content: "※";
  position: absolute;
  left: 0;
}
.w90{
	width: 90%;
	margin: auto;
}
.en{
  /* font-family: 'Barlow', sans-serif; */
  font-family: 'Outfit', sans-serif;
  font-size: 1.08em;
}

/*top*/
.top-in{
    background: url(../imgs/lp-top-new.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    padding: 3em 0 40em;
    position: relative;
}
.top-txt{
  position: absolute;
  width: 70%;
  top: .5rem;
  left: -0.2rem;
}
.header_logo{
	position: absolute;
}
.header_logo {
    display: block;
    width: 3.7em;
    color: #fff;
    right: 1rem;
    top: 1rem;
    height: 2.5em;
}
.try-btn{
    position: absolute;
    width: 11rem;
    right: 2rem;
    bottom: 8rem;
}
/* .home{
    position: absolute;
    bottom: -3rem;
    z-index: 1;
    width: 100%;
} */
.lp_head_title {
  position: absolute;
  bottom: -1em;
  left: 0;
  right: 0;
  z-index: 1;
  width: 95%;
  margin: auto;
  filter: drop-shadow(.3em .3em .15em rgba(0, 126, 172, .5));
}
.lp_head_title img {
  transform: rotateZ(-7deg);
}

/*lp-sectionback*/
.s1-back{
    background: url(../imgs/lp-s1-back.svg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    padding: 7em 0 7em;
    position: relative;
    margin-top: -0.2rem;
}
.lp-right,.lp-left,.scroll{
	position: absolute;
}
.scroll{
    width: 20%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.lp-left{
	width: 40%;
    bottom: 2rem;
}
.lp-right{
	width: 40%;
    top: 2rem;
	right: 0;
}
.joutatu-back{
	
}
/*lp-sectionback*/
.s2-back{
    background: url(../imgs/joutatu-back.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    padding: 0px 0 30em;
    position: relative;
    margin-top: -0.2rem;
}
.s2-ttl{
	width: 90%;
    margin: auto;
    padding-top: 3rem;
}
/*hp*/
.intro_example_header::after{
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 1.8rem .9rem 0 .9rem;
  border-color: var(--color-a) transparent transparent transparent;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}
.intro_example_block{
  padding: 1rem 0;
  margin: auto;
  width: 85%;
	color: #333;
}
.intro_example_box{
  font-size: 1.55rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: .45em 0 .45em 1.6em;
  position: relative;
}
.intro_example_box::after{
  content: "";
  display: block;
  width: 1.1em;
  height: 1.1em;
  background-image: url(https://www.vocalmaster.jp/imgs/icon_checkbox.svg);
  background-position: center;
  position: absolute;
  left: 0;
  top: .1em;
  bottom: 0;
  margin: auto;
}
.intro_example_footer{
  width: 27rem;
  margin: 2rem auto 0;
}
/*//hp*/
.red {
   color: #F56478;
}
.aright{
	width: 10%;
    margin: 3rem auto;
}
.kaisyou{
	width: 95%;
    margin: auto;
}
.levelup{
	padding: 3rem 0;
}
.vocal-box{
    border-radius: 17px;
    margin-top: 2rem;
    background: #fff;
    width: 100%;
    top: 90%;
}
.s-back,.s-back2{
    position: relative;
}
.iphone{
    padding: 8rem 0 0;
    background: url(../imgs/s-back.svg);
    background-size: cover;
    background-repeat: no-repeat;
}
.reason{
	position: absolute;
      bottom: -12%;
    width: 100%;
	z-index: 1;
}
.reason-ttl{
  width: 100%;
  position: absolute;
  /* left: 1rem; */
  top: 3rem;
  font-size: 6rem;
  text-align: center;
  color: #fff;
  filter: drop-shadow(0 0 .5em rgba(0, 126, 172, .5));
}
.s-back-wp{
	font-size: 1.5rem;
	color: #fff;
}
.s-back2{
    background: url(../imgs/s-back.svg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    padding: 0 0 8em;
}
.s-1pd{
	    padding-top: 14rem;
    padding-bottom: 9em;
}
.number,.number-top,.number2{
	font-size: 11rem;
  position: absolute;
  color: #fff;
  font-weight: 500;
  letter-spacing: -5px;
  font-family: 'Outfit', sans-serif;
  line-height: 1;
  filter: drop-shadow(0 0 15px #009baf);
}
.number-top{
    right: 1rem;
    top: 6rem;
}
.number{
    right: 1rem;
    top: -8rem;
}
.number2{
    left: 1rem;
    top: -8rem;
}
.reason-ttl2-top,.reason-ttl2,.reason-ttl2-right{
  font-size: 4rem;
  position: absolute;
  color: #fff;
  font-family: 'Outfit', sans-serif;
  filter: drop-shadow(0 0 15px #009baf);
}
.reason-ttl2-top {
  left: 1rem;
  top: 10.8rem;
}
.reason-ttl2 {
  left: 1rem;
  top: -3.2rem;
}
.reason-ttl2-right {
  right: 1rem;
  top: -3.2rem;
}
.lp-ttl3 {
  color: #fff;
  font-weight: bold;
  font-size: 2.5rem;
  margin: 2rem auto;
  filter: drop-shadow(.1em .1em .15em rgba(0, 126, 172, .6));
}
.border_line{
	border-bottom: solid 3px #ffff00;
}
.pointbottom{
	    padding-bottom: 8rem;
}

.lp_reason_desc{
  font-size: 1.4rem;
  font-weight: 500;
  padding: .3em 0;
  line-height: 1.7;
}
.lp_reason_desc p{
  padding: .3em 0;
}
.back_text{
  display: block;
  font-size: .75em;
  line-height: 1.3;
  padding: .2em .4em;
  width: fit-content;
  background-color: #fff;
  color: #0097af;
  margin-bottom: .2em;
}

/* Q&A
========================================= */
.qa_block{
  max-width: 56rem;
  margin: 0 auto 1em;
}
.qa_box{
  padding: .6em 0;
}
.tab-head,.tab-content{
  padding: 1.5rem ;
  background-color: var(--color-c);
  color: #333;
  width: 100%;
}
.tab-head{
  position: relative;
  font-size: 1.35rem;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: .03em;
  cursor: pointer;
  transition: padding .5s;
}
.tab-head::before,.tab-head::after{
  content: "";
  position: absolute;
  display: block;
  background-color: var(--color-a);
  width: .2em;
  height: 1.4em;
  right: 1.7em;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: transform .3s;
}
.tab-head::after{
  transform: rotateZ(90deg);
}
.tab-content{
  display: none;
  font-size: clamp(12px,1.2rem,16px);
  padding-top: 0;
  text-align: justify;
}

.tab-head.open{
  padding-top: 1.8em ;
  padding-bottom: 1.8em ;
}
.tab-head.open::before{
  transform: rotateZ(135deg);
}
.tab-head.open::after{
  transform: rotateZ(225deg);
}

.tab-head-q{
  display: none;
}

/* FOOTER
========================================= */
.footer{
  background-color: rgb(109,188,183);
  background: linear-gradient(100deg, rgba(109,188,183,1) 0%, rgba(55,172,206,1) 50%, rgba(0,126,172,1) 100%);
  color: #fff;
  font-size: clamp(10px,1rem,12px);
  max-width: 640px;
  margin: auto;
}
.footer .container{
  padding: 2.5rem;
}

.footer-logo{
  display: block;
  max-width: 21rem;
  padding: 1em 0;
  margin: 0 auto;
}
.footer_sns{
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 12rem;
  margin: 0 auto;
  padding: 1em 0;
}
.footer_sns_a{
  display: block;
  /* padding: 1em .6em;
  width: 3.4em; */
}
.footer_sns_box i {
  font-size: 2em;
}
.footer_desc{
  text-align: justify;
  padding: 1em 0;
  line-height: 1.7;
}
.footer_gaiyou_wrap{
  display: flex;
  gap: 5em;
  padding: 4em 0;
}

.footer_gaiyou_block a{
  display: block;
  padding: .4em 0;
}
.en_block a{
  font-family: 'Outfit', sans-serif;
  font-size: 1.45em;
  font-weight: 500;
  line-height: 1.4;
}
.ja_block {
  margin-top: -.05em;
}
.ja_block a {
  padding: .55em 0;
}
.footer-copyrights{
  font-size: 10px;
}

.sec_question{
	padding-bottom: 8rem;
}
@media (min-width: 600px) {	.top-in{
    padding: 12em 0 40em;
}
	.reason-ttl2-top, .reason-ttl2, .reason-ttl2-right {
    font-size: 5rem;
    font-weight: bold;
}
.s-back2 {
    padding: 0 0 10em;
}
.s-1pd {
    padding-top: 20rem;
}
.reason-ttl2-top {
    left: 1rem;
    top: 15.8rem;
    font-weight: bold;
}
.number-top {
    right: 1rem;
    top: 5.5rem;
}
.number, .number-top, .number2 {
    font-size: 14rem;
}
.reason-ttl2-right {
    top: -4.2rem;
}
.number2 {
    left: 1rem;
    top: -14.4rem;
}
.number {
    right: 1rem;
    top: -14.6rem;
}
.reason-ttl2 {
    left: 1rem;
    top: -4.2rem;
	
}
	.pointbottom{
	    padding-bottom: 8rem;
}
	.beg_lesson_ttl_img{
 width: 70%;
}
}
@media (min-width: 600px) {
.top-txt {
       width: 60%;
	    top: 1.7rem;
}
	.scroll{
	width: 15%;
	}

}


/* Recommend Course
=========================================== */
.sec_recommend{
  padding: 2em 0;
}

.sec_recommend .sec_ttl_a_sub {
  font-size: .7em;
  padding: .8em 0 0;
}
/* .sec_recommend {
  background-color: var(--color-c);
} */
/* .top-page .sec_recommend, */
/* .inst-page .sec_recommend {
  background-color: transparent;
} */
.inst-page .sec_recommend {
  position: relative;
}
.inst-page .sec_recommend::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -10;

  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #f8fdfd;
}
.sec_recommend_block {
  padding: 0 .5em;
}
.sec_recommend_box{
  background-color: #fff;
  /* box-shadow: 0.2em 0.5em 3em rgba(18 114 140 0.3); */
  box-shadow: .2em .5em 3em rgba(116, 128, 131, 0.1);
  margin: 2em 0 ;
  text-align: center;
}
.sec_reco_head{
  position: relative;
  padding: 1em 0;
  background-color: var(--color-a);
  color: #fff;
  font-size: 1.6em;
  font-weight: 500;
  line-height: 1.4;
  margin-bottom: 1.8em;
}
.sec_reco_head::after{
  position: absolute;
  bottom: -.8em;
  left: 0;
  right: 0;
  margin: auto;
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 1.4rem .8rem 0 .8rem;
  border-color: var(--color-a) transparent transparent transparent;
}
.reco_detail_wrap{
  padding: .2em 0 0;
}
.sec_reco_ttl{
  font-size: 2.8rem;
  font-weight: 600;
  line-height: 1.4;
  padding-bottom: 0.7em;
  border-bottom: 1px solid #d7d7d7;
}
.sec_reco_ttl span{
  display: block;
  font-size: 0.6em;
}
.sec_reco_sub{
  font-family: 'Outfit', sans-serif;
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.03em;
  color: var(--color-a);
}
.reco_desc{
  text-align: center;
  font-size: 1.28rem;
  font-weight: 500;
  color: #333;
  padding: 1em 0 1.2em;
}
.sec_recommend_box .link_btn{
  color: var(--color-e);
  width: 100%;
  padding-right: 0;
  z-index: 2;
  transition: color .3s .1s cubic-bezier(.39,.575,.565,1);
}
.sec_recommend_box .link_btn.arrow::after {
  right: 0.8em;
}
.fade-bg::before{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* background-color: var(--color-e); */
  background: linear-gradient(-45deg, rgba(109,188,183,1) 0%, rgba(0,126,172,1) 35%, rgba(55,172,206,1) 80%,rgba(109,188,183,1) 100%);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .3s cubic-bezier(.39,.575,.565,1);
  z-index: -1;
}
.sec_recommend_box:hover .link_btn{
  color: #fff;
}
.sec_recommend_box:hover .fade-bg::before{
  transform: scaleX(100%);
}

.sec_foot_btn_block{
  padding: 0 0 2em;
}
.top_course_block{
  padding: 2rem 0;
}
.top_course_box{
  padding: 4rem 0 2rem;
}
.top_cource_img_box{
  position: relative;
  width: 100%;
  margin-left: -1.5rem;
}
.top_cource_img_box::before{
  content: "";
  position: absolute;
  right: -3em;
  top: 3.8em;
  z-index: -1;
  display: block;
  width: 95%;
  height: 100%;
  background-color: var(--beg-bgc);
  mix-blend-mode: multiply;

  transform-origin: left top;
  transform: scaleX(0);
  transition: transform .3s ease-in-out;
  transition-delay: .3s;
}

.top_cource_img_box.on::before{
  transform: scaleX(1);
}

.top_cource_img_sub{
  position: absolute;
  right: -0.1em;
  bottom: -0.05em;
  font-size: 2.4rem;
  text-align: right;
  line-height: .9;
  writing-mode: vertical-rl;
  color: #fff;
}
.top_cource_img_num{
  position: absolute;
  right: -.3em;
  top: -4rem;
  font-size: 1.4rem;
  line-height: .9;
  text-align: center;
  color: var(--color-d);
  z-index: 10;
}
.top_cource_img_num ._line1{
  font-weight: 600;
}
.top_cource_img_num ._line2{
  display: block;
  font-size:  4.2em;
}
.top_cource_detail_wrap{
  padding: 1.5rem 0;
}
.top_course_box_ttl{
  font-size: 3.1rem;
  font-weight: 600;
  line-height: 1.3;
  padding: 1rem 0;
  color: var(--color-d);
}
.top_course_box_ttl ._course{
  display: block;
  font-size: 0.6em;
  line-height: 1.6;
}
.top_course_box_desc{
  font-size: 1.45rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: .5rem 0 .1em;
  color: var(--color-e);
}
.top_cource_detail_wrap .link_btn{
  color: var(--color-e);
}

.top_course_box:nth-child(even) .top_cource_img_box{
  margin: 0 -1.5rem 0 auto;
}
.top_course_box:nth-child(even) .top_cource_img_box::before{
  margin: 0 -1.5em 0 0;
  left:  -3em;
  right: inherit;
}
.top_course_box:nth-child(even) .top_cource_img_num{
  right: inherit;
  left: -0.6em;
}
.top_course_box:nth-child(even) .top_cource_img_sub{
  right: calc(100% - .82em);
}

.lp_course_txt{
  font-size: 1.3rem;
  color: #333;
  margin: .3em 0;
  line-height: 1.7;
}
.top_cource_detail_wrap .link_btn{
  display: none;
}










































