.logo_panel .logo {
    width: 70px;
}

.sect_fv h1 {
    font-weight: 700;
    font-size: 72px;
    line-height: 1.3;
    text-align: center;
    color: #003F73;
    margin-top: 46px;
}

.sect_fv_text02 {
    font-size: 64px;
    color: #000;
}

.sect_fv_text03 {
    color: #000;
}

.sect_fv_layout01 {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    flex-wrap: nowrap;
    padding: 0 20px;
    margin-top: 40px;
}

.sect_fv_box01 {
    background-color: #fff;
    padding: 28px 20px;
    margin: 9px;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    /* width: 500px; */
    height: auto;
}

.sect_fv_box01:first-child {
    margin-left: 0;
}

.sect_fv_box01:last-child {
    margin-right: 0;
}

.sect_fv_box01 .detail {
    margin-left: 16px;
}

.sect_fv_box01:nth-child(1) .detail,
.sect_fv_box01:nth-child(3) .detail {
    margin-top: -14px;
}

.sect_fv_text04 {
    font-size: 26px;
    font-weight: 900;
    color: #003F73;
    letter-spacing: -0.05em;
}

.sect_fv_text05 {
    font-size: 44px;
    color: #2888CC;
}

.sect_fv_text06 {
    margin-top: 6px;
    font-size: 13px;
    letter-spacing: -0.05em;
}

.sect_fv_text07 {
    font-size: 26px;
    color: #2888CC;
    letter-spacing: -0.01em;
}

.sect_fv_text08 {
    font-size: 22px;
    font-weight: 900;
    color: #003F73;
}

.sect_fv_layout02 {
    width: fit-content;
    display: flex;
    align-items: center;
    margin: 14px auto;
    position: relative;
    font-size: 26px;
    font-weight: 700;
}

.sect_fv_layout02::before {
    content: '';
    width: 80px;
    height: 1px;
    background-color: #000;
    margin-right: 16px;
}

.sect_fv_layout02::after {
    content: '';
    width: 80px;
    height: 1px;
    background-color: #000;
    margin-left: 16px;
}

.sect_fv_text09 {
    font-size: 52px;
    font-weight: 900;
    color: #2888CC;
    margin-top: -19px;
}

.button_layout01 {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    width: fit-content;
    margin-top: 28px;
}

.button_link01,
.button_link02 {
    width: 340px;
    max-width: 100%;
    height: 86px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #003F73;
    border-radius: 44px;
    font-weight: 700;
    font-size: 26px;
    color: #fff;
    text-align: center;
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.25);
    -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.25);
    margin: 0 16px;
}

.button_link01 .icon,
.button_link02 .icon {
    margin-left: 16px;
}

.button_link02 {
    background-color: #2888CC;
}

.button_link01:first-child,
.button_link02:first-child {
    margin-left: 0;
}

.button_link01:last-child,
.button_link02:last-child {
    margin-right: 0;
}

.button_link01:hover,
.button_link02:hover {
    opacity: 1;
    transform: translateY(-5px);
    transition: transform 250ms cubic-bezier(.3, .7, .4, 1.5);
}

.sect_fv_layout03 {
    position: relative;
    padding-bottom: 53px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
}

.sect_fv_box02 {
    position: absolute;
    width: 200px;
    height: 200px;
    background-color: #C8E8FF;
    border-radius: 100px;
    bottom: 25px;
    right: 65px;
    font-size: 18px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.sect_fv_box02_sp {
    display: none;
}

.sect_fv_person {
    position: absolute;
    bottom: 0;
    right: -248px;
}

@media screen and (max-width: 1600px) {
    .sect_fv_layout01 {
        padding: 0 1.25vw;
        margin-top: 2.5vw;
    }

    .sect_fv_box01 {
        padding: 2.3vw 1.5vw;
        margin: 0.56vw;
        height: auto;
    }

    .sect_fv_box01 .thumb {
        width: 6.5vw;
    }

    .sect_fv_box01 .detail {
        margin-left: 1.2vw;
    }

    .sect_fv_box01:nth-child(1) .detail,
    .sect_fv_box01:nth-child(3) .detail {
        margin-top: -0.9vw;
    }

    .sect_fv_text04 {
        font-size: 1.85vw;
    }

    .sect_fv_text05 {
        font-size: 3.1vw;
    }

    .sect_fv_text06 {
        margin-top: 0.4vw;
        font-size: 0.9vw;
    }

    .sect_fv_text07 {
        font-size: 1.85vw;
    }

    .sect_fv_text08 {
        font-size: 1.5vw;
    }

    .sect_fv_layout02 {
        margin: 0.9vw auto;
        font-size: 1.65vw;
    }

    .sect_fv_text09 {
        font-size: 3.3vw;
        margin-top: -1.18vw;
    }

    .sect_fv_layout02::before {
        width: 5vw;
        margin-right: 0.85vw;
    }

    .sect_fv_layout02::after {
        width: 5vw;
        margin-left: 0.85vw;
    }

    .button_layout01 {
        margin-top: 1.75vw;
    }

    .button_link01,
    .button_link02 {
        width: clamp(175px, 21vw, 336px);
        height: clamp(52px, 5.4vw, 86px);
        border-radius: 3.2vw;
        font-size: clamp(14px, 1.65vw, 26px);
        margin: 0 0.8vw;
    }

    .sect_fv_box02 {
        width: 13.2vw;
        height: 13.2vw;
        border-radius: 6.6vw;
        bottom: 3.5vw;
        right: 4.06vw;
        font-size: 1.21vw;
    }

    .sect_fv_person {
        width: 20vw;
        right: -5vw;
        bottom: -13vw;
    }

    .sect_fv h1 {
        font-size: 4.5vw;
    }

    .sect_fv_text02 {
        font-size: 4vw;
    }
}

@media screen and (max-width: 768px) {
    .logo_panel .u-inner {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .sect_fv h1 {
        font-size: 6.13vw;
        padding-top: 3vw;
    }

    .sect_fv_text02 {
        font-size: 5.46vw;
    }

    .sect_fv_layout01 {
        margin-top: 5.2vw;
        flex-direction: column;
        margin-right: auto;
        margin-left: 0;
    }

    .sect_fv_layout03 {
        width: 92vw;
    }

    .sect_fv_box01 {
        width: 70.26vw;
        height: auto;
        padding: 2.7vw 2vw;
        margin: 0 0 2.66vw 0;
        position: relative;
        z-index: 10;
    }

    .sect_fv_box01 .thumb {
        width: 15.33vw;
    }

    .sect_fv_box01 .detail {
        margin-left: 2vw;
    }

    .sect_fv_text04 {
        font-size: 4.4vw;
    }

    .sect_fv_text05 {
        font-size: 7.4vw;
    }

    .sect_fv_text06 {
        margin-top: 0;
        font-size: 2.93vw;
    }

    .sect_fv_text07 {
        font-size: 5.06vw;
    }

    .sect_fv_text08 {
        font-size: 4vw;
    }

    .sect_fv_box02 {
        display: none;
    }

    .sect_fv_box02_sp {
        display: block;
        position: absolute;
        top: 12vw;
        right: -23vw;
        width: 50.9vw;
        z-index: 1;
    }

    .sect_fv_person {
        width: 39vw;
        bottom: 30vw;
        right: -49px;
        z-index: 11;
    }

    .sect_fv_layout02 {
        margin: 5.86vw auto 0 auto;
        font-size: 4.26vw;
    }

    .sect_fv_layout02::before,
    .sect_fv_layout02::after {
        display: none;
    }

    .sect_fv_layout04 {
        width: 106vw;
        margin-left: -3vw;
        margin-right: -3vw;
        position: relative;
        z-index: 12;
        padding-bottom: 2.9vw;
        background: #EDF6FF;
        background: linear-gradient(180deg, rgba(237, 246, 255, 0) 0%, rgba(237, 246, 255, 1) 10%, rgba(237, 246, 255, 1) 100%);
    }

    .sect_fv_text09 {
        font-size: 8vw;
    }

    .button_layout01 {
        margin-top: 2.13vw;
    }

    .button_link01,
    .button_link02 {
        width: 44.66vw;
        height: 14.4vw;
        border-radius: 8vw;
        font-size: 4.26vw;
        margin: 0 2.1vw;
    }

    .button_link01 .icon,
    .button_link02 .icon {
        margin-left: 2.13vw;
        width: 1.46vw;
    }

}

@media screen and (min-width: 769px) {
    .sect_fv {
        overflow-x: clip;
    }

    .sect_fv_layout03 {
        width: min(1680px, calc(100vw - 40px));
        padding: 0 60px 25px 60px;
        box-sizing: border-box;
        overflow: visible;
    }

    .sect_fv h1 {
        font-size: clamp(28px, 3.9vw, 62px);
        margin-top: 80px;
    }

    .sect_fv_text02 {
        font-size: clamp(24px, 3.4vw, 56px);
    }

    .sect_fv_layout01 {
        transform: none;
    }

    /* Bottom row: layout04 を真ん中センタリング、right_group を右端に絶対配置 */
    .sect_fv_bottom_row {
        position: relative;
        width: 100%;
        margin-top: 6px;
    }

    .sect_fv_layout04 {
        width: 100%;
        transform: none;
        margin-top: 0;
        text-align: center;
    }

    /* 水色の丸 + 男性画像を横並び、右端・下端から固定px */
    .sect_fv_right_group {
        position: absolute;
        right: -110px;
        bottom: -30px;
        display: flex;
        flex-direction: row;
        align-items: flex-end;
    }

    /* 水色の丸: 絶対配置を解除・左上にずらす・線形スケール */
    .sect_fv_box02 {
        position: relative;
        right: auto;
        bottom: auto;
        flex-shrink: 0;
        margin-left: -11vw;
        margin-bottom: 1vw;
        width: clamp(72px, 13.2vw, 185px);
        height: clamp(72px, 13.2vw, 185px);
        border-radius: clamp(36px, 6.6vw, 92px);
        font-size: clamp(7px, 1.21vw, 17px);
    }

    /* 男性画像: 線形スケール */
    .sect_fv_person {
        position: relative;
        right: auto;
        bottom: auto;
        width: clamp(90px, 18vw, 252px);
        margin-left: -1.25vw;
        margin-bottom: -1.5vw;
        flex-shrink: 0;
    }
}

.sect02 {
    padding: 36px 0;
}

.sect02_text01 {
    font-size: 50px;
    font-weight: 900;
    line-height: 1.3;
    text-align: center;
}

.sect02_text02 {
    color: #11338F;
}

.sect02_text03 {
    font-size: 55px;
    color: #2888CC;
}

.sect02_layout01 {
    display: block;
    width: 652px;
    max-width: 100%;
    margin: 40px auto 0 auto;
}

.sect02_text04 {
    position: relative;
    width: 100%;
    padding: 23px 16px;
    background: #fff;
    font-size: 30px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
    margin-bottom: 30px;
    z-index: 5;
}

.sect02_text04 .icon {
    position: absolute;
    z-index: -1;
    right: 85px;
    bottom: -46px;
}

.sect02_text04:nth-child(2) .icon {
    right: 65px;
    bottom: -52px;
}

.sect02_layout02 {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    width: 652px;
    max-width: 100%;
    padding-bottom: 218px;
    position: relative;
    margin-left: auto;
    margin-right: auto;
}

.sect02_text05 {
    position: relative;
    width: 260px;
    padding: 35px 10px 35px 23px;
    background: #fff;
    font-size: 28px;
    font-weight: 700;
    line-height: 1.8;
    text-align: left;
}

.sect02_text06 {
    position: relative;
    width: 370px;
    padding: 23px 16px;
    background: #fff;
    font-size: 28px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
    margin-bottom: 30px;
    z-index: 5;
}

.sect02_text06 .icon {
    position: absolute;
    z-index: -1;
    right: 46px;
    bottom: -70px;
}

.sect02_img01 {
    position: absolute;
    bottom: 0;
    right: 41px;
}

.sect02_box01 {
    width: 750px;
    max-width: 100%;
    margin: 0 auto;
    background-color: #fff;
    position: relative;
    z-index: 10;
}

.sect02_box01::before {
    content: '';
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: -2px;
    width: 744px;
    height: 115px;
    background: url(../img/sect02_img02.png);
    background-size: cover;
    background-position: center;
    z-index: -1;
}

.sect02_text07 {
    font-size: 36px;
    font-weight: 700;
    line-height: 1.3;
    color: #fff;
    text-align: center;
    padding-top: 30px;
}

.sect02_text08 {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    font-size: 40px;
    font-weight: 700;
    line-height: 1.3;
    color: #11338F;
    padding-top: 50px;
    padding-bottom: 50px;
}

@media screen and (max-width: 768px) {
    .sect02_text01 {
        font-size: 6.66vw;
    }

    .sect02_text03 {
        font-size: 7.33vw;
    }

    .sect02_layout01 {
        width: 86.93vw;
        margin: 5.33vw auto 0 auto;
    }

    .sect02_text04 {
        padding: 3.06vw 2.13vw;
        font-size: 4vw;
        margin-bottom: 4vw;
    }

    .sect02_text04 .icon {
        right: 11.33vw;
        bottom: -6.13vw;
        width: 10.4vw;
    }

    .sect02_text04:nth-child(2) .icon {
        right: 8.66vw;
        bottom: -6.93vw;
    }

    .sect02_layout02 {
        width: 86.93vw;
        padding-bottom: 29vw;
    }

    .sect02_text05 {
        width: 34.66vw;
        padding: 4.66vw 1.33vw 4.66vw 3.06vw;
        font-size: 3.73vw;
    }

    .sect02_text06 {
        width: 49.33vw;
        padding: 3.06vw 2.13vw;
        font-size: 3.73vw;
        margin-bottom: 4vw;
    }

    .sect02_text06 .icon {
        width: 10.4vw;
        right: 6.13vw;
        bottom: -9.33vw;
    }

    .sect02_img01 {
        width: 60.66vw;
        right: 5.46vw;
    }

    .sect02_box01 {
        width: 100%;
    }

    .sect02_box01::before {
        width: 92vw;
        height: 14.22vw;
    }

    .sect02_text07 {
        font-size: 4.8vw;
        padding-top: 2.5vw;
    }

    .sect02_text08 {
        font-size: 5.33vw;
        padding-top: 6.66vw;
        padding-bottom: 6.66vw;
    }
}

.sect03 {
    padding: 30px 0;
}

.sect03_text01,
.sect03_text02 {
    font-size: 40px;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
}

.sect03_text02 {
    color: #003F73;
}

.sect03_list01 {
    margin-top: 10px;
}

.sect03_list01 li {
    list-style: none;
    padding: 20px 0;
    border-bottom: solid 2px #8ABFE5;
    display: flex;
    align-items: center;
    justify-items: flex-start;
    width: 100%;
    height: auto;
}

.sect03_list01 li:last-child {
    border-bottom: none;
}

.sect03_box01 {
    width: 135px;
    min-width: 135px;
    height: 135px;
    min-height: 135px;
    border-radius: 70px;
    background-color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.sect03_text03 {
    font-size: 24px;
    font-weight: 500;
    color: #4696D0;
    line-height: 1;
}

.sect03_text04 {
    font-size: 64px;
    font-weight: 700;
    color: #2888CC;
    line-height: 1;
}

.sect03_text05 {
    font-size: 26px;
    padding: 0 5px 0 17px;
    letter-spacing: -0.05em;
}

.sect03_image01 {
    display: block;
    max-width: 100%;
    margin: 0 auto;
}

@media screen and (max-width: 768px) {

    .sect03_text01,
    .sect03_text02 {
        font-size: 5.33vw;
    }

    .sect03_list01 li {
        padding: 2.66vw 0;
    }

    .sect03_box01 {
        width: 18vw;
        min-width: 18vw;
        height: 18vw;
        min-height: 18vw;
        border-radius: 9vw;
    }

    .sect03_text03 {
        font-size: 3.2vw;
    }

    .sect03_text04 {
        font-size: 8.53vw;
    }

    .sect03_text05 {
        font-size: 3.46vw;
        padding: 0 0.66vw 0 2.26vw;
    }
}

.sect04 {
    padding: 30px 0;
}

.sect04_text01 {
    width: fit-content;
    margin: 0 auto;
    color: #2888CC;
    font-size: 36px;
    font-weight: 700;
    line-height: 1.5;
    padding: 6px 30px;
    background-color: #fff;
}

.sect04_text02 {
    font-size: 40px;
    font-weight: 700;
    line-height: 1.2;
    color: #003F73;
    text-align: center;
    margin-top: 3px;
}

.sect04_list01 {
    margin-top: 25px;
}

.sect04_list01 li {
    list-style: none;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: 16px;
}

.sect04_list01 li:last-child {
    margin-bottom: 0;
}

.sect04_list01 li .thumb {
    width: 324px;
    height: auto;
}

.sect04_text03 {
    padding-left: 40px;
    font-size: 26px;
    line-height: 1.5;
    letter-spacing: -0.05em;
}

.sect04 .sect_fv_layout02::before,
.sect04 .sect_fv_layout02::after {
    display: none;
}

.sect04 .button_layout01 {
    margin-top: 16px;
}

.sect04 .button_link01,
.sect04 .button_link02 {
    width: 335px;
}

@media screen and (max-width: 1600px) {

    .sect04 .button_link01,
    .sect04 .button_link02 {
        width: 22vw;
    }
}

@media screen and (max-width: 768px) {
    .sect04_text01 {
        font-size: 4.8vw;
        padding: 0.8vw 4vw;
    }

    .sect04_text02 {
        font-size: 5.33vw;
    }

    .sect04_list01 {
        margin-top: 3.33vw;
    }

    .sect04_list01 li {
        margin-bottom: 2.13vw;
    }

    .sect04_list01 li .thumb {
        width: 43.2vw;
    }

    .sect04_text03 {
        padding-left: 5.33vw;
        font-size: 3.46vw;
    }

    .sect04 .button_link01,
    .sect04 .button_link02 {
        width: 44.66vw;
    }

    .copyright {
        font-size: 12px;
    }
}

.sect-left-ad {
    position: absolute;
    left: calc(50vw - 375px - 7.15vw - 27.5vh);
    top: 62.57vw;
}

.sect-left-ad_image01 {
    width: 27.5vh;
}

.sect-left-ad.fixed {
    position: fixed;
    top: 4.5vh;
}

.sect-right-ad {
    position: absolute;
    left: calc(50vw + 375px + 4.73vw);
    top: 56.6vw;
    width: fit-content;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.sect-right-ad.fixed {
    position: fixed;
    top: 14.2vh;
}

.sect-right-ad_text01 {
    width: 10.33vh;
}

.sect-right-ad .button_layout01 {
    flex-direction: column;
    margin-top: 8.5vh;
}

.sect-right-ad .button_link01,
.sect-right-ad .button_link02 {
    width: 28vh;
    height: 7.2vh;
    border-radius: 4vh;
    font-size: 2.13vh;
    margin: 0 0 2.13vh 0;

}

.sect-right-ad .button_link01:last-child,
.sect-right-ad .button_link02:last-child {
    margin-bottom: 0;
}

@media screen and (max-width: 1350px) {
    .sect-left-ad {
        left: calc(50vw - 375px - 3vw - 20vh);
    }

    .sect-right-ad {
        left: calc(50vw + 375px + 1vw);
    }

    .sect-right-ad .button_link01,
    .sect-right-ad .button_link02 {
        width: 15vw;
        height: 3.85vw;
        border-radius: 2.5vw;
        font-size: 1.14vw;
    }

    .sect-right-ad .button_link01 .icon,
    .sect-right-ad .button_link02 .icon {
        margin-left: 0.57vw;
        width: 0.4vw;
    }

    .sect-left-ad_image01 {
        width: 21vh;
    }

    .sect-left-ad.fixed {
        top: 20vh;
    }
}

@media screen and (max-width: 1100px) {
    .sect-left-ad {
        display: none;
    }

    .sect-right-ad {
        display: none;
    }
}

/* Pick Up セクション */
.pickup-section {
    padding: 48px 0;
    background: #f7fbfe;
}

.pickup-header {
    text-align: center;
    margin-bottom: 20px;
}

.pickup-en {
    font-size: 28px;
    letter-spacing: 2px;
    margin: 0;
    color: #0b2340;
    font-weight: 700;
}

.pickup-ja {
    margin: 6px 0 0;
    color: #6b7680;
    font-size: 13px;
}

.pickup-card {
    max-width: 980px;
    margin: 0 auto;
    display: flex;
    gap: 20px;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 6px 20px rgba(8, 27, 46, 0.06);
    overflow: hidden;
    align-items: stretch;
}

.pickup-thumb {
    width: 360px;
    height: 202px;
    /* 16:9 比率の目安 */
    object-fit: cover;
    flex-shrink: 0;
    display: block;
}

.pickup-body {
    padding: 18px 22px;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.pickup-title {
    font-size: 18px;
    margin: 0 0 8px;
    color: #0b2340;
    line-height: 1.3;
}

.pickup-tags {
    margin-bottom: 8px;
}

.tag {
    display: inline-block;
    font-size: 12px;
    color: #4f6570;
    margin-right: 8px;
}

.pickup-excerpt {
    margin: 0 0 14px;
    color: #58656e;
    font-size: 14px;
}

.pickup-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    color: #7b8791;
}

.author {
    display: flex;
    align-items: center;
    gap: 10px;
}

.author-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
}

.meta-right {
    text-align: right;
    display: flex;
    gap: 10px;
    align-items: center;
    color: #7b8791;
}

.views::before {
    content: "👁︎";
    margin-right: 6px;
    font-size: 13px;
}

@media (max-width:880px) {
    .pickup-card {
        flex-direction: column;
        gap: 0;
        border-radius: 8px;
    }

    .pickup-thumb {
        width: 100%;
        height: 200px;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
    }

    .pickup-body {
        padding: 14px;
    }

    .pickup-en {
        font-size: 22px;
    }
}