/* ================================================

FOOTER フッター

================================================ */

.footer {
    background-color: var(--color-bg-l-beige);
    position: relative;
    z-index: 900;
    background:
        url(../../img/common/bg_body.webp) repeat center/contain,
        #fff;
    padding-top: var(--space-10xl);
}

.footer__inner {
    display: grid;
    grid-template-columns: clamp(80px, 8vw, 130px) 1fr auto clamp(200px, 23vw, 400px);
    grid-template-rows: 1fr;
    grid-template-areas: "logo nav link map";
    gap: 3em clamp(1.5em, 2.5vw, 9em);
    align-items: start;
    justify-items: center;
    margin: 0 auto;
    max-width: 1400px;
}

/* ········ grid area ········ */
.footer__logo {
    grid-area: logo;
    width: 100%;
    height: auto;
    aspect-ratio: 107/150;
}

.footer__nav {
    grid-area: nav;
    justify-self: center;
}

.footer__link {
    grid-area: link;
}



.footer__map {
    grid-area: map;
    width: 100%;
    height: 100%;
    aspect-ratio: 198 / 150;
    text-align: center;
}

.footer__map img {
    margin-inline: auto;
    object-fit: contain;
}


/* ········ navigation ········ */
.footer__nav ul {
    display: flex;
    flex-direction: row-reverse;
    gap: clamp(16px, 1.2vw, 32px);
}

.footer__nav li {
    font-size: var(--fontSize-sm);
    writing-mode: vertical-rl;
    text-orientation: mixed;
    letter-spacing: 0.5em;
    display: flex;
    gap: 1em;
    align-items: center;
}

/* ········ link ········ */
.footer__link {
    font-size: clamp(12px, 1.5vw, 14px);
    display: flex;
    flex-direction: column;
    letter-spacing: 0.05em;
    gap: 0.5em;
    line-height: 1.5;
}


.footer__insta{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 0.5em;

}

.footer__insta-text {
    font-size: clamp(10px, 1.3vw, 12px);
    line-height: 1.25;
}

.footer__insta-name{
    display: flex;
    align-items: center;
    gap: 0.5em;
}
.footer__insta-name::after{
    content: "";
    display: block;
    width: 1.5em;
    height: auto;
    aspect-ratio: 1 / 1;
    background: url(../../img/common/icon_instagram.svg) no-repeat center/contain;
}

@media (hover: hover) and (pointer: fine) {
    .footer__link a:hover{
        opacity: 0.7;
    }
}

/* ········ COPYRIGHT/PRIVACYリンク ········ */
.footer__bottom {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--space-sm);
    margin-top: 80px;
}

.footer__privacy {
    font-size: 11px;
    letter-spacing: 0.1em;
}

/* ········ copyright ········ */
.copyright {
    grid-column: 1 / -1;
    /* 全幅 */
    text-align: right;
    font-size: var(--fontSize-2xs);
    letter-spacing: 0.1em;
}

/* ------------------------------------------------
レスポンシブ
------------------------------------------------ */

@media (width < 1024px) {
    .footer__inner {
        grid-template-columns: clamp(70px, 10vw, 120px) auto;
        grid-template-rows: auto auto auto;
        grid-template-areas:
            "logo link"
            "nav nav"
            "map map";
        gap: var(--space-6xl) var(--space-2xl);
        width: min-content;
    }

    .footer__logo {
        margin-left: 0.5em;
    }

    .footer__nav {
        grid-column: 1 / -1;
        justify-self: center;
    }

    .footer__nav ul {
        gap: 2.5vw;
    }

    .footer__link {
        justify-content: center;
        height: 100%;
    }

    .footer__map {
        grid-column: 1 / -1;
    }

    .copyright {
        grid-column: 1 / -1;
    }
}