@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&family=Shippori+Mincho:wght@500;600;700;800&display=swap');

@media (max-width: 1024px) {
}

@media (max-width: 599px) {
}

main {
    font-family: "Shippori Mincho", serif;
    font-weight: 500;
    font-style: normal;
}


/* ===============================================
   header
=============================================== */
.nav {
    color: #fff;
    background-color: #9e6048;
}

.nav_actions {
    border-color: #fff;
    background-color: #fff;
}

.nav_actions a {
    color: #fff;
    background-color: var(--color-black);
}

.nav_actions a::before {
    background-color: #ffc237;
}

.nav_actions a span::before {
    background-color: #fff100;
}

.nav_sns a {
    background-color: #9e6048;
}

.nav_sns a img {
    opacity: 0;
}

.nav_sns > li {
    background-color: #fff;
    border-radius: 50%;
}

.nav_sns > li:nth-child(1) a {
    -webkit-mask-image: url("../img/menu_icon_line.svg");
    mask-image: url("../img/menu_icon_line.svg");
    -webkit-mask-size: contain;
    mask-size: contain;
}

.nav_sns > li:nth-child(2) a {
    -webkit-mask-image: url("../img/menu_icon_x.svg");
    mask-image: url("../img/menu_icon_x.svg");
    -webkit-mask-size: contain;
    mask-size: contain;
}

.nav_sns > li:nth-child(3) a {
    -webkit-mask-image: url("../img/menu_icon_insta.svg");
    mask-image: url("../img/menu_icon_insta.svg");
    -webkit-mask-size: contain;
    mask-size: contain;
}

.nav_sns > li:nth-child(4) a {
    -webkit-mask-image: url("../img/menu_icon_youtube.svg");
    mask-image: url("../img/menu_icon_youtube.svg");
    -webkit-mask-size: contain;
    mask-size: contain;
}


/* ===============================================
   bg
=============================================== */
.bg_tile_1 {
    width: 100%;
    background: url("../img/ningen/bg_tile_1.jpg") no-repeat top center / 100% auto;
}

.bg_tile_2 {
    width: 100%;
    background: url("../img/ningen/bg_tile_2.jpg") repeat-y top center / 100% auto;
}

@media (max-width: 1920px) {
    .bg_tile_1,
    .bg_tile_2 {
        background-size: clamp(0px, 140.6vw, 1920px) auto;
    }
}

@media (max-width: 599px) {
    .bg_tile_1 {
        background: url("../img/ningen/bg_tile_1_sp.jpg") no-repeat top center / cover;
    }

    .bg_tile_2 {
        background: url("../img/ningen/bg_tile_2_sp.jpg") repeat-y top center / 100% auto;
    }
}


/* ===============================================
   button
=============================================== */
.button {
    width: clamp(0px, 28.6vw, 390px);
    aspect-ratio: 390 / 76;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 60px;
    color: #fff;
    border: 2px solid var(--color-black);
    background-color: var(--color-black);
    font-size: clamp(0px, 1.7vw, 20px);
    font-weight: 700;
    position: relative;
}

.button:hover {
    color: var(--color-black);
    background-color: #fff;
}

.button::before {
    content: "";
    width: 7.7%;
    aspect-ratio: 1 / 1;
    background: url("../img/ningen/link_arrow.svg") no-repeat center center / contain;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 7.7%;
    margin: auto;
}

@media (max-width: 599px) {
    .button {
        width: clamp(0px, 60dvw, 600px);
        aspect-ratio: 600 / 150;
        border-radius: 150px;
        border-width: clamp(0px, 0.3dvw, 3px);
        font-size: clamp(0px, 3.5dvw, 35px);
    }

    .button::before {
        right: 5%;
    }
}


/* ===============================================
   mv
=============================================== */
#mv {
    width: 100%;
    position: relative;
    z-index: 1;
}

.mv_img {
    width: 100vw;
    margin: 0 auto;
    overflow: hidden;
    display: flex;
    justify-content: center;
    position: relative;
    z-index: 1;
}

.mv_img img {
        width: 100vw;
}

@media (max-width: 1920px) {
    .mv_img {
        width: clamp(0px, 100vw, 1920px);
    }

    .mv_img img {
        width: 1920px;
        max-width: 140.6vw;
    }
}

@media (max-width: 599px) {
    .mv_img {
        width: 100dvw;
    }

    .mv_img img {
        width: 100%;
        max-width: 100%;
    }
}


/* ===============================================
   about
=============================================== */
#about {
    padding-top: clamp(0px, 1.8vw, 25px);
    padding-bottom: clamp(0px, 15.7vw, 215px);
    text-align: center;
    position: relative;
    z-index: 2;
}

#about .sec_title {
    width: clamp(0px, 19.4vw, 265px);
    margin: 0 auto clamp(0px, 5.9vw, 80px);
}

.about_em {
    font-size: clamp(0px, 2.6vw, 35px);
    letter-spacing: 0.1em;
    line-height: 1em;
    margin-bottom: 1.5em;
    padding-left: 0.5em;
}

.about_text {
    font-size: clamp(0px, 1.3vw, 18px);
    line-height: 2.4em;
    letter-spacing: 0.085em;
}

.about_bg {
    width: clamp(0px, 100vw, 1600px);
    margin: 0 auto;
    overflow: hidden;
    display: flex;
    justify-content: center;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: -1;
    pointer-events: none;
}

.about_bg img {
    width: 1600px;
    max-width: 117.1vw;
}

@media (max-width: 599px) {
    #about {
        padding-top: clamp(0px, 7.5dvw, 75px);
        padding-bottom: 0;
    }

    #about .sec_title {
        width: clamp(0px, 24.5dvw, 245px);
        margin: 0 auto clamp(0px, 9.5dvw, 95px);
    }

    .about_em {
        font-size: clamp(0px, 5dvw, 50px);
    }

    .about_text {
        font-size: clamp(0px, 3.5dvw, 35px);
        line-height: 1.7em;
        letter-spacing: 0.05em;
        white-space: nowrap;
        padding-bottom: clamp(0px, 2dvw, 20px);
    }

    .about_bg {
        width: 100vw;
        top: clamp(-60px, -6dvw, 0px);
        bottom: inherit;
    }

    .about_bg img {
        width: 100%;
        max-width: 100%;
    }

    .about_img_sp,
    .about_img_sp img {
        width: 100%;
    }
}


/* ===============================================
   point
=============================================== */
#point {
    width: 100%;
    padding: clamp(0px, 12.8vw, 175px) 0 clamp(0px, 11vw, 150px);
    display: flex;
    justify-content: center;
}

.point_lead {
    width: 100vw;
    height: clamp(0px, 150.8vw, 2060px);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.point_lead img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.point_bg.bg_1 {
    width: clamp(0px, 100vw, 1366px);
    position: absolute;
    top: clamp(-75px, -5.5vw, 0px);
    left: 0;
    right: 0;
    margin: auto;
    z-index: 2;
}

.point_main {
    width: clamp(0px, 75.4vw, 1030px);
    padding-left: clamp(0px, 10.3vw, 140px);
    display: flex;
    flex-direction: column;
    gap: clamp(0px, 8.8vw, 120px);
    position: relative;
    z-index: 3;
}

.point_main .img_area {
    display: flex;
    margin-bottom: clamp(0px, 3.3vw, 45px);
}

.point_main .img_area .nb {
    width: clamp(0px, 19.1vw, 260px);
}

.point_main .img_area .img {
    width: clamp(0px, 46.1vw, 630px);
}

.point_main .text_1 {
    font-size: clamp(0px, 2.2vw, 30px);
    line-height: 1;
    margin-bottom: 1em;
}

.point_main .text_2 {
    font-size: clamp(0px, 1.2vw, 17px);
    line-height: 1.7em;
    letter-spacing: 0.1em;
}

@media screen and (min-width: 600px) and (max-width: 1450px) {
    .point_lead {
        height: 142vw;
    }
}
@media (max-width: 599px) {
    #point {
        padding: 0 0 clamp(0px, 5dvw, 50px);
        flex-direction: column;
        align-items: center;
    }

    .point_lead {
        width: 100dvw;
        height: 32dvw;
        position: relative;
        margin-bottom: clamp(0px, 4.5dvw, 45px);
    }

    .point_bg.bg_1 {
        width: 100vw;
        position: absolute;
        top: clamp(-60px, -6dvw, 0px);
    }

    .point_main {
        width: 84dvw;
        padding-left: 0;
        gap: clamp(0px, 19dvw, 190px);
    }

    .point_main .img_area {
        margin-bottom: clamp(0px, 7dvw, 70px);
        position: relative;
    }

    .point_main .img_area .nb {
        width: clamp(0px, 20.5dvw, 205px);
        position: absolute;
        top: clamp(-50px, -5dvw, 0px);
        left: clamp(-40px, -4dvw, 0px);
    }

    .point_main .img_area .img {
        width: 100%;
    }

    .point_main .text_1 {
        font-size: clamp(0px, 4dvw, 40px);
        line-height: 1.7em;
        letter-spacing: 0.1em;
        text-align: center;
        margin-bottom: 1em;
    }

    .point_main .text_2 {
        font-size: clamp(0px, 3.5dvw, 35px);
    }
}


/* ===============================================
   course
=============================================== */
#course {
    width: 100%;
    padding: clamp(0px, 43.9vw, 600px) 0 0;
    background: url("../img/ningen/course_bg.png") no-repeat top center / clamp(0px, 161.1vw, 2200px) auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0px, 3.7vw, 50px) 0;
    position: relative;
}

.course_sec {
    width: 100%;
    height: clamp(0px, 88.6vw, 1210px);
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
}

.course_sec.course_1 {
    background: url("../img/ningen/course_bg_blue.png") repeat-x center;
    background-size: clamp(0px, 139.8vw, 1910px) auto;
    z-index: 1;
}

.course_sec.course_2 {
    background: url("../img/ningen/course_bg_pink.png") repeat-x center;
    background-size: clamp(0px, 139.8vw, 1910px) auto;
    z-index: 2;
}

.deco_clip {
    width: clamp(0px, 100vw, 1366px);
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
}
.course_1 .deco_clip { top: clamp(-100px, -7.3vw, 0px); }
.course_2 .deco_clip { top: clamp(-90px, -6.6vw, 0px); }

.about_course {
    width: clamp(0px, 91.5vw, 1250px);
    position: relative;
}

.about_course .text_1 {
    font-size: clamp(0px, 1.95vw, 27px);
    line-height: 1.5em;
    margin-left: clamp(0px, 5.1vw, 70px);
}

.course_img {
    width: clamp(0px, 35.9vw, 490px);
    position: absolute;
    top: clamp(0px, 12.1vw, 165px);
    left: clamp(0px, 53.1vw, 725px);
    z-index: 3;
}

.course_img .img {
    width: clamp(0px, 28.2vw, 385px);
    display: block;
    position: absolute;
    top: clamp(0px, 2.2vw, 30px);
    left: 0;
    right: 0;
    margin: auto;
}

.pickup_course {
    width: clamp(0px, 91.5vw, 1250px);
    position: relative;
}

.pickup_course .pickup_cont {
    width: clamp(0px, 81.9vw, 1120px);
    position: absolute;
    top: clamp(0px, 8.1vw, 110px);
    left: 0;
    right: 0;
    margin: auto;
    display: flex;
    justify-content: space-between;
}

.pickup_course .pickup_cont .block {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
}

.course_1 .pickup_course .pickup_cont .block_1 {
    width: clamp(0px, 34.5vw, 470px);
}

.course_1 .pickup_course .pickup_cont .block_2 {
    width: clamp(0px, 40.2vw, 550px);
}

.course_1 .pickup_course .pickup_cont .img {
    width: clamp(0px, 15vw, 205px);
    aspect-ratio: 205 / 190;
}

.pickup_course .pickup_cont .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pickup_course .pickup_cont .text_1 {
    width: 100%;
    flex: 1;
    font-size: clamp(0px, 2.2vw, 30px);
    font-weight: 700;
    line-height: 1;
}

.pickup_course .pickup_cont .text_2 {
    width: 100%;
    font-size: clamp(0px, 1.2vw, 17px);
    line-height: 1.7em;
    margin-top: 1em;
}

.course_2 .pickup_course .pickup_cont .block_1 {
    width: clamp(0px, 40.2vw, 550px);
    display: grid;
    grid-template-columns: 60% clamp(0px, 15vw, 205px);
    grid-template-rows: 60% 40%;
    grid-column-gap: 2.7%;
    grid-row-gap: 0px;
}
.course_2 .pickup_course .pickup_cont .block_1 .text_1 { grid-area: 1 / 1 / 2 / 2; }
.course_2 .pickup_course .pickup_cont .block_1 .img { grid-area: 1 / 2 / 3 / 3; }
.course_2 .pickup_course .pickup_cont .block_1 .text_2 { grid-area: 2 / 1 / 3 / 2; }

.course_2 .pickup_course .pickup_cont .block_2 {
    width: clamp(0px, 34.5vw, 470px);
}

.course_2 .pickup_course .pickup_cont .block_1 .img {
    width: clamp(0px, 15vw, 205px);
    aspect-ratio: 205 / 265;
}

.course_2 .pickup_course .pickup_cont .block_2 .img {
    width: clamp(0px, 15vw, 205px);
    aspect-ratio: 205 / 140;
}

.course_2 .pickup_course .pickup_cont .block_1 .text_1 {
    white-space: nowrap;
}

.course_2 .pickup_course .pickup_cont .block_1 .text_2 {
    margin: 0;
}

@media (max-width: 599px) {
    #course {
        padding: clamp(0px, 51dvw, 510px) 0 0;
        background: url("../img/ningen/course_bg_sp.png") no-repeat top center / 100% auto;
        gap: clamp(0px, 13dvw, 130px) 0;
    }

    .course_sec {
        height: clamp(0px, 256dvw, 2560px);
    }

    .course_sec.course_1 {
        background: url("../img/ningen/course_bg_blue_sp.png") repeat-x center / 100% auto;
    }

    .course_sec.course_2 {
        background: url("../img/ningen/course_bg_pink_sp.png") repeat-x center / 100% auto;
    }

    .deco_clip {
        width: 100dvw;
    }
    .course_1 .deco_clip { top: clamp(-85px, -8.5vw, 0px); }
    .course_2 .deco_clip { top: clamp(-80px, -8dvw, 0px); }

    .about_course {
        width: 100%;
    }

    .about_course .text_1 {
        width: 84%;
        font-size: clamp(0px, 3.5dvw, 35px);
        line-height: 1.7em;
        margin: 0 auto clamp(0px, 2dvw, 20px);
    }

    .course_img {
        width: 100dvw;
        top: 0;
        left: 0;
    }

    .course_img .img {
        width: clamp(0px, 38dvw, 380px);
        top: clamp(0px, 25dvw, 250px);
        left: clamp(0px, 50.2dvw, 502px);
        right: inherit;
    }

    .pickup_course {
        width: 100%;
    }

    .pickup_course .pickup_cont {
        width: clamp(0px, 76dvw, 760px);
        top: clamp(0px, 12dvw, 120px);
        flex-direction: column;
        gap: clamp(0px, 15dvw, 150px);
    }

    .course_1 .pickup_course .pickup_cont .block_1,
    .course_1 .pickup_course .pickup_cont .block_2 {
        width: 100%;
    }

    .course_1 .pickup_course .pickup_cont .img {
        width: clamp(0px, 39dvw, 390px);
        aspect-ratio: 390 / 360;
    }

    .pickup_course .pickup_cont .text_1 {
        font-size: clamp(0px, 4dvw, 40px);
        font-weight: 500;
        letter-spacing: 0;
    }

    .pickup_course .pickup_cont .text_2 {
        font-size: clamp(0px, 3.5dvw, 35px);
        margin-top: 0.8em;
    }

    .course_2 .pickup_course .pickup_cont {
        gap: clamp(0px, 14dvw, 140px);
    }

    .course_2 .pickup_course .pickup_cont .block_1 {
        width: 100%;
        display: flex;
    }

    .course_2 .pickup_course .pickup_cont .block_2 {
        width: 100%;
    }

    .course_2 .pickup_course .pickup_cont .block_1 .img {
        width: clamp(0px, 28.5dvw, 285px);
        aspect-ratio: 285 / 370;
    }

    .course_2 .pickup_course .pickup_cont .block_2 .img {
        width: clamp(0px, 42dvw, 420px);
        aspect-ratio: 420 / 285;
    }

    .course_2 .pickup_course .pickup_cont .block_1 .text_1 {
        width: 100%;
        flex: 1;
        white-space: normal;
    }

    .course_2 .pickup_course .pickup_cont .block_1 .text_2 {
        margin-top: 0.8em;
    }

    .course_2 .pickup_course .pickup_cont .block_2 .text_2 {
        margin-top: 2em;
    }
}


/* ===============================================
   career
=============================================== */
#career {
    width: 100%;
    padding: clamp(0px, 16.9vw, 230px) 0 clamp(0px, 10.3vw, 140px);
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 1;
}

#career .sec_title {
    width: clamp(0px, 22vw, 300px);
    margin-bottom: clamp(0px, 4.7vw, 65px);
}

#career .sec_sub_title {
    font-size: clamp(0px, 2.2vw, 30px);
    line-height: 1;
    letter-spacing: 0.1em;
    text-align: center;
    margin-bottom: clamp(0px, 6.6vw, 90px);
}

.career_list {
    display: flex;
    justify-content: center;
    margin-bottom: clamp(0px, 17.6vw, 240px);
}

.career_list li {
    padding: 0 clamp(0px, 5.9vw, 80px);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    position: relative;
    z-index: 1;
}

.career_list li::after {
    content: "";
    width: clamp(0px, 27.1vw, 370px);
    aspect-ratio: 370 / 840;
    background-color: rgba(255,250,188,0.5);
    position: absolute;
    right: clamp(-10px, -0.7vw, 0px);
    bottom: clamp(-70px, -5.1vw, 0px);
    z-index: -1;
}

.career_list li .img_area {
    display: flex;
    gap: clamp(0px, 2.2vw, 30px);
    margin-bottom: clamp(0px, 5.1vw, 70px);
}

.career_list li .img_area img {
    width: clamp(0px, 29.3vw, 400px);
}

.career_list li .img_area .caption {
    display: flex;
    align-items: flex-end;
    gap: clamp(0px, 1.1vw, 15px);
}

.career_list li .img_area .caption p {
    line-height: 1;
    writing-mode: vertical-rl;
    text-orientation: upright;
}

.career_list li .img_area .caption .text_1 {
    font-size: clamp(0px, 1.5vw, 20px);
}

.career_list li .img_area .caption .text_1 span {
    font-size: 0.8em;
}

.career_list li .img_area .caption .text_2 {
    font-size: clamp(0px, 1.1vw, 15px);
}

.career_list li .img_area .caption .text_2 span {
    text-orientation: initial;
}

.career_list li .text_area p {
    width: clamp(0px, 29.3vw, 400px);
}

.career_list li .text_area .text_1 {
    font-size: clamp(0px, 1.5vw, 20px);
    letter-spacing: 0.1em;
    line-height: 1.6em;
    margin-bottom: 1em;
}

.career_list li .text_area .text_2 {
    font-size: clamp(0px, 1.2vw, 17px);
    letter-spacing: 0.05em;
    line-height: 1.8em;
}

.career_bg {
    width: clamp(0px, 100vw, 1920px);
    display: flex;
    justify-content: center;
    overflow: hidden;
    position: absolute;
    z-index: -1;
}

.career_bg.bg_1 {
    top: 0;
    right: 0;
}

.career_bg.bg_2 {
    bottom: 0;
    left: 0;
}

.career_bg img {
    width: 1920px;
    max-width: 140.6vw;
}

@media (max-width: 599px) {
     #career {
        padding: clamp(0px, 15dvw, 150px) 0 clamp(0px, 10dvw, 100px);
    }

    #career .sec_title {
        width: clamp(0px, 28dvw, 280px);
        margin-bottom: clamp(0px, 4.5dvw, 45px);
    }

    #career .sec_sub_title {
        font-size: clamp(0px, 3.5dvw, 35px);
        margin-bottom: clamp(0px, 5.5dvw, 55px);
    }

    .career_list {
        margin-bottom: clamp(0px, 8dvw, 80px);
        flex-direction: column;
        align-items: center;
        gap: clamp(0px, 18dvw, 180px);
    }

    .career_list li {
        width: 76dvw;
        padding: 0 0 clamp(0px, 10dvw, 100px);
    }

    .career_list li::after {
        width: clamp(0px, 37dvw, 370px);
        aspect-ratio: 370 / 1650;
        right: clamp(-48px, -4.8dvw, 0px);
        bottom: 0;
    }

    .career_list li .img_area {
        gap: clamp(0px, 4.5dvw, 45px);
        margin-bottom: clamp(0px, 10.5dvw, 105px);
    }

    .career_list li .img_area img {
        width: clamp(0px, 55.5dvw, 555px);
    }

    .career_list li .img_area .caption {
        gap: clamp(0px, 2dvw, 20px);
    }

    .career_list li .img_area .caption .text_1 {
        font-size: clamp(0px, 3.4dvw, 34px);
    }

    .career_list li .img_area .caption .text_2 {
        font-size: clamp(0px, 2.6dvw, 26px);
    }

    .career_list li .text_area p {
        width: 100%;
    }

    .career_list li .text_area .text_1 {
        font-size: clamp(0px, 3.5dvw, 35px);
        letter-spacing: 0.15em;
        line-height: 1.7em;
        margin-bottom: 1.5em;
    }

    .career_list li .text_area .text_2 {
        font-size: clamp(0px, 3.5dvw, 35px);
        letter-spacing: 0.15em;
        line-height: 1.7em;
    }

    .career_bg {
        width: 100dvw;
    }

    .career_bg img {
        width: 100dvw;
        max-width: 100dvw;
    }
}


/* ===============================================
   license
=============================================== */
#license {
    width: 100%;
    background-color: #fef5f3;
    padding: 0 0 clamp(0px, 12.4vw, 170px);
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 2;
}

#license .lead {
    width: clamp(0px, 140.6vw, 1920px);
    aspect-ratio: 1920 / 550;
    background:url("../img/ningen/license_bg.svg") no-repeat top center / cover;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

#license .lead .text_1 {
    font-size: clamp(0px, 2.5vw, 33px);
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1;
    margin-bottom: 1em;
}

#license .lead .text_2 {
    width: clamp(0px, 59.7vw, 815px);
    aspect-ratio: 815 / 80;
    font-size: clamp(0px, 2.5vw, 33px);
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1;
    background-color: #c8161d;
    color: #fff;
    border-radius: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: clamp(0px, 3.7vw, 50px);
}

#license .lead .text_3 {
    font-size: clamp(0px, 1.7vw, 23px);
    line-height: 1.7em;
}

.license_main {
    width: clamp(0px, 77.6vw, 1060px);
    padding: clamp(0px, 6.6vw, 90px) 0 clamp(0px, 12.5vw, 170px);
}

.license_main .block {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.license_main .block + .block {
    margin-top: clamp(0px, 4.4vw, 60px);
    padding-top: clamp(0px, 4.4vw, 60px);
    border-top: 1px solid var(--color-black);
}

.license_main .text_1 {
    font-size: clamp(0px, 1.8vw, 25px);
    letter-spacing: 0.1em;
    line-height: 1;
    color: #c8161d;
    margin-bottom: 2em;
}

.license_main .text_2 {
    font-size: clamp(0px, 2.2vw, 30px);
    letter-spacing: 0.1em;
    line-height: 1;
    margin-bottom: 1.2em;
}

.license_main .text_3 {
    font-size: clamp(0px, 1.8vw, 25px);
    letter-spacing: 0.1em;
    line-height: 1.6em;
}

.license_bg {
    width: clamp(0px, 100vw, 1366px);
    display: flex;
    justify-content: center;
    overflow: hidden;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    z-index: -1;
}

.license_bg.bg_1 {
    bottom: 0;
}

.license_bg.bg_2 {
    bottom: clamp(-15px, -1.1vw, 0px);
}

.license_bg img {
    width: 1366px;
    max-width: 100vw;
}

@media (max-width: 599px) {
    #license {
        padding: 0 0 clamp(0px, 25dvw, 250px);
    }

    #license .lead {
        width: 100dvw;
        aspect-ratio: 1000 / 470;
        background-image:url("../img/ningen/license_bg_sp.svg");
    }

    #license .lead .text_1 {
        font-size: clamp(0px, 4dvw, 40px);
        letter-spacing: 0.1em;
    }

    #license .lead .text_2 {
        width: 93dvw;
        aspect-ratio: 930 / 65;
        font-size: clamp(0px, 4dvw, 40px);
        margin-bottom: clamp(0px, 3.7vw, 37px);
    }

    #license .lead .text_3 {
        font-size: clamp(0px, 3.5dvw, 35px);
    }

    .license_main {
        width: 89dvw;
        padding: 7.5dvw 0 13.5dvw;
    }

    .license_main .block + .block {
        margin-top: clamp(0px, 10dvw, 100px);
        padding-top: clamp(0px, 7.5dvw, 75px);
    }

    .license_main .text_1 {
        font-size: clamp(0px, 3.5dvw, 35px);
        letter-spacing: 0.05em;
        white-space: nowrap;
    }

    .license_main .text_2 {
        font-size: clamp(0px, 4dvw, 40px);
    }

    .license_main .text_3 {
        font-size: clamp(0px, 3.5dvw, 35px);
    }

    .license_bg {
        width: 100dvw;
    }

    .license_bg.bg_2 {
        bottom: clamp(-70px, -7dvw, 0px);
    }

    .license_bg img {
        width: 100dvw;
        max-width: 100dvw;
    }
}


/* ===============================================
   voice
=============================================== */
#voice {
    width: clamp(0px, 90vw, 1230px);
    padding: clamp(0px, 9.5vw, 130px) 0 0;
    margin: 0 auto clamp(0px, 11vw, 150px);
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 1;
}

#voice .sec_title_area {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: clamp(0px, 2.9vw, 40px);
    margin-bottom: clamp(0px, 9.5vw, 130px);
}

#voice  .sec_title {
    font-size: clamp(0px, 9.9vw, 135px);
    font-weight: 700;
    line-height: 0.7em;
    letter-spacing: 0.1em;
}

#voice  .sec_title span {
    font-size: 0.7em;
    padding-bottom: 0.1em;
}

#voice .sec_title_s {
    font-size: clamp(0px, 2.9vw, 40px);
    font-weight: 700;
    line-height: 1;
    padding: 0 clamp(0px, 6.2vw, 85px);
    position: relative;
}

#voice .sec_title_s::before,
#voice .sec_title_s::after {
    content: "";
    width: clamp(0px, 4.4vw, 60px);
    height: 1px;
    background-color: var(--color-black);
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}

#voice .sec_title_s::before {
    left: 0;
}

#voice .sec_title_s::after {
    right: 0;
}

.voice_qa {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: clamp(0px, 5.1vw, 70px) 0;
}

.qa {
    width: 100%;
    background-color: #fff;
    border: clamp(0px, 0.4vw, 5px) solid #f8b500;
    border-radius: clamp(0px, 1.5vw, 20px);
    overflow: hidden;
    position: relative;
}

.area_q {
    width: 100%;
    aspect-ratio: 1230 / 130;
    padding: 0 clamp(0px, 9.5vw, 130px) 0 clamp(0px, 10.2vw, 140px);
    position: relative;
    display: flex;
    align-items: center;
}

.area_q .icon {
    width: clamp(0px, 5.5vw, 75px);
    height: clamp(0px, 5.5vw, 75px);
    background: var(--color-black);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    bottom: 0;
    left: clamp(0px, 2.2vw, 30px);
    margin: auto;
    font-size: clamp(0px, 2.9vw, 40px);
    line-height: 1;
    color: #f8b500;
    padding-bottom: 0.1em;
}

.area_q .text p {
    font-size: clamp(0px, 1.9vw, 26px);
    line-height: 1.7em;
}

.area_a {
    padding-bottom: clamp(0px, 1.1vw, 15px);
}

.area_a .block_a {
    padding: clamp(0px, 4.4vw, 60px) clamp(0px, 5.1vw, 70px) clamp(0px, 4.4vw, 60px) clamp(0px, 10.2vw, 140px);
    position: relative;
}

.area_a .block_a + .block_a {
    padding-top: clamp(0px, 4.9vw, 67px);
    background: url("../img/ningen/voice_border.svg") no-repeat top center / 100% auto;
}

.area_a .block_a .text {
    width: 100%;
    position: relative;
}

.area_a .block_a .text p {
    font-size: clamp(0px, 1.8vw, 24px);
    line-height: 2em;
}

.area_a .block_a .text p.name {
    text-align: right;
    margin-top: 1em;
}

@media (max-width: 599px) {
    #voice {
        width: 100%;
        padding: clamp(0px, 11.5dvw, 115px) 0 0;
        margin: 0 auto clamp(0px, 13.5dvw, 135px);
    }

    #voice .sec_title_area {
        gap: clamp(0px, 1dvw, 10px);
        margin-bottom: clamp(0px, 10dvw, 100px);
    }

    #voice  .sec_title {
        font-size: clamp(0px, 13.5dvw, 135px);
    }

    #voice .sec_title_s {
        font-size: clamp(0px, 3.6dvw, 36px);
        padding: 0 clamp(0px, 7.5dvw, 75px);
    }

    #voice .sec_title_s::before,
    #voice .sec_title_s::after {
        width: clamp(0px, 5.5dvw, 55px);
    }

    .voice_qa {
        width: clamp(0px, 82dvw, 820px);
        gap: clamp(0px, 9dvw, 90px) 0;
    }

    .qa {
        border-width: clamp(2px, 0.5vw, 5px);
        border-radius: clamp(0px, 2dvw, 20px);
    }

    .area_q {
        aspect-ratio: 820 / 540;
        padding: clamp(0px, 7dvw, 70px) 0 clamp(0px, 4dvw, 40px);
        flex-direction: column;
        align-items: center;
    }

    .area_q .icon {
        width: clamp(0px, 7.5dvw, 75px);
        height: clamp(0px, 7.5dvw, 75px);
        position: relative;
        left: 0;
        margin: 0;
        font-size: clamp(0px, 4dvw, 40px);
    }

    .area_q .text {
        height: 100%;
        flex: 1;
        display: flex;
        align-items: center;
    }

    .area_q .text p {
        font-size: clamp(0px, 4dvw, 40px);
        line-height: 1.75em;
        font-weight: 700;
        text-align: center;
    }

    .area_a {
        padding-bottom: 0;
    }

    .area_a .block_a {
        padding: clamp(0px, 6.5dvw, 65px) clamp(0px, 6dvw, 60px) clamp(0px, 7dvw, 70px);
    }

    .area_a .block_a + .block_a {
        padding-top: clamp(0px, 8dvw, 80px);
    }

    .area_a .block_a .text p {
        font-size: clamp(0px, 3.5dvw, 35px);
        line-height: 1.7em;
    }
}


/*----------------------------
accordion
----------------------------*/
.acc_button {
    cursor: pointer;
    position: relative;
}

.acc_cont {
    display: none;
    border-top: clamp(0px, 0.4vw, 5px) solid #f8b500;
}

.acc_icon {
    position: absolute;
    width: clamp(0px, 9.5vw, 130px);
    aspect-ratio: 1 / 1;
    top: 0;
    right: 0;
}

.acc_icon::before{
    position: absolute;
    content: "";
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: url("../img/ningen/voice_arrow.svg") no-repeat center center / contain;
    transform: rotate(0deg);
    transition: all .3s ease-in-out;
}

.acc_button.open .acc_icon::before {
    transform: rotate(180deg);
}

@media (max-width: 599px) {
    .acc_cont {
        border-top: clamp(2px, 0.5dvw, 5px) solid #f8b500;
    }

    .acc_icon {
        width: clamp(0px, 13dvw, 130px);
        right: clamp(0px, 1.5dvw, 15px);
    }
}


/* ===============================================
   link
=============================================== */
#link {
    width: clamp(0px, 67.3vw, 920px);
    padding-bottom: clamp(0px, 2.2vw, 30px);
    margin: 0 auto;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

#link p {
    font-size: clamp(0px, 2.9vw, 35px);
    font-weight: 700;
    letter-spacing: 0.15em;
    margin-right: 1em;
}

@media (max-width: 599px) {
    #link {
        padding-bottom: 0;
        flex-direction: column;
        align-items: center;
    }

    #link p {
        font-size: clamp(0px, 4dvw, 40px);
        margin-right: 0;
        margin-bottom: 0.8em;
    }
}


/* ===============================================
   Instagram
=============================================== */
#insta {
    width: 100%;
    height: clamp(0px, 18.3vw, 220px);
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0 clamp(0px, 2.5vw, 30px);
}

#insta a {
    display: flex;
    align-items: center;
    gap: 0 clamp(0px, 2.5vw, 30px);
}

#insta .text_1 {
    font-size: clamp(0px, 2.3vw, 28px);
    font-weight: var(--font-w-b);
    white-space: nowrap;
}

#insta a img {
    width: clamp(0px, 5.8vw, 70px);
}

#insta .text_2 {
    font-size: clamp(0px, 1.7vw, 20px);
    line-height: 1.6em;
    font-weight: var(--font-w-m);
    white-space: nowrap;
}

@media (max-width: 599px) {
    #insta {
        height: clamp(0px, 29dvw, 290px);
    }

    #insta a {
        gap: 0 clamp(0px, 5dvw, 50px);
    }

    #insta .text_1 {
        font-size: clamp(0px, 3.6dvw, 36px);
    }

    #insta a img {
        width: clamp(0px, 9dvw, 90px);
    }

    #insta .text_2 {
        font-size: clamp(0px, 2.6dvw, 26px);
    }
}
