@charset "UTF-8";
@import url("https://cdnjs.cloudflare.com/ajax/libs/meyer-reset/2.0/reset.min.css");
* {
    top: min(var(--top) * 1vw / 19.2, var(--top) * 1px);
    left: min(var(--left) * 1vw / 19.2, var(--left) * 1px);
    right: min(var(--right) * 1vw / 19.2, var(--right) * 1px);
    width: min(var(--width) * 1vw / 19.2, var(--width) * 1px);
    height: min(var(--height) * 1vw / 19.2, var(--height) * 1px);
    font-family: "メイリオ", Meiryo, "Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
}
body {
    align-items: center;
    background-color: var(--white);
}
.wrapper {
    overflow-x: hidden;
}
body .inner_wrap {
    max-width: 1200px;
    height: 100%;
    width: 100%;
    margin: 0 auto;
    align-items: center;
    padding: 0 6.4rem;
}
@media screen and (max-width: 1100px) {
    body .inner_wrap {
        max-width: 1200px;
        height: 100%;
        width: 100%;
        margin: 0 auto;
        align-items: center;
        padding: 0 3.2rem;
    }
}
@media screen and (max-width: 520px) {
    body .inner_wrap {
        max-width: 1200px;
        height: 100%;
        width: 100%;
        margin: 0 auto;
        align-items: center;
        padding: 0 1rem;
    }
}
.sp_block {
    display: none;
}
.bg_green_toptxt {
    align-items: center;
    background-color: var(--aqua-spring);
    border-radius: 15px;
    display: flex;
    justify-content: center;
    margin: auto;
    padding: 2rem;
    width: 65%;
}
.bg_green_toptxt .inner_toptxt {
    line-height: 37.5px;
    text-align: center;
}
/*　詳しく見るボタン　*/
.btn_readme {
    background-color: var(--white);
    border: 1px solid;
    border-color: #20a392;
    border-radius: 50px;
    color: #333;
    box-shadow: 0px 4px 4px #00000040;
    height: 64px;
    position: relative;
    max-width: 400px;
    text-align: center;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
    align-self: stretch;
    margin-top: 2rem;
    position: relative;
}
.btn_readme:hover {
    top: 10px;
    transition: 0.3s;
    box-shadow: none;
}
.btn_readme .circle {
    align-items: flex-end;
    align-self: center;
    background-color: #019682;
    border-radius: 100px;
    display: flex;
    height: 31px;
    margin-top: 0;
    min-width: 30px;
    padding: 10.8px 9.3px;
    position: absolute;
    right: 26px;
}
.btn_readme .arrow {
    border-bottom-style: solid;
    border-bottom-width: 1px;
    border-color: var(--white);
    border-right-style: solid;
    border-right-width: 1px;
    height: 8px;
    transform: rotate(-46.55deg);
    width: 8px;
}
/*　詳しく見るボタン　*/
/*　=====================================================================

固定ヘッダー
navbar

=====================================================================   */
.navbar {
    z-index: 10;
    position: fixed;
    width: 100%;
    background: #fff;
    height: 120px;
    box-shadow: 0 0 12px 0 #8d8d8d;
}
.navbar .sp_none {
    display: none;
}
.navbar .pc_none {
    display: block;
}
.navbar .inner_wrap {
    align-items: center;
    justify-content: space-between;
    display: flex;
    max-width: 1440px;
    padding: 0 1rem;
    text-align: center;
}
.navbar .logo {
    max-width: 195px;
    width: min(185 / 1200 * 100vw, 185px);
    margin-right: 2rem;
    min-width: 105px;
}
.navbar .navbar-link {
    letter-spacing: 0;
    align-content: center;
}
.navbar .navbar-link a {
    color: #333;
    text-decoration: none;
    font-size: clamp(0.75rem, 0.699rem + 0.25vw, 1rem);
}
.navbar .navbar-link a:hover {
    opacity: 0.5;
}
.navbar .nav_btn {
    align-items: flex-start;
    background-color: #ff5463;
    border: 0px none;
    border-radius: 6px;
    display: flex;
    gap: 8px;
    height: 56px;
    justify-content: flex-end;
    margin-left: 1rem;
    padding: 0 12px;
    justify-content: center;
}
.navbar .nav_btn .nav_btn_img {
    height: 78px;
    margin-top: -21px;
    width: 58px;
}
.navbar .nav_btn .nav_btn_txt {
    align-self: center;
    height: 30px;
    letter-spacing: 0.8px;
    line-height: 20px;
    margin-bottom: 3px;
    max-width: 264px;
}
.navbar #global-nav {
    display: flex;
    justify-content: space-between;
    align-content: center;
    gap: 2rem;
}
@media screen and (max-width: 1342px) {
    .navbar .nav_btn .nav_btn_img {
        width: 50px;
        margin-top: -16px;
    }
    .navbar .nav_btn .nav_btn_txt {
        font-size: 1rem !important;
    }
}
@media screen and (max-width: 1100px) {
    .navbar {
        height: 70px;
    }
    .navbar .sp_none {
        display: block;
    }
    .navbar .sp_none .nav_btn {
        width: calc(100% - 2rem)
    }
    .navbar .pc_none {
        display: none;
    }
}
@media screen and (max-width: 1330px) {
    .navbar #global-nav {
        gap: 1rem;
    }
}
/* sp　ハンバーガーメニュー */
.hamburger .btn-gNav {
    position: fixed;
    top: 1.5rem;
    right: 2rem;
    width: 30px;
    height: 24px;
    z-index: 150001;
    box-sizing: border-box;
    cursor: pointer;
    transition: all 400ms;
}
.hamburger .btn-gNav.close span {
    left: 30%;
}
.hamburger .btn-gNav.close span:nth-of-type(1) {
    transform: rotate(45deg);
}
.hamburger .btn-gNav.close span:nth-of-type(2) {
    opacity: 0;
}
.hamburger .btn-gNav.close span:nth-of-type(3) {
    top: 0px;
    transform: rotate(-45deg);
}
.hamburger .btn-gNav span {
    position: absolute;
    width: 100%;
    height: 4px;
    background: #ccc;
    border-radius: 10px;
    transition: all 400ms;
}
.hamburger .btn-gNav span:nth-child(1) {
    top: 0;
}
.hamburger .btn-gNav span:nth-child(2) {
    top: 10px;
}
.hamburger .btn-gNav span:nth-child(3) {
    top: 20px;
}
.hamburger .btn-gNav.open span:nth-child(1) {
    background: #ccc;
    top: 6px;
    transform: rotate(-45deg);
}
.hamburger .btn-gNav.open span:nth-child(2),
.hamburger .btn-gNav.open span:nth-child(3) {
    top: 6px;
    background: #ccc;
    transform: rotate(45deg);
}
.gNav {
    display: flex;
}
.btn-gNav {
    display: none;
}
.gNav .gNav-menu {
    display: flex;
    justify-content: space-between;
}
.gNav .gNav-menu li {
    margin: 0 auto;
    padding: 0 5px;
}
@media screen and (max-width: 1330px) {
    .navbar .nav_btn .nav_btn_txt {
        width: auto;
    }
}
@media screen and (min-width: 1101px) {
    .gNav {
        display: flex;
        gap: 2rem;
    }
}
@media screen and (max-width: 1100px) {
    .btn-gNav {
        display: block;
    }
    .gNav {
        position: fixed;
        top: 0;
        right: -100%;
        width: 100%;
        height: 100%;
        background-color: rgba(0, 0, 0, 0.85);
        font-size: 16px;
        box-sizing: border-box;
        z-index: 150000;
        padding-top: 75px;
        transition: 0.3s;
    }
    .gNav.open {
        right: 0;
    }
    .gNav .gNav-menu {
        padding: 0;
        width: 100%;
        height: 100%;
        display: block;
        flex-direction: column;
        text-align: center;
    }
    .gNav .gNav-menu li {
        width: 86%;
        padding: 15px;
        border-bottom: #525252 1px solid;
    }
    .gNav.open {
        display: flex;
        flex-direction: column;
    }
    .navbar .navbar-link a {
        color: #fff;
        text-decoration: none;
        display: block;
        line-height: 70px;
        height: 70px;
        font-size: 16px;
        border-top: 1px solid #444;
    }
}
/*　=====================================================================

メインビジュアル
mainvisual

=====================================================================   */
.mainvisual {
    align-items: flex-start;
    width: 100%;
    background-color: #f8eb00;
    background-size: cover;
    background-position: 0rem;
    background-repeat: no-repeat;
}
.mainvisual .hero_img_wrap {
    text-align: center;
    margin: auto;
}
.mainvisual img.hero_img {
    width: 100%;
}
.mainvisual .hero_txt{
    max-width: 1440px;
    margin:auto;
    text-align: center;
}
.mainvisual .hero_txt img{
   max-width: 780px;
   width: auto;
   max-height: 140px;
}
.mainvisual .description_group {
    margin: auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-width: 1200px;
}
.mainvisual .sub_description_inner_wrap {
    margin: auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}
.mainvisual .main-txt .main-txt-img {
    max-width: 685px;
    width: 100%;
    height: auto;
    padding-left: 4rem;
}
.mainvisual .laurel_group {
    text-align: center;
    display: flex;
}
.mainvisual .laurel {
    max-width: 350px;
    width: 100%;
}
.mainvisual .description01 {
    color: var(--mine-shaft);
    font-size: clamp(1rem, 0.52rem + 0.81vw, 1.538rem);
    font-weight: 700;
    line-height: 24px;
    text-align: center;
    background: #ffffff;
    border-radius: 8px;
    padding: 1rem;
}
.mainvisual .description02 {
    letter-spacing: 0;
    line-height: 24px;
    text-align: left;
    font-size: 14px;
    display: flex;
    justify-content: flex-start;
    flex-direction: row;
    gap: 1rem;
}
.mainvisual .description03 {
    margin: auto;
    letter-spacing: 0;
    line-height: 32px;
    text-align: left;
}
.mainvisual_bottom_group {
    margin: auto;
    flex-direction: column;
    display: flex;
    padding-bottom: 3rem;
}


.mainvisual_bottom_group .bg_grad{
    background-image: linear-gradient(#FD8040, #F8EB00);
}

.mainvisual_bottom_group .main_subtxt{
    text-align: center;
    font-size: 3rem;
    font-weight: bold;
    color:#fff;
    margin: 2rem 0 ;
}


.mainvisual_bottom_group .inner_wrap{
        max-width: 1440px;
}

.mainvisual_bottom_group .main_subtxt .br{
    display:none
}

@media (max-width: 1200px) {
    .mainvisual {
        width: 100%;
    }
.mainvisual .hero_txt img{
   max-width: 100%;
   width: auto;
   max-height: 140px;
}
}
@media (max-width: 945px) {
.mainvisual_bottom_group .main_subtxt{
    font-size: 2rem;
}

}
@media (max-width: 768px) {
    .mainvisual .description_group {
        width: 100%;
        padding: 0 1rem;
        bottom: 5%;
    }
    .mainvisual .description01, .mainvisual .description02, .mainvisual .description03 {
        line-height: 30px
    }
    .mainvisual_bottom_group .main_subtxt .br{
        display:block
    }
    .mainvisual .sub_description_inner_wrap {
        width: 100%
    }

    
}
@media (max-width: 719px) {
    .mainvisual .description_group {
        width: 100%;
        padding: 0 1rem;
        bottom: 2%;
    }
    .mainvisual .description01, .mainvisual .description02, .mainvisual .description03 {
        line-height: 25px;
    }
    .mainvisual img.hero_img {
        max-width: 100%;
        width: auto;
    }
    .mainvisual .sub_description_inner_wrap {
        width: 100%
    }
}
@media (max-width: 700px) {
    .mainvisual .laurel_group {
        flex-wrap: wrap;
        justify-content: center;
    }
    .mainvisual .laurel {
        max-width: 150px;
        width: 100%;
    }
    .mainvisual {
    }
}

@media (max-width: 400px) {
.mainvisual .description02{
    font-size:12px;
}
}

/*　=====================================================================

「その後の人生」 考えていますか？
section_appeal

=====================================================================   */
.section_appeal {
    background-image: url(../img/section_appeal_bg.png);
    background-size: cover;
    background-repeat: no-repeat;
    padding-bottom: 4rem;
    background-position: bottom center;
    margin-top: -3px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 2rem;
}
.section_appeal .sp_none {
    display: block;
}
.section_appeal .pc_none {
    display: none;
}
@media (max-width: 767px) {
    .section_appeal .inner_wrap {
        padding: 0rem 1rem;
    }
    .section_appeal {
    background-image: url(../img/section_appeal_bg.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: left 51.5% bottom 0rem;
    margin-top: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-bottom: 4rem;
}
}
.section_appeal .inner_flex {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 17px;
}
@media (max-width: 767px) {
    .section_appeal .inner_flex {
        flex-direction: column;
    }
}
.section_appeal .appeal-txt {
    justify-content: center;
    display: flex;
    flex-direction: column;
    gap: 2rem;
    flex: 1 0 59%;
}
@media (max-width: 767px) {
    .section_appeal .appeal-txt {
        gap: 24px;
    }
}
.section_appeal .appeal-white-balloon {
    align-items: center;
    justify-content: center;
    background-color: var(--white);
    border-radius: 8px;
    display: flex;
    padding: 1.5rem 0.5rem;
    line-height: 2rem;
}
.section_appeal .appeal-imgwrap {
    align-items: center;
    justify-content: center;
    display: flex;
    max-width: 404px;
    width: 100%
}
.section_appeal .appeal-imgwrap img {
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
}
.section_appeal .description {
    left: 0;
    letter-spacing: 0;
    line-height: 40px;
}
.section_appeal .span0-4 {
    color: #f18200;
    font-size: clamp(1.35rem, 1.148rem + 0.5vw, 1.75rem);
    font-weight: 700;
}

@media (max-width: 767px) {
    .section_appeal .appeal-imgwrap img {
    max-width: 200px;
}
}

@media (max-width: 500px) {
.section_appeal .appeal-white-balloon {
    align-items: center;
    justify-content: center;
    background-color: var(--white);
    border-radius: 8px;
    display: flex;
    padding: 0.8rem 0.5rem;
    line-height: 2rem;
}
}
@media (max-width: 375px) {
    .section_appeal .span0-4 {
        color: #f18200;
        font-size: clamp(1rem, 1rem + 1vw, 2.5rem);
        font-weight: 700;
    }
}
/*　=====================================================================

エンジニアに必要なのは自走し続ける力！
section_appeal02　

=====================================================================   */
.section_appeal02 {
    background-color: var(--white);
    padding-bottom: 3rem;
}
.section_appeal02 .inner_flex {
    align-items: center;
    justify-content: center;
    display: flex;
    gap: 83px
}
.section_appeal02 .txt_wrap {
    display: flex;
    flex-direction: column;
    gap: 40px;
    flex: 1 50%;
}
.section_appeal02 p {
    line-height: 3rem;
}
.section_appeal02 .img_wrap {
    display: flex;
    justify-content: center;
    mix-blend-mode: multiply;
    padding: 0.0px 0;
    position: relative;
    flex: 0 auto;
    width: 50%;
}
.section_appeal02 .overlap-group-8 {
    height: 567px;
    position: relative;
    width: 648px;
}
.section_appeal02 .appeal02-img {
    max-height: 535px;
    max-width: 100%;
    left: 0;
}
.section_appeal02 .top-main-beyond-1 {
    left: -140px;
    position: absolute;
    top: 0;
}
@media (max-width: 767px) {
    .section_appeal02 .img_wrap {
        width: 100%;
    }
    .section_appeal02 .top-main-beyond-1 {
        left: 0px;
        z-index: -1;
    }
    .section_appeal02 .inner_flex {
    align-items: center;
    justify-content: center;
    display: flex;
    gap: 83px
}
.section_appeal02 .txt_wrap {
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1 50%;
}
.section_appeal02 p {
    line-height: 2.5rem;
}
    .section_appeal02 .appeal02-img {
    max-height: 250px;
    max-width: 100%;
    left: 0;
}
}
/*　黄色線　*/
.section_appeal02 .rectangle-1702 {
    background-color: var(--turbo);
    height: 8px;
    margin-left: 6px;
    margin-top: 6px;
    width: 230px;
}
@media (max-width: 767px) {
    .section_appeal02 .inner_flex {
        flex-direction: column-reverse;
        gap: 1rem;
    }
}
@media screen and (max-width: 1112px) {
    .sp_none {
        display: none;
    }
}
@media (max-width: 420px) {
    .section_appeal02 .inner_flex {
        flex-direction: column-reverse;
        gap: 0rem;
    }
   .section_appeal02 .appeal02-img {
        max-height: 250px;
        max-width: 100%;
        left: 0;
    }
    .section_appeal02 p {
    line-height: 1.85rem;
    margin-top: 1rem;
}
    .section_appeal02 .rectangle-1702 {
    width: 230px;
}
}
/*　=====================================================================

IT道場は「魚を釣ってあげる」のではなく、
魚の釣り方を教えるプログラミングスクールです。
section-about

=====================================================================   */
.section-about {
    background-image: url(../img/about-bg.svg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: bottom 0rem center;
    padding-bottom: 4rem;
    position: relative;
}
.section-about .balloon {
    color: var(--mine-shaft);
    font-size: clamp(2rem, 1.792rem + 1.04vw, 3.038rem);
    font-weight: 700;
    letter-spacing: 0;
    text-align: center;
    background: url(../img/abount-balloon.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    margin-top: 2rem;
    width: 100%;
    min-height: 90px;
    padding-top: 1rem;
    margin-bottom: 2rem;
}
.section-about .bg {
    background-image: url(../img/about-bg-dot.png);
    background-size: 100% 100%;
    height: 251px;
    left: 422px;
    position: absolute;
    top: 172px;
    width: 289px;
    z-index: 0;
}
.section-about .about-txt {
    letter-spacing: 0;
    line-height: 52.8px;
    width: 55%;
    display: flex;
    flex: 0 0 58%;
    flex-direction: column;
}
@media (max-width: 767px) {
    .section-about .about-txt {
        width: 100%;
        flex: 1 1 100%;
    }
    .section-about .about-txt {
    letter-spacing: 0;
    line-height: 40px;
}
    .section-about .balloon {
    color: var(--mine-shaft);
    font-size: clamp(2rem, 1.792rem + 1.04vw, 3.038rem);
    font-weight: 700;
    letter-spacing: 0;
    text-align: center;
    background: url(../img/abount-balloon.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    margin-top: 1rem;
    width: 100%;
    min-height: 90px;
    padding-top: 1.4rem;
    margin-bottom: 0rem;
}
}
.section-about .about-txt .inter-bold-eerie-black-40px {
    display: inline-block;
}
.section-about .about-txt .text-4-1 {
    background: #fff;
    color: #FE7B22;
    max-width: 470px;
    padding: 0 0.5rem;
    margin-right: 0.3em;
    text-align: center;
    display: inline-block;
}
@media (max-width: 767px) {
    .section-about .about-txt .text-4-1 {
        margin-right: 0;
        display: inline-block;
    }
}
.section-about .about-txt .description-1 {
    margin-top: 1rem;
}
.section-about .img_wrap {
    margin-top: -50px;
    margin-right: -50px;
}
.section-about .img_wrap img {
    width: 100%;
}
.section-about .linkbnr_wrap {
    padding: 0;
}
@media (max-width: 767px) {
    .section-about .img_wrap {
        margin: auto;
    }
    .section-about .img_wrap img {
        width: auto;
        max-width: 250px;
    }
}
.section-about .inner_flex {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}
@media (max-width: 767px) {
    .section-about .inner_flex {
        flex-direction: column;
    }
}
/*　=====================================================================

こんなお悩みありませんか？
section_problem

=====================================================================   */
.section_problem .inner_wrap {
    position: relative;
}
.section_problem .image-container {
    margin: 5rem auto -6px;
    text-align: center;
}
.section_problem .image-container img {
    max-width: 525px;
    width: auto;
}
.section_problem .problem_top_wish {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: center;
}
@media (max-width: 767px) {
    .section_problem .problem_top_wish {
        margin-right: 0;
    }
    .section_problem .image-container img {
        max-width: 100%;
        width: auto;
    }
}
.section_problem .overlap-group48 {
    align-items: center;
    justify-content: center;
    background-color: var(--lemon-chiffon);
    border: 2px solid;
    border-color: var(--mine-shaft);
    border-radius: 8px;
    display: flex;
    height: 144px;
    line-height: 1.8rem;
    width: 250px;
    padding: 16px 0;
}
@media (max-width: 1220px) {
    .section_problem .overlap-group48 {
        width: 200px
    }
    .section_problem .overlap-group48 .text-2 {
        font-size: 0.85rem;
    }
}
@media (max-width: 768px) {
    .section_problem .overlap-group48 {
        width: 160px;
        height: 100px;
        line-height: 1rem;
        padding: 8px 0;
    }
}
.section_problem .arrow_bottom_but {
    text-align: center;
    margin: 2rem auto;
}
.section_problem .arrow_bottom_but img {
    width: auto;
    max-width: 100%;
}
.section_problem .sp_block {
    display: none;
}
@media (max-width: 619px) {
    .section_problem .sp_block {
        display: block;
    }
    .section_problem .arrow_bottom_but {
        text-align: center;
        margin: 2rem auto 1rem;
    }
}
@media (max-width: 1199px) {
    .section_problem .problem_top_wish {
        flex-wrap: wrap;
    }
}
.section_problem .decoration-english {
    --height: 69;
    left: -310px;
    z-index: 0;
    letter-spacing: 0;
    line-height: 69.0px;
    position: absolute;
    bottom: 368px;
    transform: rotate(90.00deg);
    white-space: nowrap;
}
@media (max-width: 1199px) {
    .section_problem .decoration-english {
        left: -150px;
        z-index: -1
    }
}
@media (max-width: 720px) {
.section_problem .image-container {
    margin: 2rem auto -6px;
    text-align: center;
}
}

.section_problem .ul-problem_list {
    align-items: flex-end;
    background-color: #383c40;
    border-radius: 8px;
    padding: 2rem;
    max-width: 665px;
    width: 100%;
    margin: 0 auto 3rem;
}
.section_problem .ul-problem_list li {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 30px;
    border-bottom: 1px dotted #8c8c8c;
    width: 100%;
    padding: 1rem 0 1.5rem;
}
.section_problem .ul-problem_list li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}
.section_problem .ul-problem_list .flex-row {
    align-items: center;
    display: flex;
    justify-content: space-between;
    width: 100%;
}
.section_problem .ul-problem_list .txt {
    width: 100%;
    margin-left: 2rem;
    line-height: 1.6rem;
}
.problem_man_img {
    --right: 100;
    position: absolute;
    bottom: -46px;
    --width: 160;
    min-width: 100px;
}
.problem_woman_img {
    position: absolute;
    bottom: -46px;
    --width: 162;
    --left: 100;
    z-index: 1;
    min-width: 100px;
}
.section_problem .hl_txt {
    color: transparent;
    font-size: clamp(1.875rem, 1.748rem + 0.63vw, 2.5rem);
    font-weight: 700;
    left: 308px;
    letter-spacing: 0;
    text-align: center;
    margin: 2rem;
}
.section_problem .span1-2 {
    color: #fe7b22;
}
.section_problem .balloon {
    align-items: center;
    justify-content: center;
    background-image: url(../img/problem_balloon.svg);
    background-size: 100% 100%;
    display: flex;
    height: 90px;
}
@media (max-width: 420px) {
    .section_problem .balloon {
        height: 70px;
    }
    .section_problem .ul-problem_list li {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 30px;
    border-bottom: 1px dotted #8c8c8c;
    width: 100%;
    padding: 0.5rem 0 0.5rem;
}
    .section_problem .ul-problem_list {
    margin: 0 auto 2rem;
    padding: 1.5rem 1rem;
}
   .section_problem  .vector {
       max-width:20px;
   }
    .section_problem .ul-problem_list .txt {
    width: 100%;
    margin-left: 1rem;
    line-height: 1.6rem;
}
}
/*　=====================================================================

「IT道場」が全力でバックアップします！
section_backup

=====================================================================   */
.section_backup {
    align-items: center;
    background-image: url(../img/backup-bg.svg);
    background-size: contain;
    display: flex;
    flex-direction: column;
    gap: 36px;
    justify-content: center;
    padding: 3rem 0;
}
.section_backup .section_backup_hl {
    align-items: center;
    align-self: center;
    background-color: var(--white);
    display: flex;
    height: 98px;
    justify-content: center;
    max-width: 1004px;
    padding: 0 101.2px;
    margin-bottom: 2rem;
}
@media (max-width: 767px) {
    .section_backup .section_backup_hl {
        padding: 0 2rem;
    }
}
.section_backup .hl_txt-1 {
    color: transparent;
    font-size: clamp(1.875rem, 1.748rem + 0.63vw, 2.85rem);
    font-weight: 700;
    height: 66px;
    letter-spacing: 0.97px;
    width: 800px;
    text-align: center;
}
.section_backup .inner_flex {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 48px;
}
.section_backup .txt_wrap {
    max-width: 580px;
    flex: 0 1 auto;
}
.section_backup .img_wrap {
    flex: 0 1 auto;
}
.section_backup .img_wrap img {
    width: calc(100% + 40%);
    margin-left: -30%;
}
.section_backup .span1-7 {
    color: var(--burnt-sienna);
    letter-spacing: 0.39px;
}
.section_backup .main_txt-5 {
    color: var(--eerie-black);
    font-size: clamp(1.25rem, 1.123rem + 0.63vw, 1.875rem);
    font-weight: 700;
    letter-spacing: 0.80px;
    line-height: 54px;
    margin-bottom: 2rem;
}
.section_backup .sub_txt {
    letter-spacing: 1.92px;
    line-height: 26px;
    font-size: 16px;
}
@media (max-width: 850px) {
    .section_backup .img_wrap img {
        width: 100%;
        margin-left: 0;
    }
    .section_backup .sp_block {
        display: block;
    }
}
@media (max-width: 767px) {
    .section_backup .inner_flex {
        flex-direction: column;
    }
    .section_backup .inter-bold-eerie-black-40px.span-3 {
        font-size: 1.4rem
    }
    .section_backup .section_backup_hl {
        padding: 0 0.8rem;
        line-height: 2rem;
    }
}

@media (max-width: 540px) {
    .section_backup .hl_txt-1 {
    color: transparent;
    font-size: clamp(0.875rem, 1.748rem + 0.63vw, 1.5rem);
    font-weight: 700;
    height: 66px;
    letter-spacing: 0.97px;
    width: 800px;
    text-align: center;
}
.section_backup .main_txt-5 {
    color: var(--eerie-black);
    font-size: clamp(1.133rem, 1.123rem + 0.63vw, 1em);
    font-weight: 700;
    letter-spacing: 2;
    line-height: 1.75rem;
    margin-bottom: 1rem;
}
    .section_backup .hl_txt-1 {
    color: transparent;
    font-size: clamp(0.875rem, 1.748rem + 0.63vw, 1.5rem);
    font-weight: 700;
    height: 0;
    letter-spacing: 0.97px;
    width: 800px;
    text-align: center;
}
    .section_backup .inner_flex {
    gap: 24px;
}
}
/*　=====================================================================

IT道場が選ばれる理由
section_reason

=====================================================================   */
.section_reason {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 24px;
    background: #f8eb00;
}
.section_reason .hl {
    margin: auto;
    background: #fff;
    width: 100%;
    text-align: center;
    position: relative;
}
.section_reason .hl img {
    max-width: 500px;
    width: 100%;
}
.section_reason .reason_wrap {
    max-width: 1440px;
    height: 100%;
    width: 100%;
    margin: 0 auto;
    align-items: center;
}
.section_reason .inner_flex {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 4rem;
}
.reason_jump_link {
    align-items: center;
    display: flex;
    gap: 49px;
}
.section_reason .item-link {
    align-items: center;
    background-color: var(--white);
    border-radius: 20px;
    box-shadow: 0px 6px 0px #aaaaaa;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    padding: 2rem;
    position: relative;
    width: 30%;
    text-align: center;
}
.section_reason .item-link .arrow {
    background-image: url(../img/arrow_black.svg);
    background-size: 100% 100%;
    border-radius: 10px;
    height: 20px;
    margin-right: 0.01px;
    margin-top: 12px;
    width: 20px;
}
.section_reason .item-link:hover {
    top: 10px;
    transition: 0.3s;
    box-shadow: none;
}
.section_reason .paragraph-background {
    align-items: flex-end;
    background-color: var(--turbo);
    border-radius: 32.5px;
    display: flex;
    flex-direction: column;
    gap: 3px;
    margin-right: 0.01px;
    min-height: 65px;
    padding: 7.4px 21.6px;
    width: 65px;
    margin-bottom: 1rem;
    align-items: center;
}
.section_reason .inter-bold-eerie-black-20px {
    line-height: 1.85rem;
}
.section_reason .border {
    border-color: var(--white);
    left: 0;
    right: 0;
    margin: auto;
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 120px solid transparent;
    border-left: 120px solid transparent;
    border-top: 60px solid #ffffff;
    border-bottom: 0;
}
.reason_number {
    align-self: center;
    letter-spacing: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    white-space: nowrap;
    height: 110px;
    width: 110px;
    background: #f8eb00;
    font-size: clamp(0.85rem, 0.819rem + 0.15vw, 1rem);
    gap: 1rem;
    border-radius: 50%;
}
.reason_hl_txt {
    left: 0;
    letter-spacing: 3.52px;
    line-height: 66px;
    text-align: center;
    top: 0;
}
.reason-box {
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 6.4rem;
    max-width: 1440px;
    width: 100%;
}
.reason-box .heading {
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4rem;
    padding: 4rem 2rem 1rem;
    position: relative;
}
.reason-box .heading .inter-bold-eerie-black-44px {
    margin-top: 1rem;
    line-height: 3.6rem;
}
.reason_contents {
    align-items: center;
    background-color: var(--white);
    display: flex;
    justify-content: center;
    margin-top: 0;
    padding: 3rem 0;
}
.reason_contents:nth-child(2n) {
    background: #FDFFD6;
}
.reason_contents:nth-child(2n) .inner_flex {
    flex-direction: row-reverse;
}
.reason_contents .txt_wrap {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 50%;
}
.reason_contents .txt_wrap img {
    margin: auto;
}
.reason_contents .main_txt {
    align-self: stretch;
    letter-spacing: 1.50px;
    line-height: 50px;
    position: relative;
    margin-bottom: 1rem;
}
.reason_contents .sub_redtxt {
    align-self: stretch;
    letter-spacing: 1.50px;
    line-height: 32px;
    position: relative;
    margin-bottom: 2rem;
}
.section_reason .link_wrap {
    align-items: stretch;
    justify-content: center;
    display: flex;
    gap: 50px;
    padding: 6rem 0 2rem;
    max-width: 1200px;
    margin: auto;
    margin-bottom: 4rem;
}
.reason_contents .txt-12 {
    align-self: stretch;
    letter-spacing: 1.50px;
    line-height: 32px;
}
.reason_contents .annotation {
    align-self: stretch;
    color: var(--mine-shaft);
    font-size: clamp(0.625rem, 0.587rem + 0.19vw, 0.813rem);
    font-weight: 400;
    letter-spacing: 0;
    line-height: 32px;
    position: relative;
}
@media (max-width: 860px) {
    .reason-box .heading {
        text-align: center;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 4rem;
        padding: 2rem;
        position: relative;
    }
}
@media (max-width: 1440px) {
    .section_reason .reason-box {
        margin: 3.2rem;
        width: calc(100% - 6.4rem)
    }
    .section_reason .link_wrap {
        padding: 4rem 2rem 0rem;
    }
}
@media (max-width: 980px) {
    .section_reason .heading {
        flex-direction: column;
        gap: 1rem;
        padding: 2rem;
    }
    .bg_green_toptxt {
        width: 80%
    }
    .section_reason .link_wrap {
        gap: 25px;
    }
    .section_reason .item-link {
        padding: 0.8rem
    }
}

@media (max-width: 540px) {
    .section_reason .sp_block {
        display: block;
    }
}

/*　=====================================================================

受講生・卒業生の声
section_voice

=====================================================================   */

.section_voice {
    align-items: center;
    background-color: #fdffd6;
    border-radius: 10px;
    padding-bottom: 5rem;
}
@media (max-width: 500px) {
    .section_voice h5 div {
        line-height: 1.3;
    }
    .section_voice .sp_block {
        display: block;
    }
}
.pickup_voice {
    align-items: center;
    background-color: var(--white);
    border-radius: 10px;
    box-shadow: 0px 4px 11px #00000040;
    display: flex;
    margin: auto;
    justify-content: center;
    width: 100%;
    height: 100%;
}
.pickup_voice .inner_txt_box {
    align-items: center;
    background-color: var(--white);
    border: 1px solid;
    border-color: var(--burnt-sienna);
    border-radius: 15px;
    display: flex;
    flex-direction: column;
    gap: 32px;
    margin: 2rem;
    padding: 3rem;
}
.pickup_voice .inner_flex {
    align-items: center;
    align-self: center;
    justify-content: space-between;
    display: flex;
    gap: 60px;
}
.face_image {
    max-height: 175px;
}
.pickup_voice h4 {
    color: var(--mine-shaft);
    font-size: clamp(1rem, 0.9rem + 0.75vw, 2rem);
    font-weight: 700;
    letter-spacing: 1.44px;
    margin-bottom: 13.52px;
    line-height: 3rem;
}
.pickup_voice .txt {
    letter-spacing: 2.16px;
    line-height: 32px;
}
.ys-1 {
    letter-spacing: 0;
    line-height: 60px;
    text-align: center;
}
.recommend_voice {
    align-items: center;
    justify-content: center;
    display: flex;
    flex-direction: column;
    max-width: 1200px;
    gap: 5rem;
    width: 100%;
    margin: 5rem auto 0;
}
.recommend_voice_wrap {
    align-items: center;
    display: flex;
    justify-content: center;
    gap: 55px;
    margin: auto;
}
.recommend_voice_txt {
    align-items: center;
    align-self: center;
    background-color: var(--white);
    border: 3px solid;
    border-color: #cccccc;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    padding: 2rem;
    color: var(--black);
    font-size: clamp(0.813rem, 0.723rem + 0.44vw, 1.25rem);
    font-weight: 400;
    letter-spacing: 0;
    line-height: 43.1px;
}
.recommend_voice_wrap .photo {
    flex: 1 1 auto;
    max-width: 500px;
    width: 49%;
}
.section_compare {
    align-items: center;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.decoration_english {
    height: 128px;
    left: 0;
    letter-spacing: 0;
    line-height: 69.0px;
    position: absolute;
    top: 0;
    width: 933px;
}
@media (max-width: 1200px) {
    .recommend_voice {
        padding: 0 2rem;
        gap: 2rem;
    }
}
@media (max-width: 768px) {
    .recommend_voice_wrap {
        display: flex;
        flex-direction: column;
        gap: 1rem
    }
    .recommend_voice_wrap .photo {
        width: 100%;
    }
    .recommend_voice_txt {
        padding: 1.5rem
    }
    .pickup_voice .inner_txt_box {
        margin: 1rem;
        padding: 1rem;
        gap: 1rem;
        padding-bottom: 2rem;
    }
    .pickup_voice .inner_flex {
        flex-direction: column;
        gap: 24px;
    }
}
.section_course {
    align-items: center;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.compare_h2 {
    height: 30px;
    letter-spacing: 3.00px;
    line-height: 29.2px;
    margin-left: 1.0px;
    margin-top: 52px;
    min-width: 1201px;
    white-space: nowrap;
}
.course_balloon {
    position: relative;
    display: inline-block;
    margin: 1.5rem;
    padding: 2rem 4rem;
    min-width: 120px;
    max-width: 100%;
    color: #333;
    letter-spacing: 1.20px;
    line-height: 55px;
    font-size: 16px;
    text-align: center;
    background: #fcfbab;
}
.course_balloon :before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #fcfbab;
    ;
}
@media (max-width: 1200px) {
    .course_balloon {
        padding: 2rem;
        line-height: 32px;
    }
}
.course_balloon_wrap {
    width: 100%;
    max-width: 1100px;
    text-align: center;
    position: relative;
}
.course_img01 {
    --left: 0;
    position: absolute;
    bottom: 0;
    --width: 150;
    min-width: 80px;
}
.course_h2 {
    margin-bottom: 5rem;
}
.course_img02 {
    --right: 0;
    position: absolute;
    bottom: 0;
    --width: 176;
    min-width: 80px;
}
.overlap-group23 {
    align-items: flex-start;
    background-color: var(--turbo);
    border-radius: 8px;
    display: flex;
    min-width: 1920px;
}
.linkbnr_wrap_bg_yellow {
    align-items: center;
    justify-content: center;
    display: flex;
    gap: 64px;
    width: 100%;
    background: #f8eb00;
}
.link01-1 {
    align-items: flex-start;
    border-radius: 10px;
    box-shadow: 0px 4.76px 4.76px #00000040;
    display: flex;
    height: 200px;
    margin-top: 0;
    min-width: 570px;
}
.section_faq {
    align-items: center;
    justify-content: center;
    display: flex;
    flex-direction: column;
}
.faq_h2 {
    letter-spacing: 3.00px;
    white-space: nowrap;
}
.faq {
    align-items: flex-start;
    align-self: flex-start;
    display: flex;
    flex-direction: column;
    margin-top: 120px;
    min-height: 2605px;
    width: 1114px;
}
.qa {
    align-items: flex-start;
    display: inline-flex;
    flex-direction: column;
    gap: 27.56px;
    height: 215px;
    margin-left: 0.08px;
    position: relative;
}
.line-3 {
    height: 1.15px;
    margin-top: -1.15px;
    position: relative;
    width: 1113.7px;
}
.faq_content {
    height: 160.74px;
    position: relative;
    width: 1113.92px;
}
.flex-row-2 {
    align-items: flex-start;
    display: flex;
    height: 162px;
    min-width: 1114px;
    position: relative;
    top: -1px;
}
.overlap-group-container-1 {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 13px;
    min-height: 162px;
    width: 69px;
}
.overlap-group-5 {
    height: 76px;
    position: relative;
    width: 69px;
}
.ellipse {
    background-color: var(--mariner);
    border-radius: 34.44px;
    height: 69px;
    left: 0;
    position: absolute;
    top: 7px;
    width: 69px;
}
.ellipse-1 {
    border: 2.3px solid;
    border-color: var(--mariner);
    border-radius: 34.44px;
    height: 69px;
    left: 0;
    position: absolute;
    top: 5px;
    width: 69px;
}
.a {
    left: 22px;
    letter-spacing: 0;
    line-height: 70.3px;
    position: absolute;
    top: 0;
    white-space: nowrap;
}
.q_txt {
    letter-spacing: 0;
    line-height: 31.2px;
    white-space: nowrap;
}
.a_txt {
    height: 62px;
    letter-spacing: 0;
    line-height: 31.2px;
}
.text_label-container {
    align-items: flex-start;
    align-self: flex-end;
    display: flex;
    flex-direction: column;
    gap: 22px;
    margin-left: 34px;
    min-height: 146px;
    width: 918px;
}

.decoration_english02 {
    letter-spacing: 0;
    line-height: 125px;
    text-align: center;
    margin-top: 6px;
}
.splide__container {
    box-sizing: border-box;
    position: relative;
}
.splide__list {
    backface-visibility: hidden;
    display: flex;
    height: 100%;
    margin: 0 !important;
    padding: 0 !important;
}
.splide.is-initialized:not(.is-active) .splide__list {
    display: block;
}
.splide__pagination {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0;
    pointer-events: none;
}
.splide__pagination li {
    display: inline-block;
    line-height: 1;
    list-style-type: none;
    margin: 0;
    pointer-events: auto;
}
.splide:not(.is-overflow) .splide__pagination {
    display: none;
}
.splide__progress__bar {
    width: 0;
}
.splide {
    position: relative;
    visibility: hidden;
}
.splide.is-initialized, .splide.is-rendered {
    visibility: visible;
}
.splide__slide {
    backface-visibility: hidden;
    box-sizing: border-box;
    flex-shrink: 0;
    list-style-type: none !important;
    margin: 0;
    position: relative;
}
.splide__slide img {
    vertical-align: bottom;
}
.splide__spinner {
    animation: splide-loading 1s linear infinite;
    border: 2px solid #999;
    border-left-color: transparent;
    border-radius: 50%;
    bottom: 0;
    contain: strict;
    display: inline-block;
    height: 20px;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0;
    width: 20px;
}
.splide__sr {
    clip: rect(0 0 0 0);
    border: 0;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}
.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
    display: none;
}
.splide__toggle.is-active .splide__toggle__pause {
    display: inline;
}
.splide__track {
    overflow: hidden;
    position: relative;
    z-index: 0;
}
@keyframes splide-loading {
    0% {
        transform: rotate(0);
    }
    to {
        transform: rotate(1turn);
    }
}
.splide__track--draggable {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
}
.splide__track--fade>.splide__list>.splide__slide {
    margin: 0 !important;
    opacity: 0;
    z-index: 0;
}
.splide__track--fade>.splide__list>.splide__slide.is-active {
    opacity: 1;
    z-index: 1;
}
.splide--rtl {
    direction: rtl;
}
.splide__track--ttb>.splide__list {
    display: block;
}
.splide__arrow {
    align-items: center;
    background: #ccc;
    border: 0;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    height: 2em;
    justify-content: center;
    opacity: 0.7;
    padding: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 2em;
    z-index: 1;
}
.splide__arrow svg {
    fill: #000;
    height: 1.2em;
    width: 1.2em;
}
.splide__arrow:hover:not(:disabled) {
    opacity: 0.9;
}
.splide__arrow:disabled {
    opacity: 0.3;
}
.splide__arrow:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: 3px;
}
.splide__arrow--prev {
    left: 1em;
}
.splide__arrow--prev svg {
    transform: scaleX(-1);
}
.splide__arrow--next {
    right: 1em;
}
.splide.is-focus-in .splide__arrow:focus {
    outline: 3px solid #0bf;
    outline-offset: 3px;
}
.splide__pagination {
    bottom: 0.5em;
    left: 0;
    padding: 0 1em;
    position: absolute;
    right: 0;
    z-index: 1;
}
.splide__pagination__page {
    background: #ccc;
    border: 0;
    border-radius: 50%;
    display: inline-block;
    height: 8px;
    margin: 3px;
    opacity: 0.7;
    padding: 0;
    position: relative;
    transition: transform 0.2s linear;
    width: 8px;
}
.splide__pagination__page.is-active {
    background: #fff;
    transform: scale(1.4);
    z-index: 1;
}
.splide__pagination__page:hover {
    cursor: pointer;
    opacity: 0.9;
}
.splide__pagination__page:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: 3px;
}
.splide.is-focus-in .splide__pagination__page:focus {
    outline: 3px solid #0bf;
    outline-offset: 3px;
}
.splide__progress__bar {
    background: #ccc;
    height: 3px;
}
.splide__slide {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.splide__slide:focus {
    outline: 0;
}
.splide-wrapper {
    width: 100%;
    overflow: hidden;
}
.splide-wrapper .splide__track {
    overflow: visible;
}
@supports (outline-offset: -3px) {
    .splide__slide:focus-visible {
        outline: 3px solid #0bf;
        outline-offset: -3px;
    }
}
@media screen and (-ms-high-contrast: none) {
    .splide__slide:focus-visible {
        border: 3px solid #0bf;
    }
}
@supports (outline-offset: -3px) {
    .splide.is-focus-in .splide__slide:focus {
        outline: 3px solid #0bf;
        outline-offset: -3px;
    }
}
@media screen and (-ms-high-contrast: none) {
    .splide.is-focus-in .splide__slide:focus {
        border: 3px solid #0bf;
    }
    .splide.is-focus-in .splide__track>.splide__list>.splide__slide:focus {
        border-color: #0bf;
    }
}
.splide__toggle {
    cursor: pointer;
}
.splide__toggle:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: 3px;
}
.splide.is-focus-in .splide__toggle:focus {
    outline: 3px solid #0bf;
    outline-offset: 3px;
}
.splide__track--nav>.splide__list>.splide__slide {
    border: 3px solid transparent;
    cursor: pointer;
}
.splide__track--nav>.splide__list>.splide__slide.is-active {
    border: 3px solid #000;
}
.splide__arrows--rtl .splide__arrow--prev {
    left: auto;
    right: 1em;
}
.splide__arrows--rtl .splide__arrow--prev svg {
    transform: scaleX(1);
}
.splide__arrows--rtl .splide__arrow--next {
    left: 1em;
    right: auto;
}
.splide__arrows--rtl .splide__arrow--next svg {
    transform: scaleX(-1);
}
.splide__arrows--ttb .splide__arrow {
    left: 50%;
    transform: translate(-50%);
}
.splide__arrows--ttb .splide__arrow--prev {
    top: 1em;
}
.splide__arrows--ttb .splide__arrow--prev svg {
    transform: rotate(-90deg);
}
.splide__arrows--ttb .splide__arrow--next {
    bottom: 1em;
    top: auto;
}
.splide__arrows--ttb .splide__arrow--next svg {
    transform: rotate(90deg);
}
.splide__pagination--ttb {
    bottom: 0;
    display: flex;
    flex-direction: column;
    left: auto;
    padding: 1em 0;
    right: 0.5em;
    top: 0;
}
.splide__slide:not(.is-visible) .slide {
    pointer-events: none;
    opacity: 0.3;
}
.linkbnr_wrap {
    align-items: center;
    align-self: center;
    display: flex;
    gap: 64px;
    padding: 2rem;
    justify-content: center;
}
@media (max-width: 767px) {
    .linkbnr_wrap {
        gap: 18px;
        flex-direction: column;
        padding: 1rem;
    }
}
.linkbnr_wrap .link img {
    width: 100%;
    max-width: 500px;
    position: relative;
}
.linkbnr_wrap .link img:hover {
    top: 10px;
    transition: 0.3s;
}
.reason-box .img_wrap {
    display: flex;
    flex-direction: column;
    width: 49%;
    padding: 2rem 0;
}
.reason-box .reason_img04_wrap {
    padding: 1rem 0;
}
.reason-box img {
  max-width:100%;
}
.table-container {
    max-width: 1440px;
    width: 100%;
    padding: 0 1rem;
}
.reason_link_btn{
    max-width:75%;
    margin: 0px auto 2rem;
    position: relative;
}

.reason_link_btn:hover{
    top: 10px;
    transition: 0.3s;
}

@media (max-width: 960px) {
    .table-container {
        overflow-x: scroll;
    }
}
.course-table {
    border-collapse: collapse;
    width: 100%;
    min-width: 1200px;
    margin: auto;
}
.course-table th, .course-table td {
    padding: 0.8rem;
    border: 1px solid;
    border-color: var(--nobel);
    line-height: 1.6rem;
    font-size: clamp(0.813rem, 0.785rem + 0.14vw, 0.95rem);
}
.course-table th {
    font-weight: bold;
    font-size: var(--font-size-m);
    color: #fff;
    background: #717171;
    border: none;
}
.course-table .h-assist {
    padding: 4rem 0;
}
.course-table .align-center {
    text-align: center;
    vertical-align: middle;
}
.course-table .bg_orange {
    background: #e6ae5a
}
.course-table .bg_blue {
    background: #1a69c5;
}
.course-table .bg_gray {
    background: #f7f7f7;
    font-weight: bold;
}
.course-table .bg_yellow {
    background: #fffdeb
}
.course-table .bg_lightblue {
    background: #d6e9ff
}

.compare-table td:not(.bg_pink){
    max-width:180px
}


.section_compare .hl {
    align-items: center;
    background-color: var(--turbo);
    display: flex;
    height: 72px;
    text-align: center;
    justify-content: center;
    color: var(--mine-shaft);
    font-size: clamp(1rem, 1rem + 0.88vw, 2.875rem);
    font-weight: 700;
    --height: 30;
    letter-spacing: 3px;
    line-height: 29.2px;
    white-space: nowrap;
    position: relative;
    z-index: 1;
    margin-top: -2rem;
    margin: -2rem auto 1.2rem;
    max-width: 640px;
}
@media (max-width: 767px) {
    .section-compare .hl {
        margin: 0 2rem;
    }
}
.section_compare .inner_wrap {
    padding: 0;
    padding-bottom: 4.8rem;
}
.section_compare .bg_green_toptxt {
    width: 80%;
    margin: 2rem auto 5rem;
}
.compare_hl_txt {
    letter-spacing: 3px;
    line-height: 64px;
    margin-top: 24px;
    width: 100%;
    text-align: center;
}
.section_compare .table-container {
    max-width: 1440px;
    padding: 0;
    padding-top: 35px;
}
.compare-table {
    border-collapse: collapse;
    width: 100%;
    min-width: 850px;
    margin: auto;
}
.compare-table .rectangle {
    position: absolute;
    background-color: var(--burnt-sienna);
    border-radius: 10px 10px 0px 0px;
    height: 35px;
    top: -25px;
    width: 100%;
    left: 0;
}
.compare-table .hidden {
    background: #fff;
}
.compare-table th, .compare-table td {
    padding: 1.5rem 0.5rem;
    border: 1px solid;
    border-color: var(--nobel);
    line-height: 1.6rem;
    font-size: clamp(0.813rem, 0.785rem + 0.14vw, 0.95rem);
    text-align: center;
    vertical-align: middle;
}
.compare-table th {
    font-weight: bold;
    font-size: var(--font-size-m);
    color: #fff;
    background: #717171;
    border: none;
}
.compare-table th.it {
    background: var(--burnt-sienna);
    position: relative;
}
.compare-table .h-assist {
    padding: 4rem 0;
}
.compare-table .align-center {
    text-align: center;
    vertical-align: middle;
}
.compare-table tr:last-child .bg_pink {
    border-bottom: 5px solid #e86a57;
}
.compare-table .bg_pink {
    background: var(--quarter-pearl-lusta);
    border: 5px solid #e86a57;
    box-sizing: border-box;
    border-bottom: none;
    border-top: 1px solid #ccc;
}
.compare-table .bg_gray {
    background: #f7f7f7;
    font-weight: bold;
}
.compare-table .txt {
    line-height: 1.85rem;
}
.compare-table .square {
    color: var(--burnt-sienna);
    font-size: clamp(2.375rem, 2.197rem + 0.88vw, 3.25rem);
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1;
    text-align: center;
}
.compare-table .price {
    color: var(--burnt-sienna);
    font-size: clamp(1.125rem, 1.049rem + 0.38vw, 1.5rem);
    font-weight: 900;
    margin: 1rem 0;
    display: inline-block;
}
.section_compare .annotation {
    letter-spacing: 1.60px;
    line-height: 28.8px;
    text-align: right;
}
@media (max-width: 1440px) {
    .section_compare .inner_wrap {
        padding: 0 2rem;
        padding-bottom: 4.8rem;
    }
}
@media (max-width: 930px) {
    .section_compare .table-container {
        overflow-x: scroll;
        padding-top: 30px
    }
}
@media (max-width: 768px) {
    .section_compare .bg_green_toptxt {
        width: 100%;
        margin-bottom: 0.8rem;
        margin-top: 0.5rem;
        padding: 1.25rem;
    }
    .compare-table th, .compare-table td {
      padding: 0.5rem;
      line-height: 1.25rem;
    }
    .compare-table th .inter-bold-white-24px {
    color: var(--white);
    font-size: 18px!important;
    font-style: normal;
    font-weight: 700;
}
}
@media (max-width: 500px) {
    .course_balloon {
        padding: 1rem 2.5rem;
        line-height: 24px;
    }
    .compare_hl_txt {
    letter-spacing: 3px;
    line-height: 48px;
}
    .recommend_voice_txt {
    line-height: 36.1px;
}
    .course-table th, .course-table td {
    padding: 0.5rem;
    border: 1px solid;
    border-color: var(--nobel);
    line-height: 1.25rem;
    font-size: 12px;
}
    .course-table .h-assist {
    padding: 0.5rem 0;
}
    .compare-table .price {
    color: var(--burnt-sienna);
    font-size: 14px;
    font-weight: 900;
    margin: 0.25rem 0;
    display: inline-block;
}
        .compare-table th, .compare-table td {
      padding: 0.5rem;
      line-height: 1.25rem;
    }
.compare-table .rectangle {
    position: absolute;
    background-color: var(--burnt-sienna);
    border-radius: 10px 10px 0px 0px;
    height: 15px;
    top: -10px;
}
.compare-table .txt {
    line-height: 1.25rem;
}
.inter-normal-white-20px {
    font-size: 13px!important;
    font-style: normal;
    font-weight: 400;
}

    
}

.frame {
    align-items: center;
    background-color: var(--turbo-2);
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    max-height: 600px;
    padding: 1.25rem;
    max-width: 400px;
    align-items: center;
}
.frame-1 {
    align-items: flex-end;
    display: flex;
    height: 225px;
    overflow: hidden;
    width: 225px;
}
.recommend-avatar01-1 {
    height: 211px;
    margin-left: -20px;
    -o-object-fit: cover;
    object-fit: cover;
    width: 245px;
}

.text-1-2 {
    letter-spacing: 0;
    line-height: 1;
    text-align: center;
    width: 100%;
    font-size: 12px;
}
.splide-wrapper .zenkakugothicnew-normal-black-24px {
    font-size: clamp(0.875rem, 0.824rem + 0.25vw, 1.125rem)
}
.text-1-3 {
    align-self: center;
    letter-spacing: 0;
    line-height: 45px;
    margin-top: 3px;
    text-align: center;
}
.text-1-5 {
    align-self: center;
    letter-spacing: 0;
    line-height: 32px;
    margin-top: 20px;
    width: 100%;
}
.frame-9 {
    align-items: center;
    justify-content: center;
    display: flex;
    height: 100px;
    width: 100px;
    text-align: center;
}
.frame-9 img {
    width: 85px;
    height: 85px;
}
.recommend-avatar02-1 {
    height: 120px;
    margin-left: 1px;
    -o-object-fit: cover;
    object-fit: cover;
    width: 120px;
}
.frame-10 {
    align-items: center;
    display: flex;
    gap: 5px;
    justify-content: center;
}
@media (max-width: 767px) {
    .pickup_voice {
        margin: 0 auto;
        margin-top: -7rem;
    }
    .frame-10 {
        align-items: center;
    }
}
.section_voice .hl {
    background-color: var(--turbo);
    max-width: 800px;
    position: relative;
    padding: 1rem 4rem;
    margin: 2rem auto 0;
    text-align: center;
}
.section_voice .flex-box {
    display: flex;
    gap: 28px;
    align-items: center;
}
@media (max-width: 767px) {
    .section_voice .flex-box {
        flex-direction: column;
    }
    .section_voice .hl {
        padding: 0.5rem;
        margin-bottom: 2rem;
    }
}
.section_voice .flex-box+.flex-box {
    margin-top: 5rem;
}
.section_voice .voice-baloon1 {
    right: 0;
    letter-spacing: 0;
    line-height: 34.5px;
    text-align: center;
    position: relative;
    display: inline-block;
    margin: 10rem 0 -2rem;
    padding: 3rem;
    min-width: 300px;
    max-width: 100%;
    color: #555;
    font-size: clamp(0.813rem, 0.774rem + 0.19vw, 1rem);
    background: var(--aqua-spring);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
}
.section_voice .voice-baloon1:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid var(--aqua-spring);
}
.section_voice .inner_wrap {
    padding: 5rem 0;
}
.section_voice .hl_decoration {
    height: 101px;
    left: 0;
    margin: auto;
    right: 0;
    position: absolute;
    top: -113px;
    width: 128px;
}
.section_voice h5 {
    position: relative;
    margin: 5rem auto;
    height: 45px;
    max-width: 1000px;
    color: var(--mine-shaft);
    font-size: clamp(1.25rem, 1.05rem + 1vw, 2.25rem);
    font-weight: 700;
    letter-spacing: 0;
    line-height: 66px;
    text-align: center;
}
.section_voice h5 .vertical-divider {
    background-color: var(--mine-shaft);
    height: 35px;
    left: 9px;
    position: absolute;
    top: 24px;
    transform: rotate(-30deg);
    width: 2px;
}
.section_voice h5 .vertical-divider-1 {
    background-color: var(--mine-shaft);
    height: 35px;
    right: 11px;
    position: absolute;
    top: 24px;
    transform: rotate(30deg);
    width: 2px;
}
.recommend_voice h6 {
    color: var(--mine-shaft);
    font-size: clamp(1.75rem, 1.521rem + 1.13vw, 2.875rem);
    font-weight: 700;
    letter-spacing: 3.00px;
    line-height: 29.2px;
    padding: 1rem;
    white-space: nowrap;
    background: var(--turbo);
    width: 100%;
    text-align: center;
    max-width: 640px;
}
@media (max-width: 1200px) {
    .section_voice .inner_wrap {
        padding: 5rem 2rem;
    }
    .section_voice h5 {
        margin: 0 2rem 4rem;
    }
}

@media (max-width: 500px) {
.section_voice .voice-baloon1 {
    right: 0;
    letter-spacing: 0;
    line-height: 24.5px;
    text-align: center;
    position: relative;
    display: inline-block;
    margin: 5rem 0 3rem;
    padding: 1.5rem;
    min-width: 300px;
    max-width: 100%;
    color: #555;
    font-size: clamp(0.813rem, 0.774rem + 0.19vw, 1rem);
    background: var(--aqua-spring);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
}
}

/*　=====================================================================

よくある質問
section_faq

=====================================================================   */

.section_faq {
    overflow: hidden;
}
.faq_wrap {
    margin-top: 5rem;
}
.faq_wrap .faq_circle {
    position: relative;
}
.faq_wrap .accordion-title {
    cursor: pointer;
    font-size: clamp(0.875rem, 0.799rem + 0.38vw, 1.25rem);
    font-weight: bold;
    padding: 2rem 5rem 2rem 0;
    justify-content: flex-start;
    display: flex;
    gap: 1rem;
    line-height: 1.8rem;
    flex: 1;
}
.faq_wrap .accordion-content {
    display: none;
    border-bottom: 1px solid #ccc;
    padding: 2rem 0;
    align-items: center;
    gap: 40px;
    font-size: clamp(0.875rem, 0.799rem + 0.38vw, 1.25rem);
}
.faq_wrap .accordion-content p {
    font-size: 13px;
    line-height: 1.5;
}
.faq_wrap .accordion-content .valign-text-middle {
    line-height: 32px;
    font-weight: normal;
    width: -moz-fit-content;
    width: fit-content;
}
.faq_wrap .accordion-item {
    border-top: 1px solid #ccc;
}
.faq_wrap .accordion-title {
    position: relative;
}
.faq_wrap .accordion-title::after {
    border-right: solid 3px var(--mariner);
    border-top: solid 3px var(--mariner);
    content: "";
    display: block;
    height: 12px;
    position: absolute;
    right: 10px;
    top: 38%;
    transform: rotate(135deg);
    transition: transform 0.3s ease-in-out, top 0.3s ease-in-out;
    width: 12px;
}
.faq_wrap .accordion-title.open+.accordion-content .inner_flex {
    display: flex;
    gap: 16px;
}
.faq_wrap .accordion-title.open::after {
    top: 45%;
    transform: rotate(-45deg);
}
.faq_wrap .faq_circle {
    flex: 0 0 55px;
}
.faq_circle .bg {
    background-color: var(--mariner);
    border-radius: 34.44px/34.66px;
    height: 70px;
    left: 0;
    position: absolute;
    top: 8px;
    width: 70px;
}
.faq_circle .bg_answer {
    border: 2.3px solid;
    border-color: var(--mariner);
    border-radius: 34.44px/34.66px;
    height: 69px;
    left: 0;
    position: absolute;
    width: 69px;
}
.faq_circle .q {
    left: 25px;
    letter-spacing: 0;
    font-size: 24px;
    white-space: nowrap;
    color: #fff;
    background-color: var(--mariner);
    border-radius: 34.44px / 34.66px;
    left: 0;
    width: 45px;
    height: 45px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}
.faq_circle .faq_a {
    left: 25px;
    letter-spacing: 0;
    position: absolute;
    white-space: nowrap;
    font-size: 24px;
    color: #1a69c6;
    border: 2.3px solid;
    border-color: var(--mariner);
    border-radius: 34.44px / 34.66px;
    height: 45px;
    left: 0;
    position: absolute;
    width: 45px;
    display: flex;
    justify-content: center;
    align-items: center;
}
@media (max-width: 767px) {
    .reason_wrap {
        padding-bottom: 4rem
    }
    .section_compare .decoration_english02 {
        font-size: 64px;
        line-height: 91px;
    }
    .decoration_english02 {
        line-height: 90px;
        margin-top: 0;
    }
    .reason_contents .inner_flex {
        flex-direction: column;
        gap: 1rem;
    }
    .reason_contents:nth-child(2n) .inner_flex {
        flex-direction: column;
        gap: 2rem;
    }
    .reason_contents .txt_wrap {
        width: 100%;
        justify-content: center;
        align-items: center;
    }
    .reason_contents .img_wrap {
        text-align: center;
        width: 100%;
        padding: 0;
    }
    .reason_contents .img_wrap img {
        max-width: 480px;
        width: 100%;
        margin: auto;
    }
    .section_reason .reason-box {
        margin: 1.6rem;
        width: calc(100% - 3.2rem)
    }
    .reason_contents .main_txt {
        text-align: center;
    }
    .reason_hl_line {
        width: 100%;
    }
    .reason_hl_line img {
        width: 100%;
    }
    .problem_man_img {
        right: 0;
    }
    .problem_woman_img {
        left: 0
    }
    .faq_wrap .faq_circle {
    /* height: 76px; */
    /* position: relative; */
    /* width: 100px; */
    /* flex: 0 0 55px; */
}
.faq_circle .bg {
    background-color: var(--mariner);
    border-radius: 34.44px/34.66px;
    left: 0;
    position: absolute;
    top: 8px;
    width: 45px;
    height: 45px;
}
.faq_circle .bg_answer {
    border: 2.3px solid;
    border-color: var(--mariner);
    border-radius: 34.44px/34.66px;
    height: 69px;
    left: 0;
    position: absolute;
    width: 69px;
}
.faq_circle .q {
    letter-spacing: 0;
    font-size: clamp(1.5rem, 1.357rem + 0.7vw, 2.2rem);
    white-space: nowrap;
    color: #fff;
}
.faq_circle .faq_a {
    letter-spacing: 0;
    white-space: nowrap;
    font-size: clamp(1.5rem, 1.357rem + 0.7vw, 2.2rem);
    color: #1a69c6;
}
}
@media (max-width: 640px) {
    .section_reason .link_wrap {
        flex-direction: column;
        align-items: center;
    }
    .section_reason .item-link {
        width: 100%;
    }
}

@media (max-width: 500px) {
.faq_wrap .accordion-title {
    cursor: pointer;
    font-size: clamp(0.875rem, 0.799rem + 0.38vw, 1.25rem);
    font-weight: bold;
    padding: 2rem 3rem 2rem 0;
    justify-content: flex-start;
    display: flex;
    gap: 1rem;
    line-height: 1.8rem;
    flex: 1;
}
}

@media (max-width: 400px) {
    .section_reason .reason-box {
        margin: 1rem;
        width: calc(100% - 2rem)
    }
    .section_compare .decoration_english02 {
        font-size: 52px;
        line-height: 91px;
    }
    .section_reason .inner_flex {
        gap: 1rem
    }
    .reason_contents .annotation {
        gap: 0rem;
        /* margin-bottom: 2rem; */
        line-height: 1.6em;
    }
    .bg_green_toptxt {
        width: 85%;
        padding: 1rem;
    }
    .section_reason .heading {
        flex-direction: column;
        gap: 1rem;
        padding: 1rem;
    }
    .section_voice .inner_wrap {
        padding: 5rem 1rem;
    }
    .pickup_voice .inner_flex {
        gap: 1rem;
    }
    .pickup_voice h4 {
        margin-bottom: 0;
        line-height: 1.5rem;
    }
    .frame {
        align-items: center;
        background-color: var(--turbo-2);
        border-radius: 20px;
        display: flex;
        flex-direction: column;
        max-height: 640px;
        padding: 1rem;
        max-width: 400px;
    }
    .text-1-5 {
        line-height: 30px
    }
    .section_problem .hl_txt {
        margin: 1rem;
    }
    .problem_woman_img, .problem_man_img {
        display: none;
    }
    .section_problem .problem_top_wish {
        gap: 0.5rem;
    }
    .mainvisual .laurel {
        max-width: 114px;
        width: 100%;
    }
    .face_image {
        max-height: 95px;
    }
    .mainvisual .laurel_group {
        top: 57%;
    }
    .mainvisual {
    }
}
/*フローティングバナー*/
.floating-bnr.bnr01 {
    box-shadow: 0 5px 16px rgba(0, 0, 0, 0.05), 0 8px 14px rgba(0, 0, 0, 0.08);
    display: none;
    position: fixed;
    bottom: 20px;
    right: 10px;
    width: 300px;
    max-width: 90vw;
    height: auto;
    z-index: 5;
}
.floating-bnr a:hover {
    opacity: 0.7;
    transition: 0.2s;
}
.floating-bnr.bnr01 img {
    max-width: 100%;
}
@media (max-width: 640px) {
    .floating-bnr.bnr01 {
        width: 190px;
    }
}
/*閉じるボタン*/
.bnr_close {
    background-color: #f8f8f8;
    border: none;
    border-radius: 50%;
    box-shadow: 0 0 7px rgb(0, 0, 0, 0.4);
    color: #777;
    cursor: pointer;
    font-weight: bold;
    padding: 5px 8px;
    position: absolute;
    width: 30px;
    height: 30px;
    right: -4px;
    top: -5px;
    z-index: 100;
}
.fa-xmark:before {
    content: "×";
    font-style: bold;
}

.footer {
  align-items: center;
  background-color: var(--turbo);
  display: flex;
  flex-direction: row;
  flex-shrink: 1;
  height: 64px;
  justify-content: center;
  text-align: center;
}
.copyright {
  height: 20px;
  letter-spacing: 0;
  line-height: normal;
}

.table_inner_em_block {
    background: #f9ffb1;
    padding: 1rem;
    border-radius:6px;
}
.text-1-1 {
    text-align: center;
    margin-bottom: 1rem;
}


.p-header-attention {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 3.75vw 6.25vw 2.5vw;
    background-color: #ed3e3e;
    font-weight: 700;
    margin-top: 4.25rem;
}

.p-header-attention__body {
    width: 65%
}

.p-header-attention__body>._top {
    color: #FFF;
    border-top: 1px solid #FFF;
    border-bottom: 1px solid #FFF;
    font-size: 3.375vw;
    line-height: 1.5;
    margin-bottom: 0.5rem;
}

.p-header-attention__body>._bottom {
    font-size: 3.9375vw;
    color: #FFF;
    line-height: 1.5
}

.p-header-attention__body>._bottom>._num {
    font-size: 1.1578947368em
}

.p-header-attention__badge {
    width: 30%;
    border-radius: 3.125vw;
    padding: 2.5vw;
    background-color: #fff;
    color: #ed3e3e;
    font-weight: 700;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center
}

.p-header-attention__badge>._vertical {
    position: relative;
    top: -0.0625vw;
    writing-mode: vertical-rl;
    margin-right: 1.25vw
}

.p-header-attention__badge>._main {
    font-size: 3.3125vw;
}

.p-header-attention__badge>._main>._num {
    font-size: 2.0588235294em
}


@media (min-width: 720px) {
    .p-header-attention {
    padding: 0.95vw 12.25vw 0.5vw;
    background-color: #ed3e3e;
    font-weight: 700;
    margin-top: 7rem;
    align-items: center;
    justify-content: center;
    }

.p-header-attention__body {
   display:flex;
   justify-content:center;
   align-items: center;
}
.p-header-attention__body>._top {
    font-size: 1.2vw;
    padding: 0rem 2rem 0 0rem;
    border: none;
    border-right: 1px solid;
    margin-bottom: 0;
    margin-right: 2rem;
}

.p-header-attention__body>._bottom {
    font-size: 1vw;
    color: #FFF;
    line-height: 1;
}

.p-header-attention__body>._bottom>._num {
    font-size: 1.5em;
}

.p-header-attention__badge {
    width: 18%;
    border-radius: 3.125vw;
    padding: 0.2vw 0.5vw;
    background-color: #fff;
    color: #ed3e3e;
    font-weight: 700;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center
}

.p-header-attention__badge>._vertical {
    position: relative;
    top: -0.0625vw;
    writing-mode: vertical-rl;
    margin-right: 1.25vw;
    font-size: 1.2rem;
}

.p-header-attention__badge>._main {
    font-size: 1vw;
}

.p-header-attention__badge>._main>._num {
}

    
}

@media (min-width: 720px) and (max-width: 1100px) {
.p-header-attention {
        padding: 0.95vw 12.25vw 0.5vw;
        background-color: #ed3e3e;
        font-weight: 700;
        margin-top: 4rem;
        align-items: center;
        justify-content: center;
    }   

}



.p-sticky-top {
    z-index: 999;
    position: fixed;
    left: 0;
    bottom: 0
}

@media (max-width: 719px) {
    .p-sticky-top {
        display: none;
    }
}


.p-attention {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    width: 410px;
    padding: 10px 0;
    border-radius: 20px 20px 0 0;
    background-color: #ed3e3e;
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
}

.p-attention__body {
    width: 250px;
    text-align: center
}

.p-attention__body>._top {
    padding: 5px 0;
    color: #FFF;
    border-top: 1px solid #FFF;
    border-bottom: 1px solid #FFF
}

.p-attention__body>._bottom {
    padding-top: 10px;
    font-size: 29px;
    color: #FFF
}

.p-attention__body>._bottom>._num {
    font-size: 1.2em
}

.p-attention__badge {
    width: 92px;
    height: 92px;
    border-radius: 50%;
    font-size: 20px;
    background: #fff;
    color: #ed3e3e;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center
}

.p-attention__badge-main {
    font-size: 29px
}

.p-attention__badge-main>._num {
    font-size: 1.7em
}

.sec_reservation {
    background-image: url(../img/backup-bg.svg);
    margin: auto;
    padding-top: 2rem;
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    padding-bottom: 2rem;
}


.section-about + .sec_reservation {
    padding-top: 6rem;
    margin-top: -2rem;
}

.sec_reservation img{
    max-width: 100%;
}
.sec_reservation .bnr_wrap{
    background:#fff;
    padding:2rem;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap:1rem;
    justify-content: center;
    align-items: center;
}
.sec_reservation .bnr_wrap a:hover{
    opacity: 0.8;
}

.sec_graph{
    background: #E9FCF7;
    padding: 4rem;
}
.sec_graph .img_wrap{
    display: flex;
    justify-content: space-around;
    gap: 6rem;
    flex-wrap: wrap;
}
@media (max-width: 710px) {
    .sec_graph{
    background: #E9FCF7;
    padding: 4rem 1rem;
}
.sec_graph .img_wrap{
    display: flex;
    justify-content: center;
    gap: 2rem;
    flex-wrap: wrap;
}
    .sec_reservation .bnr_wrap{
    background:#fff;
    padding:1.5rem 1rem;
}

.reason_contents .sub_redtxt {
    align-self: stretch;
    letter-spacing: 1.50px;
    line-height: 32px;
    position: relative;
    margin-bottom: 0rem;
}
    .reason_contents .txt-12 {
    line-height: 1.5rem;
}
    .reason_contents {
    padding: 2.5rem 0;
    margin-bottom:0
}

.reason_number {
    height: 75px;
    width: 75px;
    background: #f8eb00;
    font-size: clamp(0.85rem, 0.819rem + 0.15vw, 0.85rem);
    border-radius: 50%;
    gap: 0.3rem;
}

.reason_number  .bizudpgothic-bold-eerie-black-21-6px {
    color: var(--eerie-black);
    font-size: 15px;
    font-style: normal;
    font-weight: 700;
}
.reason-box .heading .inter-bold-eerie-black-44px {
    max-width: 750px;
    margin-top: 0rem;
    line-height: 2.6rem;
    flex: 1;
}
.bg_green_toptxt .inner_toptxt {
    line-height: 24.5px;
    text-align: center;
}
.reason_contents .main_txt {
    align-self: stretch;
    letter-spacing: 1.50px;
    line-height: 25px;
    position: relative;
    margin-bottom: 0rem;
}  
       .bg_green_toptxt {
        width: 90%;
        padding:1rem 2rem;
    }
    
}

.sec_graph img{
    max-width: 35%;
    flex: 0  auto;
}

@media (max-width: 865px) {

    .sec_graph .img_wrap {
    gap: 8rem;
}
.sec_graph img{
    max-width: 80%;
    flex: 0  auto;
}

}


@media (max-width: 640px) {
     .sec_graph .img_wrap {
    gap: 6rem;
}
     .section_reason .sp_none{
     display:none!important;
 }
}
@media (max-width: 500px) {
.table_inner_em_block {
    background: #f9ffb1;
    padding: 0.5rem;
    border-radius:6px;
}
    .course_h2 {
    margin-bottom: 1.5rem;
    font-size: 24px!important;
}
}

@media (max-width: 420px) {
    .section_reason .inner_flex {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 2rem;
    }
    .section-about + .sec_reservation {
    padding-top: 4rem;
    margin-top: -2rem;
}

}



.description_msg_add {
    color: var(--mine-shaft);
    font-size: 45px;
    font-weight: 700;
    line-height: 55px;
    text-align: center;
}

.description_msg_add .kyocho {
    background: #fcff6c;
    padding: 0.5rem 2rem;
    width:auto;
    margin: 1rem;
    display:inline-block;
    font-size: 3.4rem;
    color: #e86a57;
}

.description_msg_add .price {
    color: #e86a57;
}
.price_small {
    font-size: 1.3rem;
}

@media (max-width: 768px) {

.description_msg_add {
    color: var(--mine-shaft);
    font-size: 32px;
    font-weight: 700;
    line-height: 55px;
    text-align: center;
}


}

@media (max-width: 584px) {

.description_msg_add {
    font-size: 24px;
    line-height: 45px;
}
.description_msg_add .kyocho {
    font-size: 3rem;
}
.description_msg_add .price {
    color: #e86a57;
    font-size:1.8rem
}
}

@media (max-width: 420px) {
    .description_msg_add {
    font-size: 20px;
    line-height: 45px;
}
.description_msg_add .kyocho {
    font-size: 2rem;
}

.mainvisual .description01{
    font-size:0.8rem
}
}