/* 共通 */
p,a{
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
}

/* top */
/* SP */
@media screen and (max-width: 768px) {
  .fv-section{
    position: relative;
    z-index: 5;
  }
  .fv{
    margin-bottom: 0;
    padding-top: 0;
  }
  .fv__img{
    margin-bottom: 0;
  }
  .top-section{
    margin: 0;
    display: flex;
    justify-content: center; 
    align-items: center; 
    position: relative;
    padding-bottom: 24vw;
    padding-top: 20.533vw;
    margin-top: -20.533vw;
    background: linear-gradient(to bottom, #00aaff, #b3e0ff); /* 下にかけてのグラデーション */
  }
  .top-section::after{
    content: '';
    width: 100%; 
    height: 100%;
    background: repeating-linear-gradient(
        45deg, /* 斜線の角度 */
        rgba(255, 255, 255, 0.1), /* 斜線の色 (白の透明部分) */
        rgba(255, 255, 255, 0.1) 10px, /* 斜線の幅 */
        transparent 10px, /* 透明部分の開始 */
        transparent 20px /* 透明部分の終了 */);
    position: absolute; /* 絶対位置 */
    top: 0; 
    left: 0;
  }
  .top-section__inner{
    position: relative;
    z-index: 5;
    width: 100%;
  }
  .top-section__block{
    margin-bottom: 5.333vw;
  }
}
/* PC */
@media screen and (min-width: 769px) {
  .fv-section{
    position: relative;
    z-index: 5;
  }
  .fv{
    margin-bottom: 0;
  }
  .fv__img{
    margin-bottom: 0;
  }
  .top-section{
    display: flex;
    justify-content: center; 
    align-items: center; 
    position: relative;
    padding-bottom: 90px;
    padding-top: 75px;
    margin-top: -75px;
    background: linear-gradient(to bottom, #00aaff, #b3e0ff); /* 下にかけてのグラデーション */
  }
  .top-section::after{
    content: '';
    width: 100%; 
    height: 100%;
    background: repeating-linear-gradient(
        45deg, /* 斜線の角度 */
        rgba(255, 255, 255, 0.1), /* 斜線の色 (白の透明部分) */
        rgba(255, 255, 255, 0.1) 10px, /* 斜線の幅 */
        transparent 10px, /* 透明部分の開始 */
        transparent 20px /* 透明部分の終了 */);
    position: absolute; /* 絶対位置 */
    top: 0; 
    left: 0;
  }
  .top-section__inner{
    position: relative;
    z-index: 5;
    width: 100%;
  }
  .top-section__block{
    margin-bottom: 20px;
  }
}


/* promo */
/* SP */
@media screen and (max-width: 768px) {
  .promo__wrap{
    padding-left: 4vw;
    padding-right: 4vw;
  }
  .promo_ttl{
    color: #464646;
    text-align: center;
    font-size: 5.867vw;
    font-style: normal;
    font-weight: 700;
    line-height: 140%; /* 22.4px */
    position: relative;
  }
  .promo_ttl--white{
    color: #FFFFFF;
  }
  .promo_ttl::before, .promo_ttl::after {
    content: '';
    position: absolute;
    width: 0.533vw;
    height: 8.8vw;
    transform: rotate(25deg);
    background-color: #464646;
    bottom: 1.467vw;
  }
  .promo_ttl--white::before, .promo_ttl--white::after {
    background-color: #FFFFFF;
  }
  .promo_ttl::before{
    left: 4.666vw;
    transform: rotate(-25deg);
  }
  .promo_ttl::after{
    right: 5.666vw;
  }
  .promo__block{
    padding: 6.667vw 8vw;
    border-radius: 2.667vw;
    background: #EEFAFF; 
    margin-top: 2.133vw;
  }
  .promo__block__ttl{
    color: #464646;
    text-align: center;
    font-size: 4.267vw;
    font-style: normal;
    font-weight: 700;
    line-height: 120%; /* 19.2px */
    border-bottom: 2px dashed #464646;
    padding-bottom: 1.867vw;
  }
  .promo__block__txtarea{
    text-align: center;
    margin-top: 2.667vw;
  }
  .promo__block__txtarea__rub{
    color: #FF0000;
    font-size: 2.667vw;
    font-style: normal;
    font-weight: 700;
    line-height: 120%; /* 12px */
  }
  .promo__block__txtarea__txt{
    color: #FF0000;
    font-size: 9.333vw;
    font-style: normal;
    font-weight: 700;
    line-height: 120%; /* 42px */
    letter-spacing: 0.933vw;
  }
  .promo__block__img{
    margin-top: 5.333vw;
    display: block;
  }
  .promo__block__line-cv{
    margin-top: 5.333vw;
  }
  .promo__block__line-cv__link{
    color: #FFF;
    font-size: 4.8vw;
    font-style: normal;
    font-weight: 700;
    line-height: 155.556%; /* 28px */
    border-radius: 6.667vw;
    background: #1ABD00;
    box-shadow: 3px 5px 14px 0px rgba(0, 0, 0, 0.20);
    padding-top: 2.933vw;
    padding-bottom: 2.933vw;
  }
  .promo__block__line-cv__link::after{
    background-color: #FFF !important;
    mask-image: url(/_share/221114_42498_common_rn_btn_icon_arrow_black.svg) !important;
    mask-repeat: no-repeat;
    background-image: none !important;
  }
  .promo__cv{
    margin-top: 8vw;
    padding-left: 4vw;
    padding-right: 4vw;
  }
}
/* PC */
@media screen and (min-width: 769px) {
  .promo{
    max-width: 630px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  .promo_ttl{
    color: #464646;
    text-align: center;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 140%; /* 22.4px */
    position: relative;
  }
  .promo_ttl--white{
    color: #FFFFFF;
  }
  .promo_ttl::before, .promo_ttl::after {
    content: '';
    position: absolute;
    width: 2px;
    height: 38px;
    transform: rotate(25deg);
    background-color: #464646;
    bottom: -6px;
  }
  .promo_ttl--white::before, .promo_ttl--white::after {
    background-color: #FFFFFF;
  }
  .promo_ttl::before{
    left: 35px;
    transform: rotate(-25deg);
  }
  .promo_ttl::after{
    right: 35px;
  }
  .promo__block{
    padding: 25px 30px 20px;
    border-radius: 10px;
    background: #EEFAFF; 
    margin-top: 15px;
  }
  .promo__block__body{
    display: flex;
    gap: 30px;
    justify-content: center;
    align-items: center;
  }
  .promo__block__body__left{
    flex: 1;
  }
  .promo__block__ttl{
    color: #464646;
    text-align: center;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 120%; /* 19.2px */
    border-bottom: 2px dashed #464646;
    padding-bottom: 10px;
  }
  .promo__block__txtarea{
    text-align: center;
    margin-top: 10px;
  }
  .promo__block__txtarea__rub{
    color: #FF0000;
    font-size: 10px;
    font-style: normal;
    font-weight: 700;
    line-height: 120%; /* 12px */
  }
  .promo__block__txtarea__txt{
    color: #FF0000;
    font-size: 35px;
    font-style: normal;
    font-weight: 700;
    line-height: 120%; /* 42px */
    letter-spacing: 3.5px;
  }
  .promo__block__img{
    display: block;
    max-width: 215px;
    width: 100%;
    height: auto;
  }
  .promo__block__line-cv{
    margin-top: 20px;
  }
  .promo__block__line-cv__link{
    color: #FFF;
    width: 500px;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 155.556%; /* 28px */
    border-radius: 25px;
    background: #1ABD00;
    box-shadow: 3px 5px 14px 0px rgba(0, 0, 0, 0.20);
    padding-top: 11px;
    padding-bottom: 11px;
    margin-right: auto;
    margin-left: auto;
  }
  .promo__block__line-cv__link::after{
    background-color: #FFF !important;
    mask-image: url(/_share/221114_42498_common_rn_btn_icon_arrow_black.svg) !important;
    mask-repeat: no-repeat;
    background-image: none !important;
  }
  .promo__cv{
    margin-top: 30px;
  }
  .promo__cv__link{
    max-width: 500px;
    padding: 16px 16px 18px 16px;
  }
}


/* main-section */
/* SP */
@media screen and (max-width: 768px) {
  .main-section{
    border-radius: 8vw 8vw 0px 0px;
    background: #0077D5;
    padding: 16vw 4vw;
    margin-top: -9.333vw;
    position: relative;
    z-index: 5;
  }
  .grade__list{
    display: flex;
    flex-direction: column;
    gap: calc(16vw / 3.75);
    justify-content: center;
    margin: 0 4vw;
  }
  .grade__list:not(:first-child){
    margin-top: calc(45vw / 3.75);
  }
  .grade__list__item__link{
    text-decoration: none;
    width: 100%;
    padding: calc(14vw / 3.75);
    border-radius: calc(48vw / 3.75);
    background-color: #fff;
    color: #464646;
    text-align: center;
    line-height: 150%; /* 24px */
    font-weight: 700;
    position: relative;
    display: block;
    font-size: 4.267vw;
  }
  .grade__list__item__link::after{
    content: "";
    position: absolute;
    display: block;
    width: calc(11vw / 3.75);
    height: calc(11vw / 3.75);
    right: calc(28vw / 3.75);
    background-color: #0077D5;
    mask-image: url(/_share/221114_42498_common_rn_btn_icon_arrow_blue.svg);
    mask-repeat: no-repeat;
    background-image: none;
    margin-top: auto;
    margin-bottom: auto;
    top: 0;
    bottom: 0;
  }
  .grade-cont{
    margin-top: 16vw;
  }
  .grade-cont__inner{
    padding: 10.667vw 4vw 16vw 4vw;
    border-radius: 2.667vw;
    background: #FFF;
  }
  .grade-cont__ttl{
    color: #0077D5;
    text-align: center;
    font-size: 6.933vw;
    font-style: normal;
    font-weight: 700;
    position: relative;
    display: flex;
    justify-content: center;  
    gap: 2.667vw;  
  }
  .grade-cont__ttl::before, .grade-cont__ttl::after {
    content: '';
    position: absolute;
    width: 0.72vw;
    height: 10.4vw;
    background-color: #0077D5;
    top: 0;
  }
  .grade-cont__ttl::before{
    left: 16.666vw;
  }
  .grade-cont__ttl::after{
    right: 16.666vw;
  }
  .grade-cont__block{
    margin-top: 10.667vw;
  }
  .grade-cont__block__ttl{
    color: #0077D5;
    font-size: 5.867vw;
    font-style: normal;
    font-weight: 700;
    display: block;
    line-height: 140%;
    text-align: center;
  }
  .grade-cont__block__ttl--min{
    color: #0077D5;
    font-size: 4.8vw;
    font-style: normal;
    font-weight: 700;
    display: block;
    line-height: 140%;
    display: block;
  }
  .grade-cont__block__ttl--big{
    color: #0077D5;
    font-size: 6.933vw;
    font-style: normal;
    font-weight: 700;
    line-height: 140%;
    text-align: center;
    display: block;
  }
  .grade-cont__block__txt{
    margin-top: 2.667vw;
    color: #464646;
    font-size:3.733vw;
  }
  .grade-body{
    margin-top: 5.333vw;
    padding-left: 4vw;
    padding-right: 4vw;
  }
  .grade-body__caption{
    color: #464646;
    text-align: center;
    font-size: 3.733vw;
    font-style: normal;
    font-weight: 400;
    margin-top: 2.667vw;
  }
  .grade-cont__block__point-ttl__wrap{
    text-align: center;
  }
  .grade-cont__block__point-label{
    padding: 1.333vw 2.667vw;
    align-items: center;
    background: #0077D5;
    color: #fff;
    display: inline;
    font-weight: 700;
    font-size: 4.267vw;
  }
  .grade-cont__block__point-ttl{
    color: #464646;
    text-align: center;
    font-size: 4.8vw;
    font-style: normal;
    font-weight: 700;
    line-height: 150%; /* 27px */
    margin-top: 4vw;
  }
  .grade-cont__block__point-fuki{
    padding: 2.133vw 2.667vw;
    align-items: center;
    display: inline-block;
    font-weight: 700;
    font-size: 4.267vw;
    line-height: 1;
    border: 2px solid #0077D5;
    position: relative;
    color: #0077D5;
    margin-bottom: 2.133vw;
  }
  .grade-cont__block__point-fuki::before{
    position: absolute;
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
    border-top: 8px solid #0077d5;
    border-bottom: 0;
    left: 0;
    right: 0;
    bottom: -2.133vw;
    margin-right: auto;
    margin-left: auto;
    display: block;
  }
  .grade-cont__link-deco {
    color: #0077D5;
    font-size: 4.267vw;
    font-style: normal;
    font-weight: 700;
    line-height: 140%;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1.333vw;
    margin-top: 8vw;
  }
  .grade-cont__link-deco::before,
  .grade-cont__link-deco::after {
    content: '';
    flex: 1; 
    background-image: url(/lp/digi_teikitest_ht/250619_60010_lp_start23sp_border_sp.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    width: auto;
    height: 0.8vw;
    display: block;
    padding-right: 4vw;
    padding-left: 4vw;
  }
}
/* PC */
@media screen and (min-width: 769px) {
  .main-section{
    border-radius: 30px 30px 0px 0px;
    background: #0077D5;
    padding: 40px 30px;
    margin-top: -30px;
    position: relative;
    z-index: 5;
  }
  .grade__list{
    max-width: 375px;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
    justify-content: center;
  }
  .grade__list:not(:first-child){
    margin-top: 45px;
  }
  .grade__list__item__link{
    text-decoration: none;
    width: 100%;
    padding: 18px 20px;
    border-radius: 48px;
    background-color: #fff;
    color: #000;
    text-align: center;
    font-size: 18px;
    line-height: 1.4;
    font-weight: 700;
    position: relative;
    display: block;
  }
  .grade__list__item__link::after{
    content: "";
    position: absolute;
    display: block;
    width: 11px;
    height: 11px;
    right: 28px;
    background-color: #0077D5;
    mask-image: url(/_share/221114_42498_common_rn_btn_icon_arrow_blue.svg);
    mask-repeat: no-repeat;
    background-image: none;
    margin-top: auto;
    margin-bottom: auto;
    top: 0;
    bottom: 0;
  }
  .grade-cont{
    margin-top: 40px;
  }
  .grade-cont__inner{
    padding: 40px 40px 60px 40px;
    border-radius: 10px;
    background: #FFF;
  }
  .grade-cont__ttl{
    color: #0077D5;
    text-align: center;
    font-size: 26px;
    font-style: normal;
    font-weight: 700;
    position: relative;
    display: flex;
    justify-content: center;  
    gap: 10px;  
  }
  .grade-cont__ttl::before, .grade-cont__ttl::after {
    content: '';
    width: 2px;
    height: 39px;
    background-color: #0077D5;
    top: 0;
  }
  .grade-cont__ttl::before{
    left: 0;
  }
  .grade-cont__ttl::after{
    right: 0;
  }
  .grade-cont__block{
    margin-top: 40px;
  }
  .grade-cont__block__ttl{
    color: #0077D5;
    font-size: 22px;
    font-style: normal;
    font-weight: 700;
    display: block;
    line-height: 140%;
    text-align: center;
  }
  .grade-cont__block__ttl--min{
    color: #0077D5;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    display: block;
    line-height: 140%;
    display: block;
  }
  .grade-cont__block__ttl--big{
    color: #0077D5;
    font-size: 28px;
    font-style: normal;
    font-weight: 700;
    line-height: 140%;
    text-align: center;
    display: block;
  }
  .grade-cont__block__txt{
    margin-top: 10px;
    color: #464646;
    font-size:14px;
    text-align: center;
  }
  .grade-body{
    margin-top: 20px;
    max-width: 390px;
    margin-left: auto;
    margin-right: auto;
  }
  .grade-body__caption{
    color: #464646;
    text-align: center;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    margin-top: 10px;
  }
  .grade-cont__block__point-ttl__wrap{
    text-align: center;
  }
  .grade-cont__block__point-label{
    padding: 5px 10px;
    align-items: center;
    background: #0077D5;
    color: #fff;
    display: inline;
    font-weight: 700;
    font-size: 16px;
  }
  .grade-cont__block__point-ttl{
    color: #464646;
    text-align: center;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%; /* 27px */
    margin-top: 20px;
  }
  .grade-cont__block__point-fuki{
    padding: 8px 10px;
    align-items: center;
    display: inline-block;
    font-weight: 700;
    font-size: 16px;
    line-height: 1;
    border: 2px solid #0077D5;
    position: relative;
    color: #0077D5;
    margin-bottom: 10px;
  }
  .grade-cont__block__point-fuki::before{
    position: absolute;
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
    border-top: 8px solid #0077d5;
    border-bottom: 0;
    left: 0;
    right: 0;
    bottom: -10px;
    margin-right: auto;
    margin-left: auto;
    display: block;
  }
  .grade-cont__link-deco {
    color: #0077D5;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 140%;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px;
    margin-top: 30px;
    padding-right: 15px;
    padding-left: 15px;
  }
  .grade-cont__link-deco::before,
  .grade-cont__link-deco::after {
    content: '';
    flex: 1; 
    background-image: url(/lp/digi_teikitest_ht/250619_60010_lp_start23sp_border_pc.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    width: auto;
    height: 3px;
    display: block;
  }
}


/* カルーセル */
/* SP */
@media screen and (max-width: 768px) {
  .grade-carousel.c-carousel__dot{
    margin-top: 3vw;
  }
}
/* PC */
@media screen and (min-width: 769px) {
  .grade-carousel.c-carousel__dot{
    margin-top: 10px;
  }
}


/* 共通パーツ */
.c-acc-text__head--remark, .c-remark-list__item{
  color: #464646;
}
.c-acc-text--white .c-acc-text__head--remark,.c-acc-text--white .c-remark-list__item{
  color: #fff;
}
.c-acc-text--white>.c-acc-text__head.c_rn-acc-text__head::after{
  background-image: url(/lp/digi_teikitest_ht/acc_open_white.svg);
}
.c-acc-text--white>.c-acc-text__head.c_rn-acc-text__head.js-c-acc-text-open::after{
  background-image: url(/lp/digi_teikitest_ht/acc_close_white.svg);
}
/* PC */
@media screen and (min-width: 769px) {
  .c-carousel__dot{
    margin-top: 15px;
  }
  .c-carousel__arrow{
    bottom: 20px;
  }
}