@charset "utf-8";

.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 50;
    border-bottom: 0.5px solid #FFF;
    transition: background-color .8s ease;
}

.h_logo {
    max-width: 63px;
    width: 10%;
}

.h_logo img {
    width: 100%;
    height: auto;
}

.header.is-show {
    background-color: #FFF;
}

.header .inner {
    padding: 17px 0;
    display: flex;
    justify-content: space-between;
}

.header .nav-menu {
    display: flex;
    gap: 60px;
    align-items: center;
}

.header .btnarea {
    display: flex;
}

.header .btnarea .btn-link {
    padding: 14px 20px 14px 29px;
    font-family: var(--font-notosans);
    font-weight: 600;
    font-size: clamp(0.75rem, 0.417rem + 0.69vw, 1.25rem);
    color: #fff;
    display: flex;
    align-items: center;
    gap: 30px;
}



.header .btnarea .btn-link .arrow {
    overflow: hidden;
    position: relative;
}

.header .btnarea .btn-link .arrow img {
    transform: rotate(-46deg);
    transition: .8s ease;
    width: 16px;
    height: auto;
}

.header .btnarea .yellow {
    background-color: #E0B55C;
}

.header .btnarea .blue {
    background-color: #2066AA;
}

.header .btnarea .btn-link .arrow .back {
    position: absolute;
    transform: translateY(100%) rotate(-46deg) translateX(-100%);
    left: 0;
    top: 0;
}

.header .btnarea .btn-link:hover .arrow .front {
    transform: translateY(-100%) rotate(-46deg) translateX(100%);
}

.header .btnarea .btn-link:hover .arrow .back {
    transform: translateY(-16%) rotate(-46deg) translateX(0%);
}

.nav-menu a {
    font-family: var(--font-notosans);
    font-weight: 500;
    font-size: clamp(1rem, 0.917rem + 0.17vw, 1.125rem);
    color: #fff;
}

.header.is-show .nav-menu>a {
    color: #0F0F0F;
}

.hamburger,
.navigation {
    display: none;
}




@media (max-width: 1200px) {

    .header .nav-menu {
        gap: 45px;
    }
}



@media (max-width: 1023px) {
    .header .btnarea .btn-link {
        padding: 5px 11px 5px 13px;
    }

    .header .nav-menu {
        gap: 25px;
    }
}

@media (max-width: 767px) {


    .header.active {
        background-color: #FFF;
    }

        .header.is-show .line,.hamburger.active .line {
        background-color: #000000;
    }

    .header .inner {
        justify-content: flex-start;
        align-items: center;
    }

    .header .nav-menu {
        margin-left: auto;
        margin-right: 9px;
    }

    .header .nav-menu>a {
        display: none;
    }


    .hamburger {
        display: block;
        width: 20px;
        height: 14px;
        cursor: pointer;
        z-index: 100;
        position: relative;
    }



    /* ドット（初期） */
    .hamburger .line {
        position: absolute;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #FFF;
        transition: all 0.4s ease;
    }

    /* アクティブ時：中央配置に切り替え */
    .hamburger.active {
        display: block;

    }

    .hamburger.active .line {
        position: absolute;
        top: 50%;
        left: 50%;
        width: 20px;
        height: 2px;
        border-radius: 2px;
        transform-origin: center;
    }

    .hamburger .line1 {
        top: 0;
    }

    .hamburger .line2 {
        top: 8px;
    }

    .hamburger .line3 {
        top: 15px;
    }


    /* 上 → ／ */
    .hamburger.active .line1 {
        transform: translate(-50%, -50%) rotate(45deg);
    }

    /* 真ん中消す */
    .hamburger.active .line2 {
        opacity: 0;
    }

    /* 下 → ＼ */
    .hamburger.active .line3 {
        transform: translate(-50%, -50%) rotate(-45deg);
    }

    /* メニューのスタイル */


    .navigation .menu-inner {
        padding: 91px 0 7px;
        width: 80%;
        display: flex;
        flex-direction: column;
        margin: 0 auto;
    }

    .navigation .menu-inner .list {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 40px;
        justify-content: space-between;
        margin-bottom: 77px;
    }

    .navigation a {
        display: flex;
        gap: 8px;
        align-items: center;
        font-family: var(--font-notosans);
        font-weight: 500;
        font-size: 16px;
        color: #000;
    }

    .navigation {
        display: block;
        position: fixed;
        pointer-events: none;
        top: var(--header-height);
        right: -100%;
        width: 100%;
        background: #fff;
        transition: all .8s;
        z-index: 99;
        overflow: auto;
        height: calc(100svh - var(--header-height));
    }

    .navigation.active {
        right: 0;
        pointer-events: all;
    }

    .navigation .info {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin-bottom: 40px;
    }

    .navigation .info .logo {
        margin-bottom: 20px;
    }

    .navigation .info .desc {
        margin-bottom: 14px;
    }

    .navigation .info .desc p,
    .navigation .info .link p {
        font-size: 12px;
        line-height: 20px;
    }

    .navigation .copy {
        font-family: var(--font-notosans);
        font-weight: 500;
        font-size: 12px;
        text-align: center;
        color: #a09a9a;
    }


}


/* 管理画面用 */
.gjs-dashed .navigation {
    right: 0;
    top: 0;
    pointer-events: all;
}