@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap');

/* ---------------------------------------------
  common
--------------------------------------------- */
.lp_main * {
  position: relative;
  box-sizing: border-box;
}

.lp_main {
  background-color: #005ee3;
  color: #FFF;
  font-family: "Noto Sans", sans-serif;
}

.lp_main:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: min(2527px, 336.93333333vw);
  margin: 0 auto;
  background-image: url(../img/lp_main_bg_pc.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top;
  z-index: 0;
}

@media (max-width:750px) {
  .lp_main:before {
    width: 100%;
    height: min(2810px, 374.66666667vw);
    background-image: url(../img/lp_main_bg_sp.png);
  }
}

.lp_main img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}


/* ---------------------------------------------
  pc/sp 表示切替
--------------------------------------------- */
.pc_only {
  display: none;
}

.sp_only {
  display: block;
}

@media (min-width: 750px) {
  .pc_only {
    display: block;
  }

  .sp_only {
    display: none;
  }
}

.pc_only .styles_footer__obMv8 {
  width: min(100%, 1280px);
}

/*============================
header
============================*/
.styles_header__c18jA {
  background-color: #005ae200;
}

.styles_headerToolBtn__D010m,
.styles_headerTool__tztyv {
  padding: min(calc(31/750*100%), 31px) min(calc(25/750*100%), 25px) min(calc(20/750*100%), 20px);
  height: auto;
  background-color: #005ae200;
  text-align: center;
}

.styles_headerTool__tztyv h1 {
  margin: 0;
  padding: 0;
  line-height: 0;
  display: inline-block;
}

.styles_headerToolBtn__D010m,
.styles_headerTool__tztyv img {
  width: min(154px, 20.53333333vw);
  margin: 0 auto;
}


/*============================
.fv
============================*/
.lp_main .fv .fv_ttl_inner {
  padding: min(calc(45/750*100vw), 45px) 0 min(calc(25/750*100vw), 25px);
  margin: 0 auto;
}

@media (max-width:750px) {
  .lp_main .fv .fv_ttl_inner {
    max-width: 708px;
    padding: min(calc(45/750*100vw), 45px) min(calc(20/750*100vw), 20px) min(calc(30/750*100vw), 30px);
  }
}

.lp_main .fv .fv_ttl h2 {
  font-size: min(calc(53/750*100vw), 53px);
  text-align: center;
  line-height: 1.4;
  letter-spacing: 0.05em;
}

.lp_main .fv .fv_ttl h2 .fv_font {
  display: block;
  font-size: min(calc(100/750*100vw), 100px);
  font-weight: 700;
}

.lp_main .fv .fv_ttl .fv_img02 {
  margin: min(calc(25/750*100vw), 25px) auto 0;
}

@media (min-width:751px) {
  .lp_main .fv .fv_ttl .fv_img02 {
    max-width: 708px;
  }
}

/*============================
.company_logo_loop_wrapper
============================*/
.company_logo_loop_wrapper {
  max-width: 1280px;
  margin: 0 auto;
  margin-bottom: min(calc(30/750*100vw), 30px);
}

/* 無限ループ */
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-100%);
  }
}

.scroll-infinity__wrap {
  display: flex;
  overflow: hidden;
  margin-bottom: min(calc(15/750*100vw), 15px);
}

.scroll-infinity__list {
  display: flex;
  list-style: none;
  padding: 0;
  gap: min(3.33333333vw, 25px);
  margin: 0;
}

.scroll-infinity__list:nth-child(2),
.scroll-infinity__list:last-child {
  margin-left: min(calc(25/750*100%), 25px);
}

.scroll-infinity__list--left {
  animation: infinity-scroll-left 80s infinite linear 0.5s both;
}

.scroll-infinity__item {
  width: min(calc(100vw / 2.9), 232px);
}

.scroll-infinity__item>img {
  width: 100%;
}

.scroll-infinity__item img._2 {
  margin-top: min(16px, 2.133333333vw);
}

.note_r {
  max-width: 750px;
  margin: 0 auto;
  text-align: right;
  font-size: min(calc(18/750*100vw), 18px);
  font-family: 'Noto Sans JP', sans-serif;
}

/*============================
.cv
============================*/

.lp_main .cv_box {
  max-width: 702px;
  width: min(calc(702/750*100%), 702px);
  margin: 0 auto;
  background-color: #FF9220;
  border-radius: 100px;
  text-align: center;
  z-index: 2;
}

@media (min-width:751px) {
  .lp_main .cv_box {
    max-width: 600px;
    width: min(calc(600 / 1280 * 100%), 600px);
  }
}

.lp_main .cv_box a {
  font-size: min(calc(32/750*100vw), 32px);
  font-weight: 700;
  color: #FFF;
  display: block;
  padding: 0.8em 0;
  transition: all ease 0.2s;
}

@media (min-width:751px) {
  .lp_main .cv_box a {
    font-size: min(calc(32 / 1280 * 100vw), 32px);
  }
}

.lp_main .cv_box a:hover {
  opacity: 0.7;
}

.lp_main .cv_box .cv_circle {
  width: min(calc(102/750*100%), 102px);
  height: min(calc(100/750*100vw), 100px);
  background-color: #FFF;
  border-radius: 100px;
  color: #FF9220;
  font-size: min(calc(20/750*100vw), 20px);
  display: flex;
  align-items: center;
  align-content: center;
  justify-content: center;
  flex-wrap: wrap;
  line-height: 1.2;
  position: absolute;
  left: 2.5%;
  top: 7%;
}

@media (min-width:751px) {
  .lp_main .cv_box .cv_circle {
    width: calc(68 / 640 * 100%);
    height: min(calc(64 / 1280 * 100vw), 64px);
    font-size: min(calc(12 / 1280 * 100vw), 12px);
    left: 2%;
    top: 12%;
  }
}

.lp_main .cv_box .cv_circle .cv_large {
  font-size: min(calc(35/750*100vw), 35px);
  font-weight: 800;
}

@media (min-width:751px) {
  .lp_main .cv_box .cv_circle .cv_large {
    font-size: min(calc(18 / 1280 * 100vw), 18px);
  }
}

.lp_main .cv_box .cv_circle .cv_small {
  font-size: min(calc(20/750*100vw), 20px);
  padding-top: min(calc(10/750*100vw), 10px);
}

@media (min-width:751px) {
  .lp_main .cv_box .cv_circle .cv_small {
    font-size: min(calc(10 / 1280 * 100vw), 10px);
    padding-top: 0.8em;
  }
}

.lp_main .cv_login {
  display: block;
  font-size: min(calc(22/750*100vw), 22px);
  text-align: center;
  color: #FFF;
  padding: min(calc(30/750*100vw), 30px) 0 0;
  text-decoration: underline;
  text-underline-offset: min(calc(6/750*100vw), 6px);
}

/*============================
user-voice
============================*/
.lp_main .user-voice .sec_inner {
  padding-top: min(calc(100/750*100%), 100px);
}

.lp_main .user-voice_item_wrapper {
  max-width: 1150px;
  margin: 0 auto;
  padding-top: min(calc(70/750*100%), 70px);
}

@media (max-width:1300px) {
  .lp_main .user-voice_item_wrapper {
    padding: min(calc(70/750*100%), 70px) min(calc(30/750*100%), 30px) 0;
  }
}

@media (max-width:750px) {
  .lp_main .user-voice_item_wrapper {
    max-width: 100%;
  }
}

.lp_main .user-voice h2 {
  width: min(calc(656/750*100%), 656px);
  margin: 0 auto;
}

.lp_main .user-voice_item_wrapper .user-voice_item {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(calc(15/750*100%), 15px);
  margin-bottom: min(calc(25/750*100%), 25px);
}

.lp_main .user-voice_item_wrapper .user-voice_item:nth-child(2) {
  margin-bottom: min(calc(44/750*100%), 44px);
}

.lp_main .user-voice_item_wrapper .user-voice_item:nth-child(3) {
  margin-bottom: min(calc(20/750*100%), 20px);
}

.lp_main .user-voice_item_wrapper .user-voice_item:nth-child(4) {
  margin-bottom: min(calc(30/750*100%), 30px);
}

.lp_main .user-voice_item_wrapper .user-voice_item:nth-child(5) {
  margin-bottom: min(calc(20/750*100%), 20px);
}

.lp_main .user-voice_item_wrapper .user-voice_item:last-child {
  margin-bottom: 0;
}

.lp_main .user-voice_item_wrapper .user-voice_item .user-voice_item_img {
  width: min(calc(155/750*100%), 155px);
  height: auto;
}

@media (min-width:751px) {
  .lp_main .user-voice_item_wrapper .user-voice_item .user-voice_item_img {
    width: 140px;
  }
}

.lp_main .user-voice_item_wrapper .user-voice_item:first-child .user-voice_item_img {
  margin-top: min(calc(12/750*100%), 12px);
}

.lp_main .user-voice_item_wrapper .user-voice_item .user-voice_item_text {
  width: 100%;
  font-size: min(calc(28/750*100vw), 28px);
  background-color: #f5f3eb;
  color: #403e3e;
  padding: min(calc(30/750*100%), 30px);
  margin-left: min(calc(25/750*100%), 25px);
  border-radius: 1.5vw;
  position: relative;
  line-height: 1.5;
}

@media (min-width:751px) {
  .lp_main .user-voice_item_wrapper .user-voice_item .user-voice_item_text {
    font-size: 24px;
  }
}

.lp_main .user-voice_item_wrapper .user-voice_item:first-child .user-voice_item_text {
  padding: min(calc(35/750*100%), 35px) min(calc(30/750*100%), 30px);
}

.lp_main .user-voice_item_wrapper .user-voice_item:nth-child(2) .user-voice_item_text {
  padding: min(calc(22/750*100%), 22px) min(calc(30/750*100%), 30px);
}

.lp_main .user-voice_item_wrapper .user-voice_item:nth-child(3) .user-voice_item_text {
  padding: min(calc(27/750*100%), 27px) min(calc(30/750*100%), 30px);
}

.lp_main .user-voice_item_wrapper .user-voice_item.teacher .user-voice_item_text {
  background-color: #e4efff;
  margin-left: 0;
  margin-right: min(calc(25/750*100%), 25px);
}


.lp_main .user-voice_item_wrapper .user-voice_item .user-voice_item_text::before {
  content: '';
  position: absolute;
  border-top: min(35px, 4.666666667vw) solid #f5f3eb;
  border-left: min(10px, 1.333333333vw) solid transparent;
  border-right: min(10px, 1.333333333vw) solid transparent;
  position: absolute;
  top: 50%;
  left: -3%;
  width: 0;
  height: 0;
  transform: translateY(-50%) rotate(90deg);
}

@media (min-width:751px) {
  .lp_main .user-voice_item_wrapper .user-voice_item .user-voice_item_text::before {
    left: -2%;
  }
}

.lp_main .user-voice_item_wrapper .user-voice_item.teacher .user-voice_item_text::before {
  border-top: min(35px, 4.666666667vw) solid #e4efff;
  left: auto;
  right: -3%;
  transform: translateY(-50%) rotate(-90deg);
}

@media (min-width:751px) {
  .lp_main .user-voice_item_wrapper .user-voice_item.teacher .user-voice_item_text::before {
    right: -2%;
  }
}

.lp_main .user-voice .cv_box {
  margin-top: min(calc(100/750*100%), 100px);
}

/*============================
point_area
============================*/
.lp_main .point_area {
  padding-top: min(calc(50/750*100%), 50px);
  background-image: url(../img/point_area_bg_pc.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top;
}

@media (max-width:750px) {
  .lp_main .point_area {
    background-image: none;
  }
}

.lp_main .point_area section {
  max-width: 1280px;
  margin: 0 auto min(calc(80/750*100%), 80px);
}

@media (max-width:750px) {
  .lp_main .point_area section {
    margin-bottom: min(calc(50/750*100%), 50px);
  }
}

.lp_main .point_area section:first-child {
  margin-bottom: 0;
}

.lp_main .point_area section:last-child {
  max-width: 100%;
  margin-bottom: 0;
}


/*============================
.sec_01
============================*/
.lp_main .sec_01 .sec_inner .cv_box {
  position: absolute;
  left: 0;
  right: 0;
  top: 80.95%;
}

/*============================
.sec_02
============================*/

.lp_main .sec_02 .cv_box {
  position: absolute;
  left: 0;
  right: 0;
  top: 83%;
}

/*============================
.sec_03
============================*/
.lp_main .sec_03 .sec_inner .cv_box {
  position: absolute;
  left: 0;
  right: 0;
  top: 79%;
}

@media (max-width:750px) {
  .lp_main .point_area section.sec_03 {
    margin-bottom: 0;
  }
}

/*============================
.bottom_area
============================*/
.lp_main .point_area section.bottom_area {
  background-color: #FFF;
}

.lp_main .bottom_area .sec_inner {
  padding-bottom: min(calc(50/750*100%), 50px);
}

.lp_main .bottom_area .sec_inner h2 {
  width: min(calc(679/750*100%), 679px);
  margin: 0 auto;
  padding: min(calc(30/750*100%), 30px) 0;
}

.lp_main .bottom_area .sec_inner .btn_head {
  width: calc(568/2560*100%);
  margin: 0 auto 1%;
}

/*============================
.bl_floatArea
============================*/
.lp_main .bl_floatArea.js_floatArea {
  z-index: 100;
}

.lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: min(calc(15/750*100%), 15px) 0;
  z-index: 100;
}

.lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .btn_head {
  font-size: min(calc(24/750*100vw), 24px);
  color: #FFF;
  font-weight: 700;
  margin-bottom: min(calc(10/750*100%), 10px);
}

.lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .cv_box a::after {
  display: none;
}

.lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .cv_box .cv_circle .cv_small {}

.js_floatArea {
  position: fixed;
  bottom: 0;
  width: 100%;
  background-color: #005ee3;
  padding: 0;
  text-align: center;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}

.js_floatArea.hidden {
  opacity: 0;
  visibility: hidden;
}

/*============================
SMART PHONE
============================*/

@media (max-width:750px) {

  .styles_header__IpMmc {
    border: none;
  }

  .lp_main {
    background-image: none;
  }

  /*============================
.fv
============================*/
  .lp_main .fv .sec_inner #__next {
    left: 4%;
    top: 2%;
    width: calc(160/750*100%);
  }

  .lp_main .fv .sec_inner #__next header {
    height: auto;
    padding: 0;
  }

  .lp_main .fv .cv_box {
    bottom: 5%;
  }

  /*============================
.main_head
============================*/
  .lp_main .main_head {
    margin: calc(70/750*100%) 0 calc(60/750*100%);
  }

  .lp_main .main_head .sec_inner {}

  .lp_main .main_head .sec_inner h2 {
    width: calc(560/750*100%);
  }

  /*============================
.cv
============================*/
  .lp_main .cv_box {
    max-width: calc(700/750*100%);
    width: min(calc(700/750*100%), 700px);
  }

  .lp_main .cv_box a {
    font-size: min(calc(40/750*100vw), 40px);
    font-weight: 700;
    color: #FFF;
    display: block;
    padding: 1em 0 1em 1em;
  }

  .lp_main .cv_box a::after {
    width: calc(38/750*100%);
    height: 38px;
    top: calc(20.5/60*100%);
    right: calc(20.5/350*100%);
  }

  .lp_main .cv_box .cv_circle {
    width: calc(108/750*100%);
    height: min(calc(100/750*100vw), 100px);
    font-size: min(calc(20/750*100vw), 20px);
    left: 2%;
    top: 8%;
  }

  .lp_main .cv_box .cv_circle .cv_large {
    font-size: min(calc(36/750*100vw), 36px);
    font-weight: 800;
  }

  .lp_main .cv_box .cv_circle .cv_small {
    font-size: min(calc(22/750*100vw), 22px);
    padding-top: 0.6em;
  }

  .lp_main .cv_login {
    font-size: min(calc(28/750*100vw), 28px);
    padding: min(calc(20/750*100vw), 20px) 0 0;
  }

  /*============================
.sec_01
============================*/

  .lp_main .sec_01 .sec_inner .cv_box {
    left: 0;
    right: 0;
    top: 90%;
  }

  /*============================
.sec_02
============================*/

  .lp_main .sec_02 {}

  .lp_main .sec_02 .sec_inner .cv_box {
    top: 92%;
  }

  /*============================
.sec_03
============================*/
  .lp_main .sec_03 {}

  .lp_main .sec_03 .sec_inner {}

  .lp_main .sec_03 .sec_inner .cv_box {
    position: absolute;
    left: 0;
    right: 0;
    top: 90%;
  }

  /*============================
.bottom_area
============================*/
  .lp_main .bottom_area {
    background-color: #FFF;
  }

  .lp_main .bottom_area .sec_inner {
    padding-bottom: min(calc(45/750*100%), 45px);
  }

  .lp_main .bottom_area .sec_inner h2 {
    width: calc(520/750*100%);
    margin: 0 auto;
    padding: min(calc(68/750*100%), 68px) 0 min(calc(55/750*100%), 55px);
  }

  .lp_main .bottom_area .sec_inner .btn_head {
    width: calc(551/750*100%);
    margin-bottom: 3%;
  }

  .lp_main .bottom_area .cv_box {
    width: calc(672/750*100%);
    max-width: 100%;
  }

  .lp_main .bottom_area .cv_box a {
    padding-left: 1em;
  }

  .lp_main .bottom_area .cv_box .cv_circle {
    width: calc(100/672*100%);
  }

  /*============================
.bk_floatArea
============================*/
  .lp_main .bl_floatArea.js_floatArea {
    z-index: 100;
  }

  .lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner {
    padding: min(calc(15/750*100%), 15px) 0;
  }

  .lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .btn_head {
    font-size: min(calc(32/750*100vw), 32px);
    margin-bottom: min(calc(10/750*100%), 10px);
  }

  .lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .btn_head span {
    font-size: min(calc(40/750*100vw), 40px);
  }

  .lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .cv_box {
    width: calc(672/750*100%);
    max-width: 100%;
  }

  .lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .cv_box {
    padding-left: 0;
  }

  .lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .cv_box .cv_circle {
    width: calc(100/672*100%);
  }

  .js_floatArea {
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: #005CE2;
    padding: 0;
    text-align: center;
    transition: opacity 0.5s ease, visibility 0.5s ease;
  }

  .js_floatArea.hidden {
    opacity: 0;
    visibility: hidden;
  }

}

.lp_main .cv_box {
  background-color: transparent;
  border-radius: 0;
}

.lp_main .cv_box a.signup {
  font-size: min(calc(40/750*100vw), 40px);
  position: relative;
  font-weight: 700;
  color: #FFF;
  display: block;
  background-color: #FF9220;
  border-radius: 100px;
  width: 100%;
  padding: min(calc(40/750*100vw), 40px) 0;
  transition: all ease 0.2s;
  box-shadow: 0px 8px 10px #0000003d;
}

@media (min-width:751px) {
  .lp_main .cv_box a.signup {
    font-size: min(calc(32 / 1280 * 100vw), 32px);
    padding: 0.8em 0;
  }
}

.lp_main .cv_box a.signup::after {
  content: '';
  width: min(calc(35/750*100vw), 35px);
  height: min(calc(35/750*100vw), 35px);
  background-image: url(../img/Subtract.png);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 8%;
  transform: translateY(-50%);
}

.lp_main .cv_box a.signup:hover {
  opacity: 0.7;
}

/* 20250512 修正 */
.lp_main .cv_box a.signup+a {
  /* /20250512 修正 */
  font-size: min(calc(16/750*100vw), 16px);
  font-weight: 700;
  text-decoration: underline;
  color: #FFF;
  display: block;
  margin-top: 1em;
  padding: 0;
  transition: all ease 0.2s;
}

/* 20251002 修正 a..signup->a.signup */
.lp_main .bottom_area .cv_box a.signup+a {
  /* /20251002 修正 */
  color: #2d2d2d;
}

.lp_main .bl_floatArea.js_floatArea .bl_floatArea_inner .cv_box a::after {
  display: bolck;
}

.lp_main .sec_01 .sec_inner .cv_box {
  top: 78.95%;
}

.lp_main .sec_02 .cv_box {
  top: 81.5%;
}

.lp_main .sec_03 .sec_inner .cv_box {
  /* 20251002 修正 */
  top: 83%;
  /* /20251002 修正 */
}

@media (max-width:750px) {

  .lp_main .cv_box a.signup {
    font-size: min(calc(40/750*100vw), 40px);
    font-weight: 700;
    color: #FFF;
    display: block;
    padding: 1em 0 1em 1em;
  }

  /* 20250512 修正 */
  .lp_main .cv_box a.signup+a {
    /* /20250512 修正 */
    font-size: 3.6vw;
    margin-top: 0.6em;
    padding: 0;
  }

  .lp_main .sec_01 .sec_inner .cv_box {
    top: 87.6%;
  }

  .lp_main .sec_02 .sec_inner .cv_box {
    top: 90%;
  }

  .lp_main .sec_03 .sec_inner .cv_box {
    top: 87%;
  }

}

/* ---------------------------------------------
  footer
--------------------------------------------- */
footer .wrap {
  max-width: 980px;
  width: 100%;
}