@charset "UTF-8";

html {
    font-size: 100%;
    overflow-y: scroll;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
}

html,
body,
body>* {
    font-size: 16px;
    font-family: "Noto Sans JP", sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
    margin: 0px;
}

a:link {
    color: #004cca;
    text-decoration: none;
}

a:visited {
    color: #6219db;
}

a:hover {
    color: #048ade;
    text-decoration: none;
}

a:active {
    color: #048ade;
    text-decoration: none;
}

img {
    max-width: 100%;
    vertical-align: bottom;
    height: auto;
}

ul {
    padding: 0px;
    list-style: none;
    margin: 0;
}

.oh {
    overflow: hidden;
}

.sp {
    display: none;
}

.wrap.sml {
    width: 1000px;
    margin: 0 auto;
}

.flex {
    flex-wrap: wrap;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
}

.flex_sb {
    flex-wrap: wrap;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    justify-content: space-between;
}

.pr {
    position: relative;
}

.pa {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.pr_img {
    overflow: hidden;
    position: relative;
}

img.pa_img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    display: block;
}


.top_mv_sec .cont {
    position: relative;
    margin-bottom: 36px;
}

.top_mv_sec .cont .img {
    width: 420px;
    height: 341px;
    position: absolute;
    left: 0;
    top: -107px;
}

.top_mv_sec .cont .img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.top_mv_sec .cont .img.right {
    left: unset;
    right: 0;
    top: -126px;
}

.top_mv_sec .cont .text_box {
    text-align: center;
    margin-top: 77px;
}

.top_mv_sec .icon {
    margin: 0 auto;
    width: 260px;
}

.top_mv_sec {
    padding-top: 11px;
    position: relative;
    padding-bottom: 40px;
}

.top_mv_sec .icon img {
    width: 100%;
}

.top_mv_sec .cont .text_box .theme {
    font-size: 19px;
    line-height: 1.5;
    letter-spacing: .03em;
    margin-bottom: 2.5em;
    font-weight: 500;
}

.top_mv_sec .cont .text_box .line_box {
    margin-bottom: 22px;
}

.top_mv_sec .cont .text_box .line_box .line_text {
    background-color: #479BCF;
    width: fit-content;
    margin-left: 442px;
    color: #fff;
    font-size: 20px;
    padding: 0.1em 0.8em;
    letter-spacing: 0.2em;
    font-weight: 700;
}

.top_mv_sec .cont .text_box .line_box .line_text:nth-child(2) {
    margin-left: 505px;
}

.top_mv_sec .cont .catch_box .catch {
    font-size: 40px;
    letter-spacing: 0.09em;
    font-weight: 700;
    line-height: 1.4;
    margin-bottom: .1em;
}

.top_mv_sec .cont .catch_box .catch .size {
    font-size: 1.35em;
}

.top_mv_sec .cont .catch_box .en_text {
    font-size: 16.3px;
    color: #4698CA;
}

.top_mv_sec .en_list ul {
    display: flex;
    align-items: center;
    gap: 16px;
    justify-content: center;
}

.top_mv_sec .en_list ul li {
    width: 150px;
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    padding: 6px;
    background: linear-gradient(135deg, #45c6bb, #34ccf2);
    box-sizing: border-box;
    position: relative;
}

.top_mv_sec .en_list ul li::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #fff;
    border-radius: 50%;
    z-index: -1;
}

.top_mv_sec .en_list ul li .text {
    line-height: 1.3;
    font-size: 20px;
    letter-spacing: .03em;
    font-weight: 600;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: #fff;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.top_mv_sec .en_list ul li .text .size {
    font-size: 0.7em;
    font-weight: 700;
    display: block;
}

.common_btn_box {
    padding: 61px 0;
}

.common_btn_box .yer {
    text-align: center;
    font-size: 15px;
    letter-spacing: .02em;
}

.common_btn_box .link_box .link {
    display: flex;
    align-items: center;
    width: fit-content;
    margin: 0 auto 18px;
}

.common_btn_box .link_box .link .catch {
    color: #000;
    width: 100px;
    height: 89px;
    background-color: #00bfc4;
    clip-path: polygon(25% 0%,
            75% 0%,
            100% 50%,
            75% 100%,
            25% 100%,
            0% 50%);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: .06em;
}

.common_btn_box .link_box .link .text {
    width: 413px;
    height: 88px;
    background-color: #000;
    clip-path: polygon(0% 0%,
            92% 0%,
            100% 50%,
            92% 100%,
            0% 100%,
            6% 50%);
    margin: auto 0 auto -24px;
    justify-content: center;
    display: flex;
    color: #fff;
    font-size: 27.4px;
    letter-spacing: .02em;
    align-items: center;
}

.common_btn_box .link_box .link .text .size {
    display: inline-block;
    font-size: 0.7em;
    line-height: 2;
}

.common_btn_box .link_area {
    display: flex;
    align-items: center;
    width: fit-content;
    margin: 0 auto;
    gap: 20px;
}

.common_btn_box .link_area .btn {
    display: flex;
    align-items: center;
    width: 386px;
}

.common_btn_box .link_area .btn .catch {
    color: #000;
    width: 81px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: .06em;
    position: relative;
}

.common_btn_box .link_area .btn .text {
    background-color: #F1D9FC;
    width: 353px;
    height: 64px;
    clip-path: polygon(0% 0%, 92% 0%, 100% 50%, 92% 100%, 0% 100%, 6% 50%);
    margin: auto 0 auto -22.6px;
    justify-content: center;
    display: flex;
    color: #000;
    font-size: 20px;
    letter-spacing: .02em;
    align-items: center;
    position: relative;
    font-weight: 700;
}

.common_btn_box .link_area .btn .text .size {
    font-size: 0.9em;
}

.common_btn_box .link_area .btn .catch::before,
.common_btn_box .link_area .btn .catch::after {
    content: "";
    position: absolute;
}

.common_btn_box .link_area .btn .catch::before {
    content: "";
    position: absolute;
    inset: 2px;
    background-color: #F1D9FE;
    clip-path: polygon(25% 0%,
            75% 0%,
            100% 50%,
            75% 100%,
            25% 100%,
            0% 50%);
    z-index: -1;
}

.common_btn_box .link_area .btn .catch::after {
    inset: 0;
    background-color: #B883C7;
    clip-path: polygon(25% 0%,
            75% 0%,
            100% 50%,
            75% 100%,
            25% 100%,
            0% 50%);
    z-index: -2;
}

.common_btn_box .link_area .btn.line .catch::after {
    background-color: #69D397;
}

.common_btn_box .link_area .btn .text::before,
.common_btn_box .link_area .btn .text::after {
    content: "";
    position: absolute;
}

.common_btn_box .link_area .btn .text::before {
    content: "";
    position: absolute;
    inset: 2px;
    background-color: #FAECFE;
    z-index: -1;
    clip-path: polygon(0% 0%, 92% 0%, 100% 50%, 92% 100%, 0% 100%, 6% 50%);
}

.common_btn_box .link_area .btn .text::after {
    inset: 0;
    background-color: #B883C7;
    clip-path: polygon(0% 0%, 92% 0%, 100% 50%, 92% 100%, 0% 100%, 6% 50%);
    z-index: -2;
}

.common_btn_box .link_area .btn.line .text::after {
    background-color: #69D397;
}

.common_btn_box .link_area .btn.line .catch::before {
    background-color: #E8FCF0;
}

.common_btn_box .link_area .btn.line .text::before {
    background-color: #F8FFFB;
}

.common_btn_box .link_area .btn.line .text .color {
    color: #42B45B;
}

.common_btn_box .link_area .item .label {
    text-align: center;
    font-size: 14px;
    letter-spacing: .03em;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
}

.common_btn_box .link_area .item .label::before,
.common_btn_box .link_area .item .label::after {
    content: "";
    display: block;
    width: 1px;
    height: 16px;
    background-color: #000;
}

.common_btn_box .link_area .item .label::before {
    rotate: -41deg;
}

.common_btn_box .link_area .item .label::after {
    rotate: 41deg;
}

.support_sec {
    padding: 64px 0 58px;
    position: relative;
}

.support_sec .img {
    position: absolute;
    width: 853px;
    height: 458px;
    left: 0;
    top: 65px;
}

.support_sec .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0 10px 10px 0;
}

.support_sec .text {
    margin: 167px 0 0 795px;
    color: #fff;
    font-size: 28px;
    letter-spacing: .06em;
    line-height: 1.45;
}

.support_sec .icon {
    margin: 66px auto 0;
    width: 799px;
    display: block;
}

.support_sec .icon img {
    width: 100%;
}

.support_sec::before {
    content: "";
    position: absolute;
    background-color: #287FB3;
    width: 100%;
    left: 0;
    top: 120px;
    z-index: -1;
    height: calc(100% - 120px);
    pointer-events: none;
}


.achievements_sec {
    padding: 82px 0 86px;
    position: relative;
    overflow: hidden;
}

.achievements_sec .ttl_box {
    text-align: center;
    margin-bottom: 45px;
}

.achievements_sec .ttl_box .en_text {
    font-size: 22px;
    color: #2484B0;
    line-height: 1;
    margin-bottom: 0.7em;
}

.achievements_sec .ttl_box .text {
    font-size: 28.8px;
    line-height: 1;
    color: #2484B0;
}

.achievements_sec .catch_box {
    text-align: center;
    margin-bottom: 54px;
}

.achievements_sec .catch_box .label {
    font-size: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.3em;
}

.achievements_sec .catch_box .catch {
    font-size: 42px;
    line-height: 1;
    font-weight: 700;
}

.achievements_sec .img {
    margin: 0 auto 34px;
    width: 897px;
    display: block;
}

.achievements_sec .img img {
    width: 100%;
}

.support_sec .step_box {
    margin-top: 182px;
    display: flex;
    position: relative;
    justify-content: center;
    gap: 60px;
}

.support_sec .step_box .item {
    display: flex;
    align-items: center;
    gap: 16px;
    position: absolute;
    left: 267px;
    top: 73px;
}

.support_sec .step_box .item .en_text {
    color: #fff;
    font-size: 15px;
}

.support_sec .step_box .item .en_text .size {
    font-size: 1.2em;
}

.support_sec .step_box .item .en_text .num {
    font-size: 2.2em;
    font-style: italic;
}

.support_sec .step_box .item .theme {
    color: #95FC2F;
    font-size: 19px;
    line-height: 1.3;
}

.support_sec .step_box .item:nth-child(2) {
    left: 518px;
    top: 34px;
}

.support_sec .step_box .item:nth-child(3) {
    right: 258px;
    top: 5px;
    left: unset;
}

.achievements_sec .catch_box .label::before,
.achievements_sec .catch_box .label::after {
    content: "";
    display: block;
    background-color: #000;
    width: 8.4em;
    height: .1em;
}

.achievements_sec .bottom_box {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 115px;
    margin: 50px 0 0 59px;
}

.achievements_sec .bottom_box .catch_area {
    flex-shrink: 0;
}

.achievements_sec .bottom_box .catch_area .text {
    font-size: 14px;
    text-align: center;
    position: relative;
    display: flex;
    align-items: center;
    margin-bottom: 0.4em;
    letter-spacing: 0.06em;
    gap: 0.3em;
}

.achievements_sec .bottom_box .catch_area .catch {
    font-size: 34px;
    font-weight: 700;
    letter-spacing: .03em;
}

.achievements_sec .bottom_box .text_area {
    background-color: #EDF5F9;
    width: 476px;
    padding: 20px;
}

.achievements_sec .bottom_box .text_area .theme {
    font-size: 20px;
    font-weight: 700;
    text-align: center;
    line-height: 1.6;
    margin-bottom: 0.7em;
}

.achievements_sec .bottom_box .text_area .theme .small {
    display: block;
    font-size: 0.8em;
}

.achievements_sec .bottom_box .text_area .text {
    font-size: 14.5px;
    letter-spacing: .03em;
}

.achievements_sec .img .note {
    text-align: center;
    font-size: 14px;
    margin-top: 0.5em;
}

.achievements_sec .achievements_list ul {
    display: flex;
    justify-content: center;
    gap: 20px;
}

.achievements_sec .achievements_list ul li {
    position: relative;
}

.achievements_sec .achievements_list ul li .text {
    font-size: 15px;
    line-height: 1;
}

.achievements_sec .achievements_list ul li+li {}

.achievements_sec .achievements_list ul li.no_giji::before {
    content: unset;
}

.achievements_sec .achievements_list ul li::before {
    content: "";
    position: absolute;
    width: 1px;
    top: 0;
    bottom: 0;
    left: -10px;
    background-color: #000;
}

.achievements_sec .achievements_list+.achievements_list {
    margin-top: 11px;
}

.achievements_sec .bottom_box .catch_area .text::before,
.achievements_sec .bottom_box .catch_area .text::after {
    content: "";
    display: block;
    background-color: #000;
    width: 5.4em;
    height: 0.15em;
}

.youtube_sec {
    background-image: url(/wp-content/themes/tech-base-mv/image/youtube_sec_img.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    padding: 80px 0 54px;
    position: relative;
}

.youtube_sec .video video.root-6jrdpz {
    width: 100%;
    height: 100%;
}

.youtube_sec .video {
    width: 797px;
    height: 486px;
    margin: 40px auto 0;
    position: relative;
    z-index: 10;
}

.youtube_sec .video picture {
    display: none !important;
}

.youtube_sec .theme_box {
    margin-bottom: 10px;
    text-align: center;
}

.youtube_sec .theme_box .bg_text {
    background-color: #fff;
    width: fit-content;
    margin: 0 auto 0.7em;
    padding: 0.25em 2.2em;
    font-size: 20px;
    line-height: 1;
}

.youtube_sec .theme_box .text {
    font-size: 37px;
    color: #fff;
    line-height: 1;
}

.program_sec {
    padding: 160px 0;
    max-width: 100vw;
    overflow: hidden;
}

.program_sec .speech_bubble {
    min-width: 220px;
    margin: 0 auto 4px;
    width: fit-content;
    border: 1px solid #55899C;
}

.program_sec .speech_bubble .catch {
    background-color: #2D9CCF;
    color: #fff;
    font-size: 20px;
    text-align: center;
    letter-spacing: .01em;
}

.program_sec .speech_bubble .text {
    font-size: 14.2px;
    text-align: center;
    color: #50A7C7;
}

.program_sec .ttl_box {
    text-align: center;
    margin-bottom: 43px;
}

.program_sec .ttl_box .en_text {
    font-size: 22px;
    margin-bottom: .2em;
    color: #2e9ccf;
}

.program_sec .ttl_box .ttl {
    font-size: 34px;
    line-height: 1;
    letter-spacing: 0.01em;
    margin-bottom: 0.7em;
    font-weight: 700;
}

.program_sec .ttl_box .text {
    font-size: 15px;
    letter-spacing: .022em;
}

.program_sec .support_text {
    text-align: center;
    font-size: 19.7px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1em;
    letter-spacing: .05em;
    color: #fff;
    font-weight: 700;
}

.program_sec .support_text .num {
    font-size: 2.9em;
    font-style: italic;
    color: #fff;
}

.program_sec .program_list ul li {
    margin: 40px 0 0 120px;
    display: flex;
    position: relative;
    align-items: center;
}

.program_sec .program_list .img {
    width: 480px;
    height: 320px;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
    /* display: none; */
}

.program_sec .program_list .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 11px;
}

.program_sec .program_list .img .en_text {
    position: absolute;
    bottom: 5px;
    right: 0.3em;
    font-size: 63px;
    font-style: italic;
    margin: 0;
    color: #fff;
    line-height: 1;
    z-index: 1;
}

.program_sec .program_list .text_box {
    /* margin-top: 29px; */
    padding: 0;
    letter-spacing: 0.11em;
    position: relative;
    padding: 0 50px;
    flex-grow: 1;
}

.program_sec .program_list .head_box {
    display: flex;
    align-items: center;
    margin-bottom: 23px;
}

.program_sec .program_list .head_box .head_area {
    border-right: 2px solid #2688B9;
    padding-right: 19px;
    margin-right: 29px;
}

.program_sec .program_list .head_box .head_area .en_text {
    font-style: italic;
    line-height: 1;
    font-size: 18px;
    text-align: center;
    color: #2688B9;
    font-weight: 700;
}

.program_sec .program_list .head_box .head_area .num {
    font-style: italic;
    text-align: center;
    font-size: 50px;
    line-height: 1;
    color: #2688B9;
    font-weight: 700;
}

.program_sec .support_box {
    position: relative;
    display: flex;
    align-items: center;
    height: 48px;
    background: linear-gradient(90deg,
            #9edeea 0%,
            #2bb9cf 40%,
            #00a7c8 100%);
    margin: 0 auto 42px;
    width: 510px;
    justify-content: center;
    min-block-size: 70px;
    padding-left: 18px;
}

.program_sec .support_box::after {
    content: "";
    position: absolute;
    right: -24px;
    top: 0;
    width: 0;
    height: 0;
    border-top: 34px solid transparent;
    border-bottom: 34px solid transparent;
    border-left: 24px solid #00a7c8;
}

.program_sec .program_list .img .en_text::after {
    content: "";
    position: absolute;
    background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.3) 30%, rgba(0, 0, 0, 0.3) 60%);
    width: calc(100% + 38px);
    height: 100%;
    z-index: -1;
    bottom: -5px;
    right: -19px;
    border-radius: 0 0 10px 0;
}


.program_sec .program_list .head_box .text {
    font-size: 16px;
    line-height: 1.4;
    font-weight: 700;
}

.program_sec .program_list .head_box .text .size {
    font-size: 2.5em;
    display: block;
    letter-spacing: .02em;
}

.program_sec .program_list ul .item_box .item {
    display: flex;
    margin: 0;
    gap: 3px;
    align-items: center;
}

.program_sec .program_list .item_box .item .icon {
    width: 16px;
}

.program_sec .program_list ul .item_box .item+.item {
    margin-top: 3px;
}

.program_sec .program_list ul .item_box .item .text {
    line-height: 1;
    font-size: 15px;
    letter-spacing: 0.13em;
    margin-top: 0.5em;
    color: #2688B9;
    font-weight: 700;
}

.program_sec .program_list ul li:nth-child(even) {
    flex-direction: row-reverse;
    margin: 40px 120px 0 0;
}

.program_sec .program_list ul li:nth-child(even) .program_list .text_box {
    right: 0;
    left: unset;
}

.program_sec .program_list ul li:nth-child(even) .text_box {
    /* right: unset; */
    /* padding: 35px 40px 32px 220px; */
    /* left: calc(-50vw + 620px); */
}

.skill_sec .ttl_box {
    margin-bottom: 86px;
}

.skill_sec .ttl_box .speech_box {
    text-align: center;
    font-size: 18.9px;
    border: 2px solid #2585B3;
    width: fit-content;
    margin: 0 auto;
    padding: 0.15em 1.7em;
    position: relative;
    margin-bottom: 0.6em;
    color: #2585B3;
}

.skill_sec .ttl_box .speech_box::after {
    content: "";
    position: absolute;
    width: 2px;
    height: 1.3em;
    background-color: #2585B3;
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
}

.skill_sec .ttl_box .ttl {
    text-align: center;
    font-size: 34px;
    line-height: 1.5;
    font-weight: 700;
}

.skill_sec .img {
    width: 640px;
    margin-left: 190px;
    position: relative;
    display: block;
}

.skill_sec .img img {
    width: 100%;
    border-radius: 11px;
}

.skill_sec .img::after {
    content: "";
    position: absolute;
    background: url(/wp-content/themes/tech-base-mv/image/top_skill_woman.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    width: 693px;
    height: 453px;
    right: -406px;
    top: -128px;
}

.skill_sec {
    padding-bottom: 75px;
    position: relative;
}

.skill_sec::before {
    content: "";
    position: absolute;
    background: url(/wp-content/themes/tech-base-mv/image/top_skill_bg.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}

.common_btn_box.bg {
    background: url(/wp-content/themes/tech-base-mv/image/common_btn_img.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    padding: 78px 0px 81px;
    position: relative;
}

.common_btn_box.bg .bg_box {
    background-color: #fff;
    width: 1000px;
    height: 282px;
    margin: 0 auto;
    padding: 28px;
    position: relative;
}

.common_btn_box.bg .link_area .btn .catch::before {
    z-index: -1;
}

.common_btn_box.bg .link_area .btn .catch {
    z-index: 1;
}

.charm_sec .head_box {
    margin: 225px 0 256px 120px;
    position: relative;
}

.charm_sec .head_box .img {
    position: absolute;
    width: calc(50vw + 153px);
    height: 551px;
    right: calc(-50vw + 619px);
    top: -226px;
}

.charm_sec .head_box .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.charm_sec .head_box .ttl {
    font-size: 31px;
    font-weight: 700;
    letter-spacing: 0.11em;
    line-height: 1.6;
}

.charm_sec .charm_list {
    margin-bottom: 55px;
}

.charm_sec .charm_list ul {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 38px;
    justify-content: center;
    width: 998px;
    margin: 0 auto;
}

.charm_sec .charm_list ul li {
    padding: 40px 24px 0;
    position: relative;
    border-left: 1px solid #76c2e6;
    border-top: 1px solid #76c2e6;
}

.charm_sec .charm_list .speech_box {
    position: absolute;
    top: -0.9em;
    left: 1.8em;
    padding: 0.2em;
    background-color: #0099cc;
    color: #fff;
    font-size: 18px;
    letter-spacing: 0.13em;
    font-weight: bold;
    border-radius: 100vmax;
    white-space: nowrap;
    width: 8.4em;
    text-align: center;
}

.charm_sec .charm_list .text {
    font-size: 15px;
    color: #333;
    text-align: center;
    line-height: 1.2;
    margin-top: 0.2em;
}

.charm_sec .charm_list .num {
    font-size: 20px;
    color: #0099cc;
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
}

.charm_sec .charm_list .num .big {
    font-size: 2.6em;
    margin-right: 4px;
}

.charm_sec .charm_list .num .note {
    font-size: 12px;
    color: #666;
    margin-left: 4px;
}

.charm_sec .charm_list .num .size {
    font-size: 1.3em;
    margin-left: 4px;
}

.charm_sec .charm_list .catch {
    font-size: 16px;
    color: #333;
    line-height: 1.4;
    text-align: center;
}

.charm_sec .charm_list ul li:nth-child(2) {
    margin-top: 27px;
}

.charm_sec .charm_list ul li:nth-child(3) {
    margin-top: 49px;
}

.charm_sec .charm_list ul li:nth-child(4) {
    margin-top: 71px;
}

.charm_sec .charm_list .speech_box::after {
    content: "";
    position: absolute;
    width: 10px;
    height: 9px;
    background-color: #0099cc;
    clip-path: polygon(50% 100%, 0 0, 100% 0);
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
}

.charm_sec .note_text {
    font-size: 14px;
    line-height: 1.4;
    width: fit-content;
    margin: 0 auto 2.5em;
}

.charm_sec .charm_list .catch .size {
    font-size: 1.2em;
    letter-spacing: .05em;
    font-weight: 700;
}

.charm_sec .bottom_box {
    width: 800px;
    min-block-size: 220px;
    margin: 0 auto;
    min-width: 0;
    background-color: #ffffff;
    background-image: repeating-linear-gradient(0deg,
            rgba(0, 0, 0, .06) 0,
            rgba(0, 0, 0, .06) 1px,
            transparent 1px,
            transparent 16px),
        repeating-linear-gradient(90deg,
            rgba(0, 0, 0, .06) 0,
            rgba(0, 0, 0, .06) 1px,
            transparent 1px,
            transparent 16px);
    position: relative;
    display: flex;
    gap: 49.3px;
}

.charm_sec .bottom_box .bottom_list {
    width: 443px;
    height: 220px;
    background-color: #DEF3FA;
    clip-path: polygon(0 0,
            91% 0,
            100% 50%,
            91% 100%,
            0 100%);
    padding: 35px 30px 25px 65px;
    flex-shrink: 0;
}

.charm_sec .bottom_box .bottom_list ul {
    margin: 0 0 27px 45px;
}

.charm_sec .bottom_box .bottom_list ul li {
    display: flex;
    align-items: flex-end;
    gap: .3em;
}

.charm_sec .bottom_box .bottom_list .icon {
    flex-shrink: 0;
    width: 15px;
}

.charm_sec .bottom_box .bottom_list .text {
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.charm_sec .bottom_box .bottom_list .catch {
    font-size: 28px;
    letter-spacing: .05em;
    ぇっ t: ;
    ぇっ t: ぇ;
    ぇっ t: ぇっ;
    ぇっ t: ぇっt;
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
    padding: 0.2em 0 0.2em 0;
}

.charm_sec .bottom_box .text_box {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.charm_sec .bottom_box .text_box .text {
    font-size: 16px;
    margin-bottom: -0.2em;
    text-align: center;
    margin-bottom: .5em;
}

.charm_sec .bottom_box .text_box .bg_text {
    font-size: 19px;
    background: linear-gradient(90deg,
            #16a7c9 0%,
            #1fb3d6 50%,
            #16a7c9 100%);
    color: #ffffff;
    width: 13.6em;
    text-align: center;
}

.charm_sec .bottom_box .bottom_list .icon img {
    width: 100%;
}

.charm_sec .bottom_box::before {
    /* 枠線の太さ */
    content: "";
    position: absolute;
    inset: 0;
    padding: 2px;
    /* 枠線の太さ */
    background: linear-gradient(90deg,
            #28b6d6 0%,
            #2fd2c4 50%,
            #28b6d6 100%);
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    mask-composite: exclude;
    pointer-events: none;
}

.charm_sec .bottom_box .text_box .bg_text+.bg_text {
    margin-top: 8px;
}

.charm_sec .bottom_box::after {
    content: "";
    position: absolute;
    background-image: url(/wp-content/themes/tech-base-mv/image/charm_img_man.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    width: 251px;
    height: 177px;
    right: -181px;
    bottom: -83px;
    z-index: 10;
}

.voice_sec {
    padding: 78px 0;
    background-color: #EDF5F9;
}

.voice_sec .ttl_box {
    text-align: center;
    margin-bottom: 30px;
}

.voice_sec .ttl_box .catch {
    font-size: 18px;
    margin-bottom: 0.3em;
    font-weight: 700;
}

.voice_sec .ttl_box .ttl {
    font-size: 41px;
    line-height: 1;
    font-weight: 700;
}

.charm_sec {
    padding-bottom: 83px;
}

.voice_sec .voice_list ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 42px;
}

.voice_sec .voice_list ul li {
    padding-top: 3px;
    background-color: #fff;
}

.voice_sec .voice_list .case_box {
    display: flex;
    gap: 2px;
    align-items: center;
    margin: -1.5vw 0 0 22px;
}

.voice_sec .voice_list .case_box .en_text {
    background-color: #2C89C1;
    color: #fff;
    padding: 0.3em 0.9em 0.3em 0.6em;
    font-size: 16px;
    line-height: 1;
    height: 1.3em;
    clip-path: polygon(0% 0%,
            calc(100% - 10px) 0%,
            100% 50%,
            calc(100% - 9px) 100%,
            0% 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.voice_sec .voice_list .head_box {
    display: flex;
    justify-content: center;
    margin-top: -26px;
    border-bottom: 2px solid #7EAAB8;
    position: relative;
    margin-bottom: 19px;
    gap: 16px;
    margin: -26px 0 19px;
}

.voice_sec .voice_list .head_box .num_box {
    margin: 40px 0 0 25px;
}

.voice_sec .voice_list .head_box .num_box .num {
    font-size: 16px;
    text-align: right;
    line-height: 1;
    margin-bottom: 0.7em;
}

.voice_sec .voice_list .head_box .num_box .text {
    display: flex;
    line-height: 1.3;
    font-size: 16px;
}

.voice_sec .voice_list .head_box .icon {
    width: 113px;
    flex-shrink: 0;
}

.voice_sec .voice_list .head_box .icon img {
    width: 100%;
}

.voice_sec .voice_list .before_box {
    padding: 0 22px;
}

.voice_sec .voice_list .before_box .en_text {
    font-size: 18px;
}

.voice_sec .voice_list .before_box .text {
    font-size: 14px;
    border-left: 2px solid #9A9A9A;
    padding: 0 0 1.8em 1.2em;
    position: relative;
}

.voice_sec .voice_list .after_box {
    padding: 15px 24px 22px;
    background-color: #2C8ABE;
    border-radius: 2px;
}

.voice_sec .voice_list .after_box .en_text {
    font-size: 16px;
    letter-spacing: 0.03em;
    color: #fff;
}

.voice_sec .voice_list .after_box .text {
    font-size: 14px;
    border-left: 1px solid #fff;
    color: #fff;
    padding-left: 1.3em;
    margin-bottom: 1.7em;
}

.voice_sec .voice_list .after_box .after_area {
    background: #fff;
    min-block-size: 212px;
    padding: 10px;
    position: relative;
}

.voice_sec .voice_list .case_box .num {
    font-size: 39px;
    line-height: 1;
    color: #2C8ABF;
    font-style: italic;
}

.voice_sec .voice_list .before_box .text::after {
    content: "";
    position: absolute;
    background-color: #9A9A9A;
    width: 0.4em;
    height: 0.4em;
    left: -0.3em;
    bottom: 0;
    border-radius: 50%;
}

.voice_sec .voice_list ul li:nth-child(2) .head_area .num_box {
    margin: 28px 0 0 25px;
}

.voice_sec .voice_list .after_box .after_area .after_text {
    font-size: 15px;
    letter-spacing: 0.06em;
}

.course_sec {
    padding: 72px 0 78px;
    line-height: 1.5;
    position: relative;
    overflow: hidden;
}

.course_sec .wrap {
    width: 922px;
}

.course_sec .ttl {
    text-align: center;
    font-size: 29px;
    margin-bottom: 1em;
    color: #2c89c0;
    font-weight: 700;
}

.course_sec .course_list {
    margin-bottom: 80px;
}

.course_sec .course_list ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 80px;
}

.course_sec .course_list li:nth-child(even)::after {
    content: "";
    position: absolute;
    background-image: url(/wp-content/themes/tech-base-mv/image/icon_course_js.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: 63px;
    height: 77px;
    top: 68px;
    right: 25px;
    z-index: 0;
}

.course_sec .head_box {
    display: flex;
    padding-left: 30px;
    gap: 20px;
    background: linear-gradient(90deg, #D089EB 0%, #8E52E9 100%);
    min-block-size: 50px;
    align-items: center;
    justify-content: center;
    position: relative;
    border-radius: 10px 10px 0 0;
}

.course_sec .head_box .speech {
    background-color: #fff;
    position: absolute;
    left: 1.5em;
    top: -1.5em;
    font-size: 16px;
    rotate: -24deg;
    width: 5.3em;
    height: 5.2em;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #BB83EC;
    font-weight: 700;
    border: 2px solid #C86BE6;
}

.course_sec .head_box .theme {
    color: #fff;
    font-size: 20px;
    letter-spacing: .01em;
}

.course_sec .text_box {
    background-color: #F9EDFE;
    padding: 23px 20px;
}

.course_sec .text_box .catch {
    text-align: center;
    font-size: 18px;
    margin-bottom: 1.3em;
    position: relative;
    z-index: 1;
}

.course_sec .text_box .text {
    padding-left: 1.7em;
    line-height: 1;
    font-size: 15px;
    width: fit-content;
}

.course_sec .text_box .link {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 1.6em auto 0;
    color: #2B89B1;
    font-size: 18px;
    border: 2px solid #2B89B1;
    border-radius: 100vmax;
    width: 19em;
    min-block-size: 2.5em;
    position: relative;
    font-weight: 700;
    background-color: #fff;
    cursor: pointer;
}

.course_sec .course_list ul li:first-child .link {
    border-color: #9054e9;
    color: #9054e9;
}

.course_sec .course_list ul li:first-child .link::before,
.course_sec .course_list ul li:first-child .link::after {
    background-color: #9054e9;
}

.course_sec .bottom_box {
    display: grid;
    grid-template-columns: 398px 402px;
    border: 2px solid #4390A8;
    background: repeating-linear-gradient(0deg, rgba(0, 0, 0, .06) 0, rgba(0, 0, 0, .06) 1px, transparent 1px, transparent 16px), repeating-linear-gradient(90deg, rgba(0, 0, 0, .06) 0, rgba(0, 0, 0, .06) 1px, transparent 1px, transparent 16px);
    width: 800px;
    margin: 0 auto;
    position: relative;
}

.course_sec .text_box .text+.text {
    margin-top: 1.5em;
}

.course_sec .text_box .link::before,
.course_sec .text_box .link::after {
    content: "";
    position: absolute;
    background-color: #2B89B1;
}

.course_sec .text_box .link::before {
    width: .5em;
    height: 0.1em;
    right: 1.65em;
    top: 50%;
    transform: translateY(-50%);
}

.course_sec .text_box .link::after {
    height: .5em;
    width: 0.1em;
    right: 1.85em;
    top: 50%;
    transform: translateY(-50%);
}

.course_sec .course_list li:nth-child(even) .head_box {
    background: #2C89BF;
}

.course_sec .head_box .speech::before {
    content: "";
    position: absolute;
    background: url(/wp-content/themes/tech-base-mv/image/icon_course_border.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    width: 4em;
    height: 4em;
    top: -1.1em;
    right: -2.6em;
    rotate: 33deg;
}

.course_sec .course_list ul li {
    position: relative;
    z-index: 0;
}

.course_sec .course_list ul li::after {
    content: "";
    position: absolute;
    background-image: url(/wp-content/themes/tech-base-mv/image/icon_course_php.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: 63px;
    height: 77px;
    top: 68px;
    right: 25px;
    z-index: 0;
    opacity: .7;
}

.course_sec .course_list ul li+li::before {
    background: url(/wp-content/themes/tech-base-mv/image/icon_course_js.svg);
}

.course_sec .course_list li:nth-child(even) {
    position: relative;
}

.course_sec .bottom_box .text_box {
    background-color: #DEF4F9;
    padding: 56px 20px 63px 53px;
    width: 398px;
    flex-shrink: 0;
}

.course_sec .bottom_box .text_area {
    display: flex;
    align-items: flex-end;
    gap: 7px;
}

.course_sec .bottom_box .icon {
    width: 17px;
}

.course_sec .bottom_box .icon img {
    width: 100%;
}

.course_sec .bottom_box .text {
    font-size: 16px;
    padding: 0;
    font-weight: 700;
    letter-spacing: .03em;
}

.course_sec .en_text {
    border-radius: 50%;
    border: 2px solid #4390A8;
    width: 64px;
    height: 64px;
    font-size: 17px;
    top: 50%;
    position: absolute;
    transform: translate(-50%, -50%);
    left: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #448EA5;
    background-color: #fff;
}

.course_sec .line_box {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.course_sec .line_box .line {
    font-size: 20px;
    width: 12.1em;
    text-align: left;
    background: linear-gradient(to right, #3CBAE0 0%, #91E0E4 100%);
    padding: 0.1em .2em .1em 0.6em;
    color: #fff;
}

.faq_sec {
    padding: 82px 0 40px;
    background-color: #EDF5F9;
}

.faq_sec .ttl {
    text-align: center;
    font-size: 33px;
    color: #2A84B3;
    margin-bottom: 1.1em;
    font-weight: 700;
}

.faq_sec .que_box {
    padding: 25px 0 24px;
    border-top: 1px solid #2A84B3;
    display: flex;
    justify-content: space-between;
    gap: 10px;
    gap: 4vw;
    transition: .3s;
}

.faq_sec .que_box .text {
    font-size: 17px;
    color: #2A84B3;
    font-weight: 700;
}

.course_sec .line_box .line+.line {
    margin-top: .3em;
}

.course_sec .bottom_box::after {
    content: "";
    position: absolute;
    background-image: url(/wp-content/themes/tech-base-mv/image/course_img_woman.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    width: 240px;
    height: 170px;
    bottom: -80px;
    left: -130px;
}

.faq_sec .que_box .icon {
    width: 30px;
    height: 30px;
    border: 2px solid #2A84B3;
    border-radius: 50%;
    position: relative;
    flex-shrink: 0;
}

.faq_sec .ans_box {
    padding-bottom: 15px;
}

.faq_sec .ans_box .text {
    font-size: 14px;
    color: #65696b;
}

.faq_sec .que_box .icon::before,
.faq_sec .que_box .icon::after {
    content: "";
    position: absolute;
    background-color: #2A84B3;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

.faq_sec .que_box .icon::before {
    width: 12px;
    height: 2px;
}

.faq_sec .que_box .icon::after {
    width: 2px;
    height: 12px;
}

.message_sec {
    padding-top: 34px;
    position: relative;
}

.faq_sec .ans_box .closeBtnHat {
    display: none;
}

.message_sec .cont .text_box {
    margin-top: 84px;
}

.message_sec .text_box .speech {
    width: fit-content;
    border: 1px solid #2B87AE;
    color: #2B87AE;
    font-weight: 700;
    min-width: 19.9em;
    text-align: center;
    min-block-size: 2.3em;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    letter-spacing: .023em;
    position: relative;
    margin-bottom: 1.3em;
}

.message_sec .text_box .ttl {
    font-size: 35px;
    text-align: center;
    font-weight: 700;
    line-height: 1.55;
}

.message_sec .img {
    width: 268px;
}

.message_sec .cont {
    display: flex;
    gap: 107px;
    justify-content: center;
}

.message_sec .img img {
    width: 100%;
    transform: scale(-1, 1);
}

.message_sec .text_box .speech::after {
    content: "";
    position: absolute;
    width: 0.15em;
    height: 1.1em;
    background-color: #2B87AE;
    bottom: -0.9em;
    left: 50%;
    transform: translateX(-50%);
}

.footer {
    padding: 27px;
}

.footer .footer_box .footer_list ul {
    justify-content: center;
    gap: 20px;
    display: flex;
}

.footer .footer_box .footer_list ul .link {
    font-weight: 700;
    display: block;
    font-size: 16px;
    color: #000;
    letter-spacing: .03em;
}

.footer .footer_box .footer_list {
    margin-bottom: 15px;
}

.footer .footer_box .copyright small {
    text-align: center;
    display: block;
    font-size: 14px;
}

.voice_sec .voice_list .after_box .after_area::before {
    content: "";
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background: repeating-linear-gradient(0deg, rgba(0, 0, 0, .06) 0, rgba(0, 0, 0, .06) 1px, transparent 1px, transparent 16px), repeating-linear-gradient(90deg, rgba(0, 0, 0, .06) 0, rgba(0, 0, 0, .06) 1px, transparent 1px, transparent 16px);
}

.modal {
    position: fixed;
    inset: 0;
    display: none;
    z-index: 1000;
}

.modal.is-open {
    display: block;
}

.modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
}

.modal__content {
    position: relative;
    max-width: 720px;
    width: calc(100% - 32px);
    margin: 160px auto;
    background: #fff;
    border-radius: 12px;
    padding: 32px 24px 40px;
}

.modal__close {
    position: absolute;
    top: 16px;
    right: 16px;
    border: none;
    background: none;
    font-size: 24px;
    cursor: pointer;
}

.modal__title {
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    color: #8a3fb3;
    margin-bottom: 19px;
}

.flow {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.flow__box {
    width: 100%;
    max-width: 520px;
    border: 2px solid #c9a3df;
    padding: 7px;
    text-align: center;
}

.flow__box-title {
    font-weight: 700;
    margin-bottom: 4px;
}

.flow__box-text {
    font-size: 14px;
}

.flow__arrow {
    margin: 12px 0;
    text-align: center;
    color: #8a3fb3;
    font-size: 14px;
}

.flow__arrow::after {
    content: "";
    display: block;
    width: 2px;
    height: 24px;
    margin: 8px auto 0;
    background: #8a3fb3;
}

.modal #closeModal {
    background-color: #2C89BF;
    color: #fff;
    border-radius: 50%;
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: -20px;
    right: -20px;
}

.flow__arrow p {
    font-weight: 700;
}

.modal__body {
    display: none;
}

.modal__body.is-active {
    display: block;
}

.program_sec .program_list .text_box::before {
    background-color: #EDF5F9;
    content: "";
    position: absolute;
    width: 100vw;
    height: calc(100% + 80px);
    z-index: -1;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.program_sec .program_list ul li:nth-child(even) .text_box::before {
    left: unset;
    right: 0;
}

.achievements_sec::before {
    content: "";
    position: absolute;
    background-image: url(/wp-content/themes/tech-base-mv/image/achievements_bg_img.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    width: 730px;
    height: 450px;
    top: -130px;
    left: -40px;
    opacity: .7;
    rotate: -15deg;
}

.common_btn_box.bg::before {
    content: "";
    position: absolute;
    background: url(/wp-content/themes/tech-base-mv/image/support_bg_img.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: 480px;
    height: 280px;
    right: 0;
    z-index: 0;
    top: 0px;
}

.course_sec::before {
    content: "";
    position: absolute;
    background: url(/wp-content/themes/tech-base-mv/image/achievements_bg_img.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: 700px;
    height: 330px;
    top: -80px;
    left: 360px;
    rotate: 25deg;
    opacity: .5;
}

.message_sec::before {
    content: "";
    position: absolute;
    background: url(/wp-content/themes/tech-base-mv/image/message_bg_img.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    pointer-events: none;
    opacity: .6;
}

.youtube_sec::before {
    content: "";
    position: absolute;
    background: url(/wp-content/themes/tech-base-mv/image/video_img_bg.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: 100%;
    height: 100%;
    inset: 0;
    opacity: 0.2;
}

.top_mv_sec::before {
    content: "";
    position: absolute;
    background-image: url(/wp-content/themes/tech-base-mv/image/mv_img_bg.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    padding: 0;
    width: 100%;
    height: 100%;
    inset: 0;
    opacity: 0.3;
    pointer-events: none;
}

.top_mv_sec::after {
    content: "";
    position: absolute;
    background: linear-gradient(to bottom, #F2F5F6 0%, #fff 100%);
    width: 100%;
    height: 100%;
    inset: 0;
    z-index: -1;
    pointer-events: none;
}

.support_sec::after {
    content: "";
    position: absolute;
    background: linear-gradient(to bottom, #F2F5F6 0%, #000000 100%);
}

.support_sec::after {
    content: "";
    position: absolute;
    background-image: url(/wp-content/themes/tech-base-mv/image/support_bg_img.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    padding: 0;
    width: calc(100vw - 853px);
    aspect-ratio: 16/10;
    top: 160px;
    left: 853px;
    z-index: -1;
    opacity: 0.4;
}

.top_fixed_area {
    position: fixed;
    bottom: 20px;
    right: 35px;
    z-index: 10;
    background-color: #000000;
    padding: 20px 10px;
    opacity: 0;
    transition: .3s;
}

.top_fixed_area.active {
    opacity: 1;
}

.top_fixed_area::before {
    clip-path: polygon(100% 0, 0 50%, 100% 100%);
    left: 1px;
    transform: translateX(-100%);
}

.top_fixed_area::after {
    clip-path: polygon(0 0, 0% 100%, 100% 50%);
    right: 1px;
    transform: translateX(100%);
}

.top_fixed_area::before,
.top_fixed_area::after {
    content: "";
    width: 20px;
    top: 0;
    bottom: 0;
    position: absolute;
    background-color: #000;
}

.top_fixed_area .top_fixed_area_head {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1em;
    color: #fff;
    font-size: 16px;
    margin-bottom: .5em;
    font-weight: 700;
}

.top_fixed_area .top_fixed_area_head::before,
.top_fixed_area .top_fixed_area_head::after {
    content: "";
    width: 2px;
    background-color: #fff;
    height: 1em;
}

.top_fixed_area .top_fixed_area_head::before {
    transform: rotate(-20deg);
}

.top_fixed_area .top_fixed_area_head::after {
    transform: rotate(20deg);
}

.top_fixed_area .top_fixed_area_btn_flex {
    display: flex;
    align-items: center;
    gap: 20px;
    justify-content: center;
}

.top_fixed_area .top_fixed_area_btn_flex .top_fixed_area_btn {
    display: flex;
    align-items: center;
    color: #fff;
    font-size: 14px;
    line-height: 1.3;
    gap: 0.5em;
}

.top_fixed_area .top_fixed_area_btn_flex .top_fixed_area_btn .btn_letter {
    border-bottom: 1px solid #fff;
    padding-bottom: .3em;
}

.top_fixed_area .top_fixed_area_btn_flex .top_fixed_area_btn .btn_head {
    color: #000;
    width: 4.3em;
    aspect-ratio: 10/ 8.9;
    background: linear-gradient(to right, #87e9f3, #33abe0);
    clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-size: 0.8em;
    font-weight: 700;
    letter-spacing: .06em;
    flex-shrink: 0;
}

.course_sec .course_list ul li:nth-child(even) .text_box {
    background-color: #F6F6F6;
}

.faq_sec .que_box.switchHat.switchOn.nowOpen .icon::after {
    display: none;
}

.top_mv_sec .cont .text_box .line_box .line_text+.line_text {
    background-color: #2C89BF;
}

@media (max-width: 750px) {
    .pc {
        display: none;
    }

    .sp {
        display: block;
    }

    .top_mv_sec {
        padding: 4vw 0;
    }

    .top_mv_sec .icon {
        width: 44vw;
    }

    .top_mv_sec .cont .img {
        top: 0vw;
        width: 49vw;
        height: 40vw;
        right: -5vw;
        left: unset;
    }

    .top_mv_sec .cont .img.right {
        top: 17vw;
        left: -1vw;
    }

    .top_mv_sec .cont .text_box {
        margin-top: 4vw;
    }

    .top_mv_sec .cont .text_box .theme {
        text-align: left;
        font-size: 4.7vw;
        margin-bottom: 45vw;
    }

    .top_mv_sec .cont .text_box .line_box .line_text {
        margin: 5vw 0 0 calc(-5vw);
        padding: 0.4em 0.7em;
        line-height: 1;
        font-size: 5.1vw;
    }

    .top_mv_sec .cont .text_box .line_box .line_text:nth-child(2) {
        margin: 0 0 0 13vw;
    }

    .top_mv_sec .cont .catch_box .catch {
        font-size: 6.8vw;
        line-height: 1.3;
    }

    .top_mv_sec .cont .text_box .line_box {
        margin-bottom: 3vw;
    }

    .top_mv_sec .cont .catch_box .catch .size {
        font-size: 1.35em;
    }

    .top_mv_sec .en_list ul {
        gap: 3vw;
        display: grid;
        grid-template-columns: repeat(3, 1fr);
    }

    .top_mv_sec .en_list ul li {
        width: 100%;
        padding: 1vw;
        aspect-ratio: 1;
        height: auto;
    }

    .top_mv_sec .en_list ul li .text {
        font-size: 4.8vw;
        letter-spacing: .01em;
    }

    .top_mv_sec .en_list ul li .text .size {
        font-size: 0.6em;
    }

    .common_btn_box {
        padding: 4vw 0 16vw;
    }

    .common_btn_box .yer {
        font-size: 3.8vw;
        line-height: 1;
        margin-bottom: 0.6em;
    }

    .common_btn_box .link_box .link {
        margin: 0 auto 4vw;
    }

    .common_btn_box .link_box .link .catch {
        width: 18vw;
        height: 17vw;
        font-size: 4.5vw;
    }

    .common_btn_box .link_box .link .text {
        width: 70vw;
        height: 17vw;
        margin: 0 0 0 -4.5vw;
        font-size: 4.7vw;
    }

    .common_btn_box .link_box .link .text .size {}

    .common_btn_box .link_area {
        flex-direction: column;
        gap: 6vw;
    }

    .common_btn_box .link_area .btn {
        width: 84vw;
    }

    .common_btn_box .link_area .btn .catch {
        width: 25vw;
        height: 17vw;
        font-size: 4.6vw;
    }

    .common_btn_box .link_area .btn .text {
        width: 100%;
        height: 17vw;
        font-size: 4.4vw;
        margin: auto 0 auto -6vw;
    }

    .common_btn_box .link_area .btn .text .size {}

    .common_btn_box .link_area .btn .catch::before {}

    .common_btn_box .link_area .btn .catch::after {}

    .common_btn_box .link_area .btn.line .catch::after {}

    .common_btn_box .link_area .btn .text::before {}

    .common_btn_box .link_area .btn .text::after {}

    .common_btn_box .link_area .btn.line .text::after {}

    .common_btn_box .link_area .btn.line .catch::before {}

    .common_btn_box .link_area .btn.line .text::before {}

    .common_btn_box .link_area .btn.line .text .color {
        font-size: 5vw;
    }

    .common_btn_box .link_area .item .label {
        font-size: 3.5vw;
        gap: 2vw;
    }

    .common_btn_box .link_area .item .label::before {}

    .common_btn_box .link_area .item .label::after {}

    .support_sec {
        padding: 0;
    }

    .support_sec .img {
        top: -67vw;
        width: 92vw;
        height: 62vw;
    }

    .support_sec .img img {}

    .support_sec .text {
        margin: 68vw 0 0 2vw;
        font-size: 6.9vw;
        letter-spacing: 0;
    }

    .support_sec .icon {
        margin: 28vw 0 0 -5vw;
        width: 100vw;
    }

    .support_sec::before {
        top: -51vw;
        height: calc(100% - -51vw);
    }

    .achievements_sec {
        padding: 16.4vw 0 13.5vw;
    }

    .achievements_sec .ttl_box {
        margin-bottom: 11.8vw;
    }

    .achievements_sec .ttl_box .en_text {
        font-size: 5.3vw;
        margin-bottom: 0.4em;
    }

    .achievements_sec .ttl_box .text {
        font-size: 6.7vw;
        line-height: 1.2;
    }

    .achievements_sec .catch_box {
        margin-bottom: 6vw;
    }

    .achievements_sec .catch_box .label {
        font-size: 3.6vw;
        gap: 1.6vw;
        margin-bottom: 2.7vw;
    }

    .achievements_sec .catch_box .catch {
        font-size: 9vw;
    }

    .achievements_sec .img {
        width: 100%;
        margin: 0 auto 5vw;
    }

    .achievements_sec .img img {}

    .support_sec .step_box {
        margin: 0;
        gap: 5vw;
    }

    .support_sec .step_box .item {
        top: 17vw;
        left: -1vw;
        flex-direction: column;
        gap: 2.5vw;
    }

    .support_sec .step_box .item .en_text {
        font-size: 3.2vw;
        line-height: 1.4em;
    }

    .support_sec .step_box .item .en_text .size {}

    .support_sec .step_box .item .en_text .num {
        font-size: 2em;
    }

    .support_sec .step_box .item .theme {
        font-size: 4vw;
        letter-spacing: .03em;
    }

    .support_sec .step_box .item:nth-child(2) {
        top: 10.5vw;
        left: 30vw;
    }

    .support_sec .step_box .item:nth-child(3) {
        top: 4.4vw;
        right: -1vw;
    }

    .top_mv_sec .cont {
        margin-bottom: 5vw;
    }

    .achievements_sec .catch_box .label::before,
    .achievements_sec .catch_box .label::after {
        width: 7.6em;
        height: 0.15em;
    }

    .achievements_sec .catch_box .label::after {}

    .achievements_sec .bottom_box {
        margin: 10.6vw 0 0 5vw;
        gap: 0;
        flex-direction: column;
    }

    .achievements_sec .bottom_box .catch_area {}

    .achievements_sec .bottom_box .catch_area .text {
        font-size: 3.3vw;
        letter-spacing: 0.06em;
    }

    .achievements_sec .bottom_box .catch_area .catch {
        font-size: 7.6vw;
    }

    .achievements_sec .bottom_box .text_area {
        padding: 5vw 4vw 4vw;
        width: 100%;
        margin-top: 10vw;
    }

    .achievements_sec .bottom_box .text_area .theme {
        font-size: 5vw;
    }

    .achievements_sec .bottom_box .text_area .theme .small {}

    .achievements_sec .bottom_box .text_area .text {
        font-size: 3.5vw;
        letter-spacing: 0.04em;
    }

    .achievements_sec .img .note {
        font-size: 2.9vw;
    }

    .achievements_sec .achievements_list ul {
        flex-wrap: wrap;
        gap: 2vw 4vw;
    }

    .achievements_sec .achievements_list ul li .text {
        font-size: 3.8vw;
        line-height: 1.5;
    }

    .achievements_sec .achievements_list ul li+li {}

    .achievements_sec .achievements_list ul li::before {
        left: -2vw;
    }

    .achievements_sec .achievements_list+.achievements_list {
        margin-top: 2vw;
    }

    .achievements_sec .bottom_box .catch_area .text::before {}

    .achievements_sec .bottom_box .catch_area .text::after {}

    .youtube_sec {
        padding: 10.7vw 0 13vw;
    }

    .youtube_sec .video {
        width: 100%;
        height: 49vw;
    }

    .youtube_sec .video video {}

    .youtube_sec .theme_box {}

    .youtube_sec .theme_box .bg_text {
        font-size: 4.8vw;
        padding: 0.25em 1.7em;
        margin: 0 auto 0.5em;
    }

    .youtube_sec .theme_box .text {
        font-size: 6.7vw;
    }

    .program_sec {
        padding: 10vw 0;
    }

    .program_sec .speech_bubble {
        min-width: 61vw;
    }

    .program_sec .speech_bubble .catch {
        font-size: 4.8vw;
    }

    .program_sec .speech_bubble .text {
        font-size: 3.7vw;
    }

    .program_sec .ttl_box {
        margin-bottom: 8vw;
    }

    .program_sec .ttl_box .en_text {}

    .program_sec .ttl_box .ttl {
        font-size: 9vw;
        line-height: 1.1;
        margin-bottom: 0.6em;
    }

    .program_sec .ttl_box .text {
        font-size: 3.9vw;
    }

    .program_sec .support_text {
        font-size: 4.7vw;
        color: #fff;
        gap: 2.3vw;
    }

    .program_sec .support_text .num {
        font-size: 11vw;
    }

    .program_sec .program_list ul li {
        margin: 0;
        flex-direction: column;
    }

    .program_sec .program_list .img {
        width: 92vw;
        height: 62vw;
        margin-left: -5vw;
    }

    .program_sec .program_list .img img {
        border-radius: 0 2vw 2vw 0;
    }

    .program_sec .program_list .img .en_text {
        right: 19px;
        font-size: 12vw;
        bottom: 1.5vw;
    }

    .program_sec .program_list .text_box {
        width: 100%;
        position: relative;
        right: 0;
        padding: 0;
        margin-top: 6.5vw;
        height: unset;
        background-color: unset;
    }

    .program_sec .program_list .head_box {
        margin-bottom: 7.1vw;
    }

    .program_sec .program_list .head_box .head_area {
        padding-right: 4.8vw;
        margin-right: 4vw;
    }

    .program_sec .program_list .head_box .head_area .en_text {
        font-size: 3.3vw;
    }

    .program_sec .program_list .head_box .head_area .num {
        font-size: 11.1vw;
    }

    .program_sec .support_box {
        min-block-size: 3vw;
        width: 91vw;
        margin: 0 0 9vw -5vw;
        padding-left: 5.2vw;
    }

    .program_sec .support_box::after {
        border-top: 6.7vw solid transparent;
        border-bottom: 6.5vw solid transparent;
        border-left: 6.4vw solid #00a7c8;
    }

    .program_sec .program_list .img .en_text::after {}

    .program_sec .program_list .head_box .text {
        font-size: 3.6vw;
    }

    .program_sec .program_list .head_box .text .size {}

    .program_sec .program_list .item_box .item {}

    .program_sec .program_list .item_box .item .icon {
        width: 4vw;
    }

    .program_sec .program_list .item_box .item+.item {}

    .program_sec .program_list .item_box .item .text {}

    .program_sec .program_list ul li:nth-child(even) {
        flex-direction: column;
        margin: 22vw 0 0 0;
        position: relative;
    }

    .program_sec .program_list ul li:nth-child(even) .text_box {
        left: 0;
        padding: 0;
    }

    body {
        overflow: hidden;
    }

    .program_sec .program_list ul .item_box .item {
        gap: 1vw;
        line-height: 1;
    }

    .program_sec .program_list ul .item_box .item .text {
        font-size: 3.5vw;
        margin: 0;
    }

    .program_sec .program_list ul .item_box .item+.item {
        margin-top: 3.7vw;
    }

    .program_sec .program_list ul li:nth-child(even) .img {
        margin-left: 11px;
    }

    .program_sec .program_list ul li:nth-child(even) .img img {
        border-radius: 2vw 0 0 2vw;
    }

    .program_sec .program_list ul li+li {
        margin-top: 23vw;
    }

    .skill_sec {
        padding: 30vw 0 61vw;
    }

    .skill_sec .ttl_box {
        margin-bottom: 4vw;
    }

    .skill_sec .ttl_box .speech_box {
        padding: 0.05em 1.1em;
        font-size: 4.6vw;
        margin: 0 auto 3.6vw;
    }

    .skill_sec .ttl_box .ttl {
        font-size: 7.3vw;
    }

    .skill_sec .img {
        margin: 0;
        width: 94%;
        margin: 0 auto;
    }

    .program_sec .program_list ul li::before {
        content: "";
        position: absolute;
        height: 98vw;
        width: 81vw;
        right: -30px;
        top: 27vw;
        background-color: #EDF2FA;
        border-radius: 0 0 0 2vw;
    }

    .program_sec .program_list ul li:nth-child(even)::before {
        left: -5vw;
        border-radius: 0 0 2vw 0;
    }

    .skill_sec .img img {}

    .skill_sec .img::after {
        width: 110vw;
        left: 50%;
        top: 54vw;
        transform: translate(-53%);
    }

    .skill_sec::before {}

    .common_btn_box.bg {
        padding: 15.4vw 0;
    }

    .common_btn_box.bg .bg_box {
        width: 85vw;
        padding: 7vw 5vw;
        height: unset;
        border-radius: 10px;
    }

    .common_btn_box.bg .link_area .btn .catch::before {}

    .common_btn_box.bg .link_area .btn .catch {
        width: 17.5vw;
        height: 15vw;
        font-size: 4vw;
    }

    .charm_sec {}

    .charm_sec .head_box {
        margin: 0 0 10vw 0;
    }

    .charm_sec .head_box .img {
        width: calc(100% + 10vw);
        right: calc(-50vw + 45vw);
        height: 73vw;
        top: -80vw;
    }

    .charm_sec .head_box .img img {}

    .charm_sec .head_box .ttl {
        font-size: 6.7vw;
        margin-top: 80vw;
        text-align: center;
    }

    .charm_sec .charm_list {
        margin-bottom: 10vw;
    }

    .charm_sec .charm_list ul {
        grid-template-columns: repeat(2, 1fr);
        width: 100%;
        gap: 2vw;
    }

    .charm_sec .charm_list ul li {
        padding: 7vw 0px 0;
    }

    .charm_sec .charm_list .speech_box {
        font-size: 4.6vw;
        width: 29vw;
        left: 1.8em;
    }

    .charm_sec .charm_list .text {
        font-size: 3.9vw;
        margin-bottom: 0.8vw;
    }

    .charm_sec .charm_list .num {
        font-size: 4.3vw;
        line-height: 1.2;
        margin-bottom: 0.6em;
    }

    .charm_sec .charm_list .num .big {
        font-size: 2.1em;
    }

    .charm_sec .charm_list .num .note {}

    .charm_sec .charm_list .num .size {}

    .charm_sec .charm_list .catch {
        font-size: 3.5vw;
    }

    .charm_sec .charm_list ul li:nth-child(2) {}

    .charm_sec .charm_list ul li:nth-child(3) {
        margin-top: 6.2vw;
    }

    .charm_sec .charm_list ul li:nth-child(4) {
        margin-top: 12vw;
    }

    .charm_sec .charm_list .speech_box::after {}

    .charm_sec .note_text {
        font-size: 3vw;
        margin: 0 auto 3.5em;
    }

    .charm_sec .charm_list .catch .size {
        font-size: 1.4em;
    }

    .charm_sec .bottom_box {
        width: 93%;
        flex-direction: column;
        position: relative;
        border: 1.5px solid #3198C6;
        gap: 5vw;
        padding: 0 0 8vw;
    }

    .charm_sec .bottom_box .bottom_list {
        width: 100%;
        height: 48vw;
        text-align: center;
        clip-path: polygon(0 0, 100% 0, 100% 85%, 50% 100%, 0 85%);
        padding: 0;
        padding-top: 3vw;
    }

    .charm_sec .bottom_box .bottom_list ul {
        margin: 0 0 5.9vw 0;
    }

    .charm_sec .bottom_box .bottom_list ul li {
        justify-content: center;
        line-height: 1.6;
    }

    .charm_sec .bottom_box .bottom_list .icon {}

    .charm_sec .bottom_box .bottom_list .text {
        font-size: 4vw;
    }

    .charm_sec .bottom_box .bottom_list .catch {
        font-size: 6.2vw;
        text-align: center;
        padding: 0.1em 0 0.1em 0;
        border: unset;
        position: relative;
    }

    .charm_sec .bottom_box .text_box {
        margin-top: 3vw;
    }

    .charm_sec .bottom_box .text_box .text {
        position: absolute;
        top: 40vw;
        font-size: 3.4vw;
        left: 50%;
        transform: translateX(-50%);
    }

    .charm_sec .bottom_box .text_box .bg_text {
        font-size: 5vw;
        margin: 0 auto;
        width: 12.2em;
    }

    .charm_sec .bottom_box::before {
        display: none;
    }

    .charm_sec .bottom_box::after {
        top: 74vw;
        right: -8.3vw;
        width: 35vw;
        height: 25vw;
    }

    .voice_sec {
        padding: 10vw 0 15vw;
        overflow: scroll;
    }

    .voice_sec .ttl_box {}

    .voice_sec .ttl_box .catch {
        font-size: 4.4vw;
        line-height: 1.5;
        margin-bottom: 0.4em;
        letter-spacing: .03em;
    }

    .voice_sec .ttl_box .ttl {
        font-size: 9vw;
    }

    .voice_sec .voice_list ul {
        display: flex;
        gap: 5vw;
    }

    .voice_sec .voice_list ul li {
        padding: 0;
        /* width: 71.1vw !important; */
        margin: 0 4vw;
    }

    .voice_sec .voice_list .case_box {
        margin-left: 5vw;
        gap: 0vw;
    }

    .voice_sec .voice_list .case_box .en_text {
        font-size: 4vw;
        padding: 0 0.6em;
        height: 1.2em;
    }

    .voice_sec .voice_list .head_box {
        margin: -6vw 0 -0.1vw;
        gap: 3vw;
    }

    .voice_sec .voice_list .head_box .num_box {
        margin: 9vw 0 0 13.2vw;
    }

    .voice_sec .voice_list .head_box .num_box .num {
        font-size: 3.6vw;
        margin-bottom: 0.4em;
    }

    .voice_sec .voice_list .head_box .num_box .text {
        font-size: 3.4vw;
    }

    .voice_sec .voice_list .head_box .icon {
        width: 26vw;
    }

    .voice_sec .voice_list .before_box .en_text {
        font-size: 4.8vw;
    }

    .voice_sec .voice_list .before_box .text {
        font-size: 3vw;
        padding: 0 0 1.5em 1.2em;
        margin-left: .3em;
    }

    .voice_sec .voice_list .after_box {
        padding: 4vw 7vw 5vw 7vw;
        border-radius: 0 0 2vw 2vw;
    }

    .voice_sec .voice_list .after_box .en_text {
        font-size: 4.8vw;
    }

    .voice_sec .voice_list .after_box .text {
        font-size: 3.2vw;
        margin-bottom: 1.3em;
    }

    .voice_sec .voice_list .after_box .after_area {
        min-block-size: 0;
        padding: 2.9vw;
        min-height: 54vw;
    }

    .voice_sec .voice_list .case_box .num {
        font-size: 9.1vw;
    }

    .voice_sec .voice_list .after_box .after_area .after_text {
        font-size: 3.6vw;
        line-height: 1.9;
    }

    .common_btn_box.bg .bg_box .link_box .link .text {
        width: 61vw;
        height: 16vw;
    }

    .common_btn_box.bg .bg_box .link_box .link .catch {
        width: 17.5vw;
        height: 16vw;
    }

    .common_btn_box.bg .bg_box .link_box .link_area {
        justify-content: left;
        align-items: baseline;
    }

    .common_btn_box.bg .bg_box .link_box .link_area .item .btn {
        width: 75vw;
    }

    .common_btn_box.bg .bg_box .link_box .link_area .item .btn .text {
        height: 15.3vw;
        font-size: 3.9vw;
    }

    .charm_sec .bottom_box .bottom_list .catch::before,
    .charm_sec .bottom_box .bottom_list .catch::after {
        content: "";
        position: absolute;
        width: 82%;
        height: 2px;
        background-color: #3198C6;
        left: 50%;
        transform: translateX(-50%);
    }

    .charm_sec .bottom_box .bottom_list .catch::before {
        top: 0;
    }

    .charm_sec .bottom_box .bottom_list .catch::after {
        bottom: -1.3vw;
    }

    .voice_sec .voice_list button.slick-prev.slick-arrow {
        top: unset;
        bottom: -17vw;
        border: 1px solid #000;
        left: 50%;
        transform: translateX(-180%);
        z-index: 2;
        border-radius: 50%;
        width: 12vw;
        height: 12vw;
        display: flex;
        align-items: center;
        justify-content: center;
        color: #000;
    }

    .voice_sec .voice_list button.slick-prev.slick-arrow::before {
        color: #000;
        font-size: 4.5vw;
        text-align: center;
    }

    button.slick-next.slick-arrow {
        top: unset;
        bottom: -17vw;
        border: 1px solid #000;
        left: 50%;
        z-index: 2;
        border-radius: 50%;
        width: 12vw;
        height: 12vw;
        display: flex;
        align-items: center;
        justify-content: center;
        transform: translateX(120%);
    }

    button.slick-next.slick-arrow::before {
        color: #000;
        font-size: 5.5vw;
        text-align: center;
    }

    .voice_sec .voice_list ul .slick-dots {
        justify-content: center;
        bottom: -13vw;
        gap: 2.5vw;
        left: 3vw;
    }

    .voice_sec .voice_list ul .slick-dots .presentation {
        width: 2vw;
        background-color: #000;
    }

    .voice_sec .voice_list ul .slick-dots li.slick-active {
        width: 2vw !important;
        background-color: #000;
        border-radius: 50%;
        height: 2vw !important;
    }

    .voice_sec .voice_list ul .slick-dots li {
        width: 2vw !important;
        background-color: #C3C9CD;
        border-radius: 50%;
        height: 2vw !important;
        margin: 0;
    }

    .voice_sec .voice_list ul .slick-dots li button {
        width: 100%;
        height: 100%;
        padding: 0;
    }

    .voice_sec .voice_list ul li {
        /* margin-right: 4vw; */
    }

    .course_sec .ttl {
        font-size: 6.5vw;
        line-height: 1.4;
        margin-bottom: 1.6em;
    }

    .course_sec .course_list {
        margin-bottom: 14vw;
    }

    .course_sec .course_list ul {
        grid-template-columns: 1fr;
        gap: 13vw;
    }

    .course_sec .head_box {
        padding: 0;
        min-block-size: 11vw;
        border-radius: 0 1.5vw 0 0;
    }

    .course_sec .head_box .speech {
        width: 4.5em;
        height: 4.5em;
        left: 1em;
    }

    .course_sec .head_box .theme {
        font-size: 4.8vw;
    }

    .course_sec .text_box {
        padding: 6vw 4vw;
    }

    .course_sec .text_box .catch {
        font-size: 4.3vw;
        margin-bottom: 1.1em;
    }

    .course_sec .text_box .text {
        font-size: 3.6vw;
    }

    .course_sec .text_box .link {
        width: 76vw;
        margin: 1.7em auto 0;
        font-size: 4.2vw;
    }

    .course_sec .bottom_box {
        width: 84vw;
        grid-template-columns: 1fr;
    }

    .course_sec .bottom_box .text_box {
        width: 100%;
        padding: 5vw 0 0 11vw;
        min-block-size: 27vw;
    }

    .course_sec .bottom_box .text_area {}

    .course_sec .bottom_box .icon {
        width: 3.6vw;
    }

    .course_sec .bottom_box .text {}

    .course_sec .en_text {
        width: 13.5vw;
        height: 13.5vw;
        border: 2px solid #4390A8;
        top: 28.6vw;
        font-size: 3.7vw;
        color: #4390A8;
    }

    .course_sec .line_box {
        padding: 12vw 0px 6vw;
    }

    .course_sec .line_box .line {
        font-size: 4.5vw;
        width: 56vw;
        padding: 0.2em .2em 0.2em 0.6em;
    }

    .course_sec .line_box .line+.line {
        margin-top: 2.1vw;
    }

    .faq_sec {
        padding: 12vw 0 5vw;
    }

    .faq_sec .ttl {
        font-size: 7.3vw;
        line-height: 1.4;
        margin-bottom: 1.6em;
    }

    .course_sec .text_box .text+.text {
        margin-top: 1em;
    }

    .course_sec .course_list ul li:nth-child(even) {
        margin: 0 0 0 3vw;
    }

    .course_sec .course_list li:nth-child(even) .head_box {
        border-radius: 2vw 0 0;
    }

    .course_sec .bottom_box::after {
        width: 35vw;
        height: 26vw;
        bottom: -16vw;
        left: -8.6vw;
    }

    .course_sec .bottom_box .text_area .text {
        font-size: 3.9vw;
    }

    .faq_sec .que_box {
        padding: 3vw 3vw;
        gap: 4vw;
        align-items: center;
    }

    .faq_sec .que_box .text {
        font-size: 3.8vw;
        line-height: 2.1;
        padding-left: 0.4em;
        padding-left: .3em;
    }

    .faq_sec .que_box .icon {}

    .faq_sec .ans_box {
        padding: 0 0 4vw 4vw;
    }

    .faq_sec .ans_box .text {
        font-size: 2.9vw;
        color: #383a3b;
        line-height: 1.4;
    }

    .message_sec {
        padding: 31vw 0 0;
    }

    .message_sec .cont {
        flex-direction: column;
        gap: 4vw;
    }

    .message_sec .cont .text_box {
        margin: 0;
    }

    .message_sec .text_box .speech {
        min-width: 70.6vw;
        margin: 0 auto 4.1vw;
        font-size: 3.5vw;
        letter-spacing: 0.12em;
        min-block-size: 2.6em;
    }

    .message_sec .text_box .ttl {
        font-size: 7.5vw;
        line-height: 1.3;
    }

    .message_sec .img {
        width: 44vw;
        margin: 0 auto;
    }

    .message_sec .img img {}

    .footer {
        padding: 5vw 5vw 30vw;
    }

    .footer .footer_box .footer_list ul {
        flex-direction: column;
        gap: 1.9vw;
        align-items: center;
        margin-bottom: 10vw;
    }

    .footer .footer_box .footer_list ul .link {
        font-size: 4vw;
    }

    .footer .footer_box .copyright small {
        font-size: 3.1vw;
    }

    .voice_sec .voice_list .slick-track:before,
    .voice_sec .voice_list .slick-track:after {
        content: unset !important;
    }

    .voice_sec .voice_list .slick-slider .slick-track {
        display: flex;
    }

    .voice_sec .voice_list .slick-slider .slick-slide {
        height: auto !important;
    }

    .course_sec .course_list ul li {
        margin-left: -5vw;
        width: 92vw;
    }

    .course_sec .course_list ul li::after {
        width: 13vw;
        height: 16vw;
        top: 14vw;
        right: 4vw;
    }

    .course_sec .course_list li:nth-child(even)::after {
        width: 13vw;
        height: 17vw;
        top: 14vw;
        left: 4vw;
    }

    .modal__content {
        max-width: 90vw;
        margin: 20vw auto;
        padding: 6.5vw;
    }

    .modal #closeModal {
        width: 13vw;
        height: 13vw;
        right: -4vw;
        top: -5vw;
    }

    .modal__title {
        font-size: 5vw;
        margin-bottom: 4vw;
    }

    .flow__box {
        max-width: 73vw;
        padding: 2vw;
    }

    .flow__box-text {
        font-size: 3.8vw;
    }

    .flow__arrow {
        margin: 4vw 0;
    }

    .program_sec .program_list .text_box::before {
        content: unset;
    }

    .support_sec::after {
        top: -42vw;
        height: 40vw;
    }

    .top_fixed_area {
        position: fixed;
        bottom: 2vw;
        right: 10vw;
        padding: 3vw;
        width: 80vw;
        opacity: 0;
        transition: .3s;
    }

    .top_fixed_area::before {
        clip-path: polygon(100% 0, 0 50%, 100% 100%);
        left: 1px;
        transform: translateX(-100%);
    }

    .top_fixed_area::after {
        clip-path: polygon(0 0, 0% 100%, 100% 50%);
        right: 1px;
        transform: translateX(100%);
    }

    .top_fixed_area::before,
    .top_fixed_area::after {
        width: 5vw;
    }

    .top_fixed_area .top_fixed_area_head {
        font-size: 3.3vw;
    }

    .top_fixed_area .top_fixed_area_btn_flex {
        gap: 5vw;
    }

    .top_fixed_area .top_fixed_area_btn_flex .top_fixed_area_btn {
        font-size: 2.8vw;
    }

    .slick-dots li.slick-active button:before {
        display: none;
    }

    .slick-dots li button:before {
        display: none;
    }
}