/* ========== fv ========== */
.shop__fv img {
    width: 100%;
}

.shop__info__txt--outline,
.shop__info__txt--detail {
    padding: 3rem 2.2rem 5rem;
}

.shop__info__txt--h1 {
    font-size: 2rem;
    font-weight: 300;
    line-height: 1.5;
    letter-spacing: 0.16rem;
}

.shop__info__txt--h2 {
    color: #1C208E;
    font-size: 1.4rem;
    font-weight: 300;
    letter-spacing: 0.14rem;
    margin: 3rem 0 1.2rem;
}

.shop__info__txt--p {
    font-family: "Noto Sans JP";
    font-size: 1.2rem;
    font-style: normal;
    font-weight: 300;
    line-height: 1.7;
    letter-spacing: 0.2rem;
    margin-top: 2rem;
    text-align: justify;

}

.shop__info__logo--wrap {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
    list-style: none;
    padding: 0;
    margin: 0 auto;
}

.shop__info__logo--item img {
    width: 100%;
}

.shop__info__ttl {
    margin-bottom: 3rem;
}

.shop__info__txt--name,
.shop__info__txt--address,
.shop__info__txt--tel,
.shop__info__txt--tel--num,
.shop__info__txt--open-hour,
.shop__info__txt--open-time,
.shop__info__txt--link span {
    font-size: 1.2rem;
}

.shop__info__txt--detail p {
    margin-bottom: 1rem;
}

.shop__info__txt--name {
    font-size: 1.8rem;
}

.shop__info__txt--link {
    display: flex;
    align-items: flex-end;
    gap: 0.4rem;
}

.shop__info__txt--link span {
    display: inline-block;
    border-bottom: solid 1px #000;
}

.shop__map--cont {
    display: flex;
    gap: .5rem;
    margin-bottom: 4rem;
}

.shop__map--items:nth-of-type(2) {
    margin-top: 4rem;
}

.shop__map--items img {
    border-radius: 1rem;
}

.shop__map-api {
    margin: auto;
    border-radius: 10px;
    width: 95%;
    height: 31.8rem;
    background-color: #e0e0e0;
    overflow: hidden;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    position: relative;
}

.shop__map-api iframe {
            width: 100%;
            height: 100%;
            border: 0;
            border-radius: 10px;
            filter: grayscale(100%);
        }

@media (min-width: 768px) {

    .shop__info {
        display: flex;
        flex-direction: row-reverse;
        padding: 0 8.4rem;
    }

    .shop__info__txt--outline {
        width: 70%;
    }

    .shop__info__txt--detail {
        width: 30%;
    }

    .shop__info__txt--h1 {
        font-size: 2.6rem;
    }

    .shop__info__txt--h2 {
        margin-bottom: 2rem;
    }

    .shop__info__txt--p {
        font-size: 1.4rem;
    }

    .shop__info__logo--wrap {
        grid-template-columns: repeat(6, 1fr);
        max-width: 100%;
    }

    .shop__map--cont {
        padding: 0 4rem;
        margin-bottom: 6rem;
        gap: 1rem;
    }

    .shop__map-api {
        width: initial;
        height: 45.5rem;
        margin: 0 4rem;
    }

    .shop__map--items {
        width: 100%;
    }

    .shop__map--items img {
        width: 100%;
        height: 56rem;
        object-fit: cover;
    }

}