@charset "UTF-8";
body {
  background: #fafaf5;
}
/*common*/
.txNote {
  font-size: 3vmin;
  color: #777;
}
/*layout*/
.allwrap {
  background: #fff;
  overflow: hidden;
  position: relative;
  width: 100%;
  max-width: 750px;
  margin: 0 auto;
}
.wrap {
  box-sizing: border-box;
  padding: 0 4vmin;
  width: 100%;
}
.cont {
  margin: 0 auto;
  text-align: left;
  width: 100%;
  max-width: 750px;
}
@media screen and (max-width: 750px) {
  .cont {
    max-width: 100%;
  }
}
@media screen and (min-width: 1020px) {
  .cont {
    max-width: 100%;
  }
}
/*コンテンツ切り替え*/
@media screen and (max-width: 640px) {
  .sp {
    display: block !important;
  }
  .tb {
    display: none !important;
  }
}
@media screen and (min-width: 769px) {
  .sp {
    display: none !important;
  }
  .tb {
    display: block !important;
  }
}
/*button*/
.orange_btn_link {
  background: linear-gradient(to top, #e3551c 10%, #ff8e08 85%);
  box-shadow: 0 4px 0 #b84500;
  border-radius: 10px;
  color: #fff;
  display: block;
  font-size: 18px;
  font-feature-settings: "palt";
  letter-spacing: -0.1em;
  line-height: 1;
  padding: 15px 10px;
  position: relative;
  top: 0;
  text-shadow: 0 2px 0 rgba(37, 37, 37, 0.36);
  transition: 0.3s cubic-bezier(0.78, 0.76, 0.28, 0.98);
}
.orange_btn_link:hover {
  box-shadow: 0 0 0 #b84500;
  top: 4px;
}
/*title*/
.main_title {
  color: #122565;
  font-size: 50px;
  font-size: 6.66667vmin;
  font-weight: 500;
  font-feature-settings: "palt";
  letter-spacing: -0.03em;
  text-align: center;
}
@media screen and (min-width: 750px) {
  .main_title {
    font-size: 50px;
  }
}
/*header*/
.h {
  background: #2a4192;
  height: 5px;
}
/*firstview*/
.fv {
  background: url(../img/fv-bg.png) repeat;
  padding: 4.5vmin 0 0;
}
.fv__title {
  margin: 0 0 4.5vmin;
}
.fv__wrap {
  padding: 0 4vmin;
}
.fv__pt {
  position: relative;
}
.fv__pt_title {
  color: #fff;
  font-size: 29px;
  font-size: 3.86667vmin;
  font-weight: bold;
  font-feature-settings: "palt";
  text-align: center;
}
.fv__pt_frame {
  margin: 0 0 16px;
  position: relative;
  width: 100%;
  z-index: 0;
}
.fv__pt_frame:before {
  content: '';
  border: 15px solid transparent;
  border-right: 40px solid #fff;
  display: block;
  position: absolute;
  left: 22vmin;
  height: 0;
  bottom: 5px;
  transform: rotate(90deg) skew(50deg, 0deg);
  width: 0;
  z-index: -1;
}
.fv__pt_text {
  border-bottom: 1px solid #2a4192;
  color: #2a4192;
  font-size: 28px;
  font-size: 3.73333vmin;
  font-weight: bold;
  font-feature-settings: "palt";
  letter-spacing: -0.01em;
  text-align: center;
}
.fv__pt_wrap {
  padding: 1vmin 3vmin;
}
.fv__pt_head {
  background: #2a4192;
  border-radius: 10px 10px 0 0;
}
.fv__pt_body {
  background: #fff;
  border-radius: 0 0 10px 10px;
}
@media screen and (min-width: 750px) {
  .fv__pt_title, .fv__pt_text {
    font-size: 27px;
  }
}
.fv__sim_img {
  padding: 0 4vmin;
}
/*CTA*/
/* ファーストビュー用 */
.cta_top {
  background: #2a4192;
  padding: 20px 0;
}
.cta_top__cont {
  position: relative;
}
.cta_top__title {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 35px;
  font-size: 4.66667vmin;
  font-weight: 600;
  justify-content: center;
  letter-spacing: 0.03em;
  margin: 0 0 10px;
  position: relative;
  text-align: center;
}
.cta_top__title:before, .cta_top__title:after {
  content: '';
  background: #fff;
  display: block;
  height: 2px;
  width: 1.2em;
}
.cta_top__title:before {
  margin-right: 15px;
  transform: rotate(65deg) translate(0, 8px);
}
.cta_top__title:after {
  margin-left: 10px;
  transform: rotate(-65deg) translate(0, 8px);
}
.cta_top__btn {
  text-align: center;
}
.cta_top__btn a {
  background: #379dbe;
}
@media screen and (min-width:750px) {
  .cta_top__title {
    font-size: 35px;
  }
}
/*各セクション用*/
.cta {
  background: #2a4192;
}
.cta .price {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.05em;
}
.cta .price h2 {
  color: #fff71a;
  font-size: 4.4vmin;
  padding: 20px 0 12px;
}
.cta .price ul {
  margin: 0 auto;
  width: 100%;
}
.cta .price ul li {
  background: #fff71a;
  margin: 0 0 5px;
  padding: 4px 0;
  color: #2a4192;
  border-radius: 5px;
}
.cta .price ul li .txBig {
  font-size: 8vmin;
  vertical-align: middle;
}
.cta .price ul li .txSmall {
  font-size: 4vmin;
  vertical-align: middle;
}
.cta .price ul li .txSmall.sub {
  vertical-align: sub;
}
@media screen and (min-width: 750px) {
  .cta .price h2 {
    padding: 40px 0 32px;
    font-size: 28px;
  }
  .cta .price ul {
    width: 93%;
  }
  .cta .price ul li {
    margin: 0 0 10px;
  }
  .cta .price ul li .txBig {
    font-size: 55px;
  }
  .cta .price ul li .txSmall {
    font-size: 28px;
  }
}
.cta__cont {
  padding: 30px 0 30px;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 750px) {
  .cta__cont {
    padding: 40px 0 40px;
  }
}
.cta__title {
  color: #fff;
  font-size: 42px;
  font-size: 5.4vmin;
  font-weight: 600;
  margin: 0 0 14px;
  text-align: center;
}
@media screen and (min-width:750px) {
  .cta__title {
    font-size: 42px;
  }
}
.cta__sub_title {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 35px;
  font-size: 4.66667vmin;
  font-weight: 600;
  justify-content: center;
  margin: 0 0 15px;
  position: relative;
  text-align: center;
}
.cta__sub_title:before, .cta__sub_title:after {
  content: '';
  background: #fff;
  display: block;
  height: 2px;
  width: 1.2em;
}
.cta__sub_title:before {
  transform: rotate(65deg) translate(0, 8px);
}
.cta__sub_title:after {
  transform: rotate(-65deg) translate(0, 8px);
}
.cta__btn {
  text-align: center;
}
/*LINE無料相談のイメージ*/
section.step {
  background: #e1f1f6;
}
/* flow */
.flow {
  padding: 30px;
  background: #e1f1f6;
}
.flow__headline {
  background: #11ca33;
  font-size: 35px;
  color: #fff;
  padding: 15px 0 20px;
  text-align: center;
}
.flow__txLead {
  background: #fff;
  color: #2a4192;
  font-weight: bold;
  line-height: 1.4;
  padding: 15px 0;
  text-align: center;
}
.flow .phoneWrap {
  display: flex;
  justify-content: space-around;
  background: #fff;
  padding: 0 35px 35px;
}
.flow .phone.type01, .flow .phone.type03 {
  width: 44%;
}
.flow .phone.type02 {
  width: 12%;
  padding: 250px 0 0;
  margin: 15px;
}
.flow .phone__fukidashi {
  position: relative;
  display: inline-block;
  margin: 30px 0 0;
  padding: 10px;
  min-width: 120px;
  max-width: 100%;
  color: #555;
  background: #edfff0;
}
.flow .phone__fukidashi:before {
  content: "";
  position: absolute;
  top: -30px;
  left: 50%;
  margin: 0 0 -5px -15px;
  border: 15px solid transparent;
  border-bottom: 15px solid #edfff0;
}
.flow .phone__fukidashi .txNormal {
  margin: 0 0 5px 0;
  padding: 0;
  font-size: 13px;
  text-align: left;
  font-weight: bold;
  line-height: 1.5;
}
.flow .phone__fukidashi .txSmall {
  font-size: 11px;
  line-height: 1.4;
  font-weight: normal;
  margin: 0;
}
.flow .gr {
  background: #11ca33;
  padding: 3px;
  color: #ffffff;
}
.flow .mg {
  margin: 0;
}
@media screen and (max-width:500px) {
  .flow {
    padding: 30px 15px;
  }
  .flow__headline {
    font-size: 1.5em;
    padding: 3px 0 5px;
  }
  .flow .phoneWrap {
    padding: 0 15px 15px;
  }
  .flow .phone.type01, .flow .phone.type03 {
    width: 44%;
  }
  .flow .phone.type02 {
    width: 12%;
    padding: 100px 0 0;
    margin: 8px;
  }
  .flow .phone__fukidashi {
    margin: 30px 0 0;
    padding: 10px;
    min-width: 120px;
    max-width: 100%;
    font-size: 16px;
  }
  .flow .phone__fukidashi:before {
    margin: 0 0 -3px -15px;
    border: 15px solid transparent;
    border-bottom: 15px solid #edfff0;
  }
  .flow .phone__fukidashi .txNormal {
    font-size: 12px;
  }
  .flow .phone__fukidashi .txSmall {
    font-size: 10px;
    line-height: 1.4;
    font-weight: normal;
    margin: 0;
  }
}
/*こんなお悩み、ありませんか？*/
.onayami {
  background: #f5f4dd;
  position: relative;
  padding: 35px 0;
}
.onayami:after {
  content: '';
  border: 35px solid transparent;
  border-top: 31px solid #f5f4dd;
  display: block;
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -60px;
  height: 35px;
  width: 50px;
  z-index: 1;
}
.onayami__title {
  margin: 0 0 29px;
  letter-spacing: -0.05em;
}
@media screen and (min-width: 760px) {
  .onayami {
    padding: 55px 0;
  }
  .onayami__title {
    margin: 0 0 35px;
  }
}
/*訴求1 その分の残業代は誰だって出るんです！*/
.ontime {
  background: #2a4192;
  position: relative;
  padding: 55px 0 0;
}
.ontime__img {
  margin: 0 auto;
  max-width: 50%;
}
.ontime__title {
  margin: 0 0 25px;
}
@media screen and (min-width:750px) {
  .ontime__img {
    max-width: 40%;
  }
}
/*解決事例*/
.case {
  background: #f5f4dd;
  padding: 35px 0;
}
.case__title {
  margin: 0 0 20px;
}
.case__title + .txNote {
  text-align: right;
  margin: 0 0 10px;
}
.case__card + .case__card {
  margin: 50px 0 0;
}
.case__card_cont {
  background: #fff;
  border-radius: 10px;
  padding: 20px 15px;
}
.case__card_title {
  color: #122565;
  font-size: 42px;
  font-size: 5.6vmin;
  font-weight: bold;
  line-height: 1.6;
  margin: 0 0 15px;
}
.case__card_title--em {
  background: #fff71a;
  padding: 0 5px;
}
.case__card_prof {
  color: #000;
  font-size: 25px;
  font-size: 3.33333vmin;
  font-weight: bold;
  line-height: 1.6;
  margin: 0 0 10px;
  text-align: right;
}
.case__card_text {
  font-size: 27px;
  font-size: 3.6vmin;
  font-weight: bold;
  line-height: 1.6;
  margin: 0 0 20px;
  text-align: justify;
}
.case__prof {
  align-items: center;
  display: flex;
  margin: 20px 0 0;
}
.case__prof_img {
  margin: 0 20px 0 0;
  width: calc(100% * 0.25);
}
.case__prof_text {
  color: #122565;
  font-size: 27px;
  font-size: 3.6vmin;
  font-weight: bold;
  line-height: 1.8;
}
.case__card_settle {
  background: #2a4192;
  box-sizing: border-box;
  border-radius: 8px;
  color: #fff;
  display: flex;
  flex-flow: column;
  justify-content: center;
  height: 100%;
  padding: 7% 9%;
  width: 100%;
}
.case__card_settle_title {
  border: 1px solid #fff;
  border-radius: 8px;
  font-size: 36px;
  font-size: 4.8vmin;
  font-feature-settings: "palt";
  font-weight: bold;
  letter-spacing: -0.05em;
  margin: 0 0 20px;
  padding: 10px 0;
  text-align: center;
}
.case__card_settle_text {
  align-items: flex-end;
  display: flex;
  font-size: 35px;
  font-size: 4.3vmin;
  font-weight: bold;
  justify-content: space-between;
  line-height: 1.2;
}
.case__card_settle_num {
  color: #fff71a;
  font-size: 115px;
  font-size: 15.5vmin;
  font-weight: 700;
  line-height: 0.9;
  margin: 0 0 0 5px;
}
@media screen and (min-width: 760px) {
  .case {
    padding: 55px 0;
  }
  .case__title {
    margin: 0 0 35px;
  }
  .case__card_cont {
    padding: 30px;
  }
  .case__card_title {
    margin-bottom: 20px;
  }
}
/*残業代請求の時効は2年*/
.jikou {
  background: #fff71a url(../img/jikou-bg.png) right bottom 10%/65vmin auto no-repeat;
  padding: 70px 0 50px;
  position: relative;
}
.jikou:before, .jikou:after {
  content: '';
  display: block;
  height: 16px;
  background: url(../img/jikou-line.png) repeat-x left top / 19%;
  position: absolute;
  left: 0;
  width: 100%;
}
.jikou:before {
  top: 0;
}
.jikou:after {
  bottom: 0;
}
.jikou__cont {
  text-align: center;
}
.jikou__title {
  margin: 0 10px 20px;
}
.jikou__text {
  color: #2a4192;
  font-size: 40px;
  font-size: 4.9vmin;
  font-weight: bold;
  line-height: 2;
  text-align: center;
}
.jikou__text2 {
  color: #2a4192;
  font-size: 13px;
  line-height: 1.6;
  margin-top: 10px;
  text-align: center;
}
@media screen and (min-width: 750px) {
  .jikou {
    padding: 115px 0 90px;
  }
  .jikou:before, .jikou:after {
    height: 33px;
  }
  .jikou__text {
    font-size: 38px;
  }
}
@media screen and (min-width: 1000px) {
  .jikou__title img {
    width: 75%;
  }
}
/*あなたの状況にあった回収方法が簡単にわかります！*/
.point {
  background: #f5f4dd;
  padding: 40px 0;
}
.point__title {
  margin: 0 0 30px;
}
.point__title img {
  margin: 0 auto;
}
.point__sub_title {
  border-radius: 30px;
  background: #2a4192;
  color: #fff;
  display: inline-block;
  font-size: 30px;
  line-height: 1.1;
  margin: 0 0 25px;
  padding: 15px 35px 15px;
  text-align: center;
}
.point__sp {
  margin: auto auto -25vmin;
  padding-left: 2%;
  max-width: 92%;
  position: relative;
  z-index: 1;
}
.point__sp img {
  margin: 0 auto;
}
.pt_list__box {
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 5px 30px rgba(0, 0, 0, 0.05);
  padding: 33vmin 20px 10vmin;
}
.pt_list__title {
  align-items: center;
  color: #122565;
  display: flex;
  font-size: 37px;
  font-size: 4.93333vmin;
  font-weight: 600;
  justify-content: center;
  margin: 0 0 20px;
}
.pt_list {
  margin: 0 0 16vmin;
}
.pt_list_item {
  width: 100%;
}
.pt_list_item + .pt_list_item {
  margin: 20px 0 0;
}
.pt_item__title {
  font-size: 30px;
  font-size: 4vmin;
  font-weight: 500;
  margin: 0 0 10px;
  position: relative;
  text-align: center;
  z-index: 0;
}
.pt_item__title_inner {
  align-items: center;
  background: #fff;
  color: #122565;
  display: inline-flex;
  position: relative;
  padding: 0 20px;
}
.pt_item__title:before {
  content: '';
  background: #122565;
  height: 3px;
  margin: auto;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
}
.pt_item__title_num {
  border-radius: 50%;
  display: inline-block;
  font-size: 46px;
  font-size: 6.13333vmin;
  margin-left: .25em;
}
.pt_catch {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
div.pt_catch_box {
  width: 66%;
}
.pt_catch_text {
  color: #122565;
  font-size: 32px;
  font-size: 4.26667vmin;
  font-weight: bold;
  margin: 0 0 10px;
}
.pt_catch_text--orange {
  color: #fc4545;
  font-size: 32px;
  font-size: 4.26667vmin;
}
.pt_text {
  font-size: 28px;
  font-size: 3.6vmin;
  font-weight: 500;
}
figure.pt_img {
  width: 34%;
  padding-left: 5%;
}
.pt_img img {
  width: 100%;
}
@media screen and (min-width: 750px) {
  .point {
    padding: 60px 0;
  }
  .point__sub_title {
    border-radius: 40px;
    font-size: 38px;
    margin: 0 0 35px;
    padding: 15px 45px;
  }
  .point__title {
    margin: 0 0 40px;
  }
  .pt_catch_text, .pt_catch_text--orange {
    font-size: 34px;
  }
}
/*さらに！*/
.pt_more {
  background: #2a4192;
  border-radius: 10px;
  padding: 15% 20px 10%;
  position: relative;
  text-align: center;
}
.pt_more_icon {
  background: url(../img/point-polygon-bg.png) center/contain no-repeat;
  display: inline-block;
  font-size: 23.31px;
  font-size: 3.108vmin;
  font-weight: bold;
  height: 95px;
  line-height: 95px;
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
  top: -47.5px;
  text-align: center;
  width: 20%;
}
.pt_more_catch {
  color: #fff;
  font-size: 40px;
  font-size: 5.33333vmin;
  font-weight: 600;
  margin: 0 0 20px;
}
.pt_more_text {
  color: #fff;
  font-size: 26px;
  font-size: 3.46667vmin;
  font-weight: 500;
  text-align: left;
}
}
@media screen and (min-width: 750px) {
  .pt_more_icon {
    height: 120px;
    line-height: 120px;
    top: -59.5px;
  }
}
@media screen and (min-width: 1000px) {
  .pt_more_icon {
    height: 140px;
    line-height: 140px;
  }
  .pt_more {
    padding: 15% 70px 10%;
  }
}
/*サービスの流れ*/
.service {
  background: #f5f4dd;
  padding: 35px 0;
}
.service__title {
  margin: 0 0 29px;
}
.service__flow_wrap--last {
  background: #eceac8;
  border-radius: 10px;
  padding: 20px 10px;
}
.service__flow_list {
  margin: 0 auto;
  width: 100%;
}
.service__flow_item {
  position: relative;
  padding: 0 0 35px;
}
.service__flow_item:after {
  content: '';
  background: url(../img/service-arrow.png) center/contain no-repeat;
  display: block;
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0 0 34px;
  height: 11px;
  width: 23px;
}
.service__flow_cont {
  background: #fff;
  border-radius: 10px;
}
.service__flow_icon {
  background: url(../img/service-icon-free.png) left top/contain no-repeat;
  display: block;
  padding-top: 20%;
  position: absolute;
  right: -5px;
  width: 13%;
}
.service__flow_num {
  display: block;
  font-size: 16px;
  font-size: 33px;
  font-size: 5.4vmin;
  font-weight: 600;
  font-style: normal;
  margin: auto 2vmin auto 0;
  text-align: center;
}
.service__flow_title {
  align-items: center;
  background: #2a4192;
  border-radius: 10px 10px 0 0;
  color: #fff;
  display: flex;
  font-size: 33px;
  font-size: 4.4vmin;
  font-weight: 500;
  padding: 10px 10px;
  position: relative;
  letter-spacing: -0.01em;
}
.service__flow_img {
  margin-left: 30px;
  width: 180px;
}
.service__flow_text {
  font-size: 26px;
  font-size: 3.46667vmin;
  font-weight: bold;
  padding: 15px 10px;
}
.service__middle {
  text-align: center;
}
.service__middle_title {
  align-items: center;
  color: #122565;
  display: inline-flex;
  justify-content: center;
  margin: 0 0 14px;
  position: relative;
  padding: 0 4.5vmin;
}
.service__middle_title:before, .service__middle_title:after {
  content: '';
  bottom: -18px;
  display: block;
  margin: auto;
  position: absolute;
  top: 0;
  height: 28px;
  width: 16px;
}
.service__middle_title:before {
  background: url(../img/service-slash-left.png) left bottom/contain no-repeat;
  left: 0;
}
.service__middle_title:after {
  background: url(../img/service-slash-right.png) right bottom/contain no-repeat;
  right: 1.5vmin;
}
.service__middle_title_text {
  font-size: 25px;
  font-size: 3.33333vmin;
  font-weight: 500;
  margin: 0 0 0 3vmin;
  text-align: left;
}
.service__middle_img {
  width: 16%;
}
.service__flow_finish_text {
  background: #fff71a;
  border: solid 3px #2a4192;
  border-radius: 10px;
  color: #2a4192;
  font-size: 40px;
  font-size: 6vmin;
  font-weight: 500;
  letter-spacing: 0.17em;
  padding: 10px 0;
  text-align: center;
}
@media screen and (max-width: 330px) {
  .service__flow_icon {
    top: -10px;
  }
}
@media screen and (min-width: 750px) {
  .service {
    padding: 55px 0;
  }
  .service__title {
    margin: 0 0 35px;
  }
  .service__flow_item {
    padding: 0 0 60px;
  }
  .service__flow_item:after {
    width: 43px;
    padding: 0 0 56px;
  }
  .service__flow_title {
    font-size: 33px;
  }
  .service__middle_title_text {
    font-size: 25px;
    letter-spacing: -0.03em;
  }
  .service__middle_title:before, .service__middle_title:after {
    height: 68px;
    width: 29px;
  }
}
@media screen and (min-width: 1000px) {
  .service__middle_title {
    width: 100%;
  }
  .service__middle_title_text {
    margin: 0;
  }
}
/*特徴*/
.feature {
  background: #f5f4dd;
  padding: 35px 0 35px;
}
.feature__title {
  margin: 0 0 29px;
}
.feature__list {
  margin: 0 auto;
  width: 90%;
}
.feature__list_item {
  background: #fff;
  border-radius: 10px;
  padding: 15px;
  width: 100%;
}
.feature__list_item + .feature__list_item {
  margin: 27px 0 0;
}
.feature__img img {
  margin: 0 auto 15px;
  width: 35vw;
  /*max-width:260px;*/
}
.feature__catch {
  color: #122565;
  font-size: 42px;
  font-size: 5.6vmin;
  font-weight: 600;
  line-height: 1.4;
  margin: 0 0 15px;
  text-align: center;
}
.feature__sub_catch {
  display: block;
  font-size: 35px;
  font-size: 4.66667vmin;
  font-weight: 400;
}
.feature__text {
  font-size: 27px;
  font-size: 3.6vmin;
  font-weight: bold;
}
@media screen and (min-width: 750px) {
  .feature {
    padding: 55px 0 55px;
  }
  .feature__title {
    margin: 0 0 35px;
  }
  .feature__list_item {
    padding: 30px;
  }
  .feature__list_item + .feature__list_item {
    margin: 40px 0 0;
  }
  .feature__img img {
    width: 240px;
  }
  .feature__sub_catch {
    font-size: 30px;
  }
  .feature__text {
    font-size: 25px;
  }
}
/*基礎知識*/
.kl {
  background: #f5f4dd;
  padding: 35px 0 0;
}
.kl__sub_title {
  display: block;
  font-size: 30px;
  font-size: 4vmin;
  font-weight: 500;
  margin: 0 0 16px;
}
@media screen and (min-width:750px) {
  .kl__sub_title {
    font-size: 30px;
  }
}
.kl__title {
  color: #122565;
  font-size: 50px;
  font-size: 6.66667vmin;
  font-weight: bold;
  line-height: 1.2;
  margin: 0 0 30px;
  text-align: center;
}
.kl__title--em {
  position: relative;
  z-index: 0;
}
.kl__title--em:after {
  content: '';
  background: #fff71a;
  display: inline-block;
  height: 0.5em;
  position: absolute;
  left: 0;
  bottom: .1em;
  width: 100%;
  z-index: -1;
}
.kl__title--num {
  font-size: 60px;
  font-size: 8vmin;
}
/*基礎知識ボタン*/
.kl__toc {
  margin: 0 auto 35px;
  width: 100%;
}
.kl__toc_item {
  width: 100%;
}
.kl__toc_item + .kl__toc_item {
  margin: 13px 0 0;
}
.kl__toc_item a {
  align-items: stretch;
  background: #fff;
  border-radius: 5px;
  display: flex;
  text-align: center;
  position: relative;
  top: 0;
}
.kl__toc_item a:hover {
  box-shadow: 0 0 0 transparent;
}
.kl__toc_title {
  color: #fff;
  font-size: 29px;
  font-size: 3.86667vmin;
}
.kl__toc_title_wrap {
  align-items: center;
  background: #2a4192;
  border-radius: 5px 0 0 5px;
  display: inline-flex;
  justify-content: center;
  padding: 0 10px;
  width: 30%;
}
.kl__toc_num {
  background: #fff71a;
  border-radius: 50%;
  color: #2a4192;
  display: block;
  font-size: 50px;
  font-size: 6.66667vmin;
  font-weight: bold;
  line-height: 120%;
  margin: 5px auto 0;
  height: 60px;
  height: 8vmin;
  text-align: center;
  width: 60px;
  width: 8vmin;
}
.kl__toc_catch_wrap {
  align-items: center;
  display: flex;
  justify-content: space-between;
  position: relative;
  padding: 0 5% 0 10%;
  width: 100%;
}
.kl__toc_catch {
  color: #122565;
  font-size: 32px;
  font-size: 4.26667vmin;
  font-weight: 600;
  padding: 15px 5px;
  text-align: center;
}
.kl__toc_catch_icon {
  width: 5%;
}
@media screen and (min-width: 750px) {
  .kl {
    padding: 55px 0 0;
  }
  .kl__title {
    margin: 0 0 35px;
  }
  .kl__toc {
    margin: 0 auto 55px;
  }
}
/*基礎知識*/
.kl__card {
  overflow: hidden;
}
.kl__card_head {
  background: #2a4192;
  padding: 20px 20px 0;
}
.kl__card_title {
  color: #fff;
  font-size: 33px;
  font-size: 4.4vmin;
  font-weight: 500;
  text-align: center;
}
.kl__card_num {
  box-sizing: border-box;
  background: #fff71a;
  border-radius: 50%;
  color: #2a4192;
  display: inline-block;
  font-size: 40px;
  font-size: 5.33333vmin;
  line-height: 120%;
  margin: 0 0 0 0.5em;
  height: 50px;
  height: 6.66667vmin;
  text-align: center;
  width: 50px;
  width: 6.66667vmin;
}
/*head 吹き出し*/
.kl__catch {
  align-items: flex-end;
  display: flex;
  justify-content: space-between;
}
.kl__catch_balloon {
  background: #fff;
  border-radius: 10px;
  margin: 12px 10px 15px 0;
  padding: 15px 25px;
  position: relative;
  width: 100%;
}
.kl__catch_balloon:after {
  content: '';
  border: 9px solid transparent;
  border-left: 14px solid #fff;
  display: block;
  height: 19px;
  margin: auto;
  position: absolute;
  right: -20px;
  top: 0;
  bottom: 0;
}
.kl__catch_img {
  width: 25vw; /*25vw*/
  margin: 0 -10px 0 0;
}
.kl__catch_text {
  font-size: 33px;
  font-size: 4.4vmin;
  font-weight: 500;
  line-height: 1.2;
}
.kl__catch_text--em {
  color: #fc4545;
}
@media screen and (min-width:750px) {
  .kl__catch_img {
    width: 20%;
    margin: 0 -10px 0 0;
  }
}
/*コンテンツ部分*/
.kl__card_body {
  background: #fff;
  padding: 40px 20px;
}
.kl__card_cont--top {
  display: flex;
}
.kl__card_cont--bottom {
  padding: 0 0 30px;
}
.kl__card_cont_img {
  margin: 0 15px 0 0;
  width: 17%;
}
/* コンテンツ内ふきだし*/
.kl__cont_balloon {
  background: #f0f9ff;
  border: 2px solid #75bdeb;
  border-radius: 10px;
  margin: 0 0 30px;
  padding: 10px;
  position: relative;
  width: 80%;
}
.kl__cont_balloon:before, .kl__cont_balloon:after {
  content: '';
  height: 0;
  position: absolute;
  width: 0;
}
.kl__cont_balloon:before {
  border-right: 10px solid #75bdeb;
  border-left: 10px solid transparent;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  left: -20px;
  top: 17px;
}
.kl__cont_balloon:after {
  border-right: 10px solid #f1ffff;
  border-left: 10px solid transparent;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  left: -17px;
  top: 17px;
}
.kl__cont_text--balloon {
  font-size: 37px;
  font-size: 4.93333vmin;
  font-weight: 500;
  font-feature-settings: "palt";
  letter-spacing: -0.01em;
  line-height: 1.8;
}
.kl__cont_text--em {
  background: #fff71a;
  font-size: 37px;
  font-size: 4.93333vmin;
  font-weight: bold;
  padding: 0 5px;
}
.kl__cont_text--catch {
  font-size: 30px;
  font-size: 4vmin;
  font-weight: bold;
  margin: 0 0 20px;
}
.kl__cont_text {
  font-size: 27px;
  font-size: 3.6vmin;
  line-height: 1.85;
}
@media screen and (min-width:750px) {
  .kl__cont_text--balloon, .kl__cont_text--em {
    font-size: 30px;
  }
  .kl__cont_text--catch {
    font-size: 25px;
  }
  .kl__cont_text {
    font-size: 23px;
  }
}
/*POINT*/
.kl__point {
  background: #fff8fa;
  border-radius: 10px;
  border: 3px solid #ff96b6;
  padding: 15px 3vmin 20px;
  text-align: center;
}
.kl__point_title {
  background: #ff96b6;
  border-radius: 30px;
  color: #fff;
  display: inline-block;
  font-size: 27px;
  font-size: 3.6vmin;
  font-weight: 500;
  line-height: 1;
  letter-spacing: .07em;
  margin: 0 0 20px;
  padding: 10px 80px;
}
.kl__point_list {
  margin: 0 auto;
  text-align: left;
}
.kl__point_list--center {
  margin: 0 auto;
  text-align: center;
}
.kl__point_list_item, .kl__point_list_item--center {
  align-items: baseline;
  display: flex;
  font-weight: bold;
}
.kl__point_list_item--center {
  justify-content: center;
  margin: 0 0 20px;
}
.kl__point_list_item + .kl__point_list_item {
  margin: 17px 0 0;
}
.kl__point_list_item:before {
  content: '';
  background: url(../img/kl-check-icon.png) center bottom/contain no-repeat;
  display: block;
  min-height: 24px;
  margin-right: 2vmin;
  min-width: 6%;
  height: 100%;
}
.kl__point_list_text, .kl__point_list_text--center {
  font-size: 28px;
  font-size: 3.73333vmin;
}
.kl__point_list_text--center {
  position: relative;
}
.kl__point_list_text--center:before {
  background: url(../img/kl-check-icon.png) center/contain no-repeat;
  content: '';
  display: block;
  min-height: 24px;
  margin-right: 2vmin;
  min-width: 6%;
  height: 100%;
  position: absolute;
  left: -7%;
  top: 0;
}
.kl__point_list_text--em, .kl__point_list_text--large_em {
  color: #fc4545;
}
.kl__point_list_text--large_em {
  font-size: 30px;
  font-size: 4vmin;
}
@media screen and (min-width:750px) {
  .kl__point_list_text, .kl__point_list_text--center {
    font-size: 28px;
  }
  .kl__point_list_text--large_em {
    font-size: 30px;
  }
}
/*ランキング*/
.kl__rank_wrap {
  background: #fff;
  border-radius: 10px;
  padding: 15px;
  width: 100%;
}
.kl__rank_item {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
}
.kl__rank_item--left {
  align-items: center;
  display: inline-flex;
}
.kl__rank_item + .kl__rank_item {
  border-top: 2px solid #dcdcdc;
  margin: 15px 0 0;
  padding: 15px 0 0;
}
.kl__rank_icon {
  box-sizing: border-box;
  background: #ff96b6;
  border-radius: 50%;
  color: #fff;
  font-size: 24px;
  font-size: 3.2vmin;
  line-height: 1;
  margin: 0 15px 0 0;
  padding: 2.7vmin 2vmin;
}
.kl__rank_num {
  font-size: 28px;
  font-size: 3.73333vmin;
}
.kl__rank_name {
  font-size: 28px;
  font-size: 3.73333vmin;
  font-weight: 500;
  text-align: left;
}
/*STEP*/
.kl__step {
  align-items: center;
  background: #fff;
  border-radius: 5px;
  box-sizing: border-box;
  display: flex;
  justify-content: space-evenly;
  padding: 23px 10px 18px;
}
.kl__step_bg {
  box-sizing: border-box;
  background: url(../img/kl-step-bg.png) left top/100% no-repeat;
  padding: 20px 0vmin 11px 10px;
  position: relative;
  width: 45vmin;
}
.kl__step_title {
  color: #ff96b6;
  font-size: 26px;
  font-size: 3.46667vmin;
  font-weight: 600;
  position: absolute;
  left: 5px;
  top: -.8em;
}
.kl__step_item {
  display: flex;
  align-items: center;
}
.kl__step_item + .kl__step_item {
  margin: 4px 0 0;
}
.kl__step_num {
  box-sizing: border-box;
  background: #ff96b6;
  border-radius: 50%;
  color: #fff;
  display: block;
  font-size: 25px;
  font-size: 3.33333vmin;
  line-height: 130%;
  font-weight: bold;
  margin: 0 6px 0 0;
  text-align: center;
  height: 35px;
  height: 4.66667vmin;
  width: 35px;
  width: 4.66667vmin;
}
.kl__step_text {
  font-size: 25px;
  font-size: 3.33333vmin;
  font-weight: 600;
}
.kl__step--right {
  text-align: center;
}
.kl__step_complete {
  display: inline-block;
  font-size: 25px;
  font-size: 3.33333vmin;
  font-weight: 600;
  position: relative;
  z-index: 0;
}
.kl__step_complete:after {
  content: '';
  background: #fff71a;
  display: inline-block;
  height: 0.5em;
  position: absolute;
  left: 0;
  bottom: .1em;
  width: 100%;
  z-index: -1;
}
@media screen and (min-width: 750px) {
  .kl__step_item + .kl__step_item {
    margin: 15px 0 0;
  }
}
/*よくある質問*/
.faq {
  background: #f5f4dd;
  padding: 35px 0;
}
.faq__title {
  margin: 0 0 29px;
}
.faq__card {
  background: #fff;
  border: 3px solid #2a4192;
  border-radius: 10px;
}
.faq__card + .faq__card {
  margin: 20px 0 0;
}
.faq__q {
  align-items: center;
  display: flex;
  font-size: 30px;
  font-size: 4vmin;
  font-weight: 500;
  font-feature-settings: "palt";
  position: relative;
  padding: 20px 11vmin 20px 4vmin;
}
.faq__q:after {
  content: '';
  background: url(../img/faq-arrow-icon.png) center/contain no-repeat;
  display: block;
  height: 100%;
  max-height: 18px;
  margin: auto;
  position: absolute;
  right: 4vmin;
  top: 0;
  bottom: 0;
  transform: rotate(0deg);
  transition: 0.45s ease;
  width: 5%;
}
.faq__q.js-rotate-arrow:after {
  transform: rotate(540deg);
}
.faq__q:hover {
  cursor: pointer;
}
.faq__q_icon {
  margin: 0 10px 0 0;
  max-width: 10vmin;
}
.faq__q_text {
  width: calc(100% - 50px);
}
/*答え*/
.faq__a {
  height: -1%;
  opacity: 0;
  padding: 0 4vmin;
  transition: 0.3s ease;
  visibility: hidden;
}
.faq__a.js-toggle-show {
  opacity: 1;
  padding-bottom: 30px;
  height: 100%;
  visibility: visible;
}
.faq__a.js-toggle-show .faq__a_text {
  display: block;
}
.faq__a_text {
  display: none;
  font-size: 27px;
  font-size: 3.6vmin;
  line-height: 1.85;
}
.faq__a_text span.red {
  color: #f00000;
  font-weight: bold;
  font-size: 27px;
  font-size: 3.6vmin;
}
@media screen and (min-width: 750px) {
  .faq {
    padding: 55px 0;
  }
  .faq__title {
    margin: 0 0 35px;
  }
}
/*CTA フッター用*/
.cta--lg {
  background: #2a4192;
}
.cta__cont--lg {
  padding: 40px 3vmin 20px;
}
.cta__title_lg {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 41px;
  font-size: 5vmin;
  font-weight: 600;
  justify-content: center;
  margin: 0 0 20px;
  position: relative;
  text-align: center;
}
.cta__title_lg:before, .cta__title_lg:after {
  content: '';
  background: #fff;
  display: block;
  height: 3px;
  width: 2em;
}
.cta__title_lg:before {
  margin-right: 1.5vmin;
  transform: rotate(65deg) translate(0, 8px);
}
.cta__title_lg:after {
  margin-left: 1vmin;
  transform: rotate(-65deg) translate(0, 8px);
}
.cta__lg_inner {
  margin: 0 auto;
  width: 100%;
}
.cta__flex_box {
  align-items: center;
  display: flex;
  justify-content: center;
  margin: 0 0 20px -24px;
}
.cta__img {
  position: relative;
  width: 26%;
}
.cta__text_box {
  margin-left: 15px;
  width: auto;
}
@media screen and (min-width: 750px) {
  .cta__cont--lg {
    padding: 40px 2vmin 20px;
  }
  .cta__title_lg {
    font-size: 41px;
  }
}
.cta__sub_title--em {
  align-items: center;
  color: #fff71a;
  display: flex;
}
.cta__sub_title_num {
  font-weight: 600;
}
.cta__sub_title2 {
  border-top: 2px dotted #fff;
  border-bottom: 2px dotted #fff;
  color: #fff;
  font-size: 54px;
  font-size: 7.2vmin;
  font-weight: 600;
  font-feature-settings: "palt";
  line-height: 1.4;
  padding: 15px 0;
  white-space: nowrap;
}
.cta__btn_lg {
  padding: 0 4vmin;
  text-align: center;
}
.cta__btn_lg a {
  display: inline-block;
}
@media screen and (max-width: 750px) {
  .cta__btn_lg {
    padding: 0;
  }
}
/*footer*/
.footer {
  background: #e1f1f6;
}
.f_nav {
  align-items: center;
  display: flex;
  justify-content: center;
  padding: 25px 0 30px;
}
.f_nav__item + .f_nav__item {
  padding-left: 15px;
}
.f_nav__item + .f_nav__item a {
  border-left: 1px solid #333;
  line-height: 1;
  padding-left: 15px;
}
.f_nav__item a {
  color: #333;
  display: block;
  font-size: 22px;
  font-size: 2.93333vmin;
}
.f_nav__item a:hover {
  text-decoration: underline;
}
@media screen and (min-width:750px) {
  .f_nav__item a {
    font-size: 18px;
  }
}