@charset "UTF-8";


/* ナビ本体のラッパー */
.bl_gnavMenu_wrapper {
    align-items: center;
    display: flex;
    flex-direction: column;
    height: 100dvh;
    max-width: 100vw;
    overflow-y: auto;
    overflow-x: hidden;
    pointer-events: none;
    position: fixed;
    right: 0;
    top: 0;
    width: var(--recruit-gnavMenu-slide-width);

    transform: translateY(-100%);
    opacity: 1;
    visibility: hidden;
    background-color: rgba(var(--recruit-color-accent005-rgb), 1.00);
    transition: transform 0.25s ease-out, visibility 0s linear 0.25s;

    @media screen and (min-width: 768px) {
        background-color: transparent;
        flex-direction: row;
        height: auto;
        opacity: 1;
        overflow: visible;
        pointer-events: auto;
        position: static;
        transform: none;
        transition: none;
        visibility: visible;
        width: auto;
    }

    &.active {
        transform: translateY(0);
        visibility: visible;
        pointer-events: auto;
        background-color: rgba(var(--recruit-color-accent005-rgb), 0.99);
        transition: transform 0.25s ease-out;
    }
}

/* ナビ本体 */
.bl_gnavMenu {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    padding: var(--recruit-header-fixed-height) 0;
    width: calc(100% - 1%);

    @media screen and (min-width: 768px) {
        align-items: center;
        flex-direction: row;
        padding: 0;
    }
}

/* ナビ項目  */
.bl_gnavMenu_item {
    border-top: 1px solid var(--recruit-color-base);
    width: 100%;

    @media screen and (min-width: 768px) {
        border-top: none;
    }

    &:last-child {
        border-bottom: 1px solid var(--recruit-color-base);

        @media screen and (min-width: 768px) {
            border-bottom: none;
        }
    }

    a {
        background: none;
        border: none;
        box-sizing: border-box;
        color: var(--recruit-color-base);
        display: block;
        font-size: var(--recruit-gnavMenu-font-size--sp);
        font-weight: var(--font-weight-medium);
        line-height: 1.0;
        text-align: left;
        text-decoration: none;
        transition: background-color 0.3s, color 0.3s;
        padding: 1.50rem 1.25rem;
        width: auto;

        @media screen and (min-width: 768px) {
            color: var(--recruit-color-text1);
            font-size: var(--recruit-gnavMenu-font-size--pc-s);
            max-width: 100%;
            padding: 0.4rem;
            width: max-content;
        }

        @media screen and (min-width: 1024px) {
            font-size: var(--recruit-gnavMenu-font-size--pc-m);
            padding: 0.6rem;
        }

        @media screen and (min-width: 1280px) {
            font-size: var(--recruit-gnavMenu-font-size--pc-l);
            padding: 0.8rem;
        }

        @media screen and (min-width: 1600px) {
            font-size: var(--recruit-gnavMenu-font-size--pc-ll);
            padding: 1.0rem;
        }

        &:hover {
            background-color: var(--recruit-color-base);
            color: var(--recruit-color-text1);
            cursor: pointer;
            opacity: 0.5;
            text-decoration: none;
            transition: 0.3s;

            @media screen and (min-width: 768px) {
                background-color: none;
            }
        }

        &[href="#"] {
            display: none;
        }
    }

    /* エントリーボタン  */
    .bl_gnavMenu_entry {
        display: block;

        @media screen and (min-width: 768px) {
            align-items: center;
            background-color: var(--recruit-color-main);
            border-radius: 999rem;
            display: flex;
            justify-content: flex-start;
            padding: 2px;
            padding-right: 5px;
            text-align: left;
            border: 2px solid var(--recruit-color-main);

            &:hover {
                background-color: var(--recruit-color-base);
                cursor: pointer;
                opacity: 0.5;
                transition: 0.3s;
                text-decoration: none;

                .el_text {
                    color: var(--recruit-color-main);

                }

                .el_circle {
                    background-color: var(--recruit-color-main);
                }
            }
        }

        /* 円 */
        .el_circle {
            display: none;

            @media screen and (min-width: 768px) {
                align-items: center;
                background-color: var(--recruit-color-base);
                border-radius: 50%;
                display: flex;
                justify-content: center;

                height: var(--recruit-gnavMenu-circle-size--pc-s);
                width: var(--recruit-gnavMenu-circle-size--pc-s);
            }

            @media screen and (min-width: 1024px) {
                height: var(--recruit-gnavMenu-circle-size--pc-m);
                width: var(--recruit-gnavMenu-circle-size--pc-m);
            }

            @media screen and (min-width: 1280px) {
                height: var(--recruit-gnavMenu-circle-size--pc-l);
                width: var(--recruit-gnavMenu-circle-size--pc-l);
            }

            @media screen and (min-width: 1600px) {
                height: var(--recruit-gnavMenu-circle-size--pc-ll);
                width: var(--recruit-gnavMenu-circle-size--pc-ll);
            }
        }

        /* 矢印 */
        .el_circle__entryIcon {
            display: none;

            @media screen and (min-width: 768px) {
                display: inline-block;
                width: 2.35em;
                height: 2.35em;
                vertical-align: middle;
                background-image: var(--recruit-img-icon-entry-arrow-red);
                background-size: contain;
                background-repeat: no-repeat;
            }
        }

        /* 矢印（ホバー時） */
        &:hover {
            .el_circle__entryIcon {
                background-image: var(--recruit-img-icon-entry-arrow-white);
            }
        }

        /* テキスト */
        .el_text {
            @media screen and (min-width: 768px) {
                color: var(--recruit-color-base);
                font-size: var(--recruit-gnavMenu-font-size--pc-s);
                margin: 0 0.5vw;
            }

            @media screen and (min-width: 1024px) {
                font-size: var(--recruit-gnavMenu-font-size--pc-m);
            }

            @media screen and (min-width: 1280px) {
                font-size: var(--recruit-gnavMenu-font-size--pc-l);
            }

            @media screen and (min-width: 1600px) {
                font-size: var(--recruit-gnavMenu-font-size--pc-ll);
            }
        }
    }

    /* 画面が広い場合に要素を表示しない */
    .js_hideOnWideScreen {
        @media screen and (min-width: 768px) {
            display: none;
        }
    }
}
