@charset "UTF-8";
/* --------------------
 Template ストーリーテンプレート v2025
-------------------- */
:root {
    --duration: 0.35s;
    --cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
}

.template-story #article {
    overflow: hidden;
    padding: 0 0 30px;
}

.template-story #article .post_content .story-post-cover:first-of-type {
    margin-top: -27px;
}

@media (min-width: 751px) {
    .template-story #article .post_content .story-post-cover:first-of-type {
        margin-top: -45px;
    }
}

#article:has(.story-page-head) .post_content {
    padding-top: 0;
}

.story-page-head {
    align-items: stretch;
    background-image: none;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    display: flex;
    flex-flow: column nowrap;
    gap: 20px;
    height: 300px;
    justify-content: center;
    margin: 0 -30px 60px;
    position: relative;
    width: auto;
}

@media (min-width: 751px) {
    .story-page-head {
        height: 430px;
        margin: 0 min(-30px, 335px - 50vw + 50px) 70px;
    }
}

@media (min-width: 1100px) {
    .story-page-head {
        margin: 0 -165px 70px;
    }
}

.story-page-head:before {
    background-color: #000000;
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    opacity: 0.45;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}

.story-page-head__title,
.story-page-head h2.story-page-head__title {
    color: #fff;
    font-family: "Noto Serif JP";
    font-size: 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.6;
    margin: 0;
    position: relative;
    text-align: center;
    width: 100%;
    z-index: 1;
}

@media (min-width: 751px) {
    .story-page-head__title,
  .story-page-head h2.story-page-head__title {
        font-size: 30px;
    }
}

.story-page-head__subtitle {
    border: 1px solid #fff;
    color: #fff;
    font-family: "Noto Sans JP";
    font-size: 12px;
    font-weight: 400;
    line-height: 1.2;
    margin: 0 auto;
    padding: 4px 8px;
    position: relative;
    width: -moz-fit-content;
    width: fit-content;
    z-index: 1;
}

.section {
    margin: 0 0 80px;
}

@media (min-width: 751px) {
    .section {
        margin: 0 0 90px;
    }
}

.section:last-child {
    margin-bottom: 0;
}

.section:before {
    background-color: #000000;
    content: "";
    display: block;
    height: 1px;
    margin: 0 auto 30px;
    width: 30px;
}

@media (min-width: 751px) {
    .section:before {
        margin: 0 auto 30px;
    }
}

.section__title,
.section h3.section__title {
    font-size: 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.8;
    margin: 0 0 40px;
    text-align: center;
}

@media (min-width: 751px) {
    .section__title,
  .section h3.section__title {
        font-size: 24px;
        margin: 0 0 40px;
    }
}

.section__fig {
    margin: 0 0 30px;
    text-align: center;
}

@media (min-width: 751px) {
    .section__fig {
        margin: 0 0 36px;
    }
}

@media (min-width: 751px) {
    .section:has(.section__subtitle) .section__fig {
        margin-bottom: 50px;
    }
}

.section__subtitle,
.section h3.section__subtitle {
    font-size: 18px;
    letter-spacing: 0;
    line-height: 1.8;
    margin: 0 0 24px;
    text-align: center;
}

@media (min-width: 751px) {
    .section__subtitle,
  .section h3.section__subtitle {
        font-size: 20px;
    }
}

.section__content p {
    font-size: 14px;
    font-weight: 400;
    line-height: 2.2;
    margin: 0 0 1.5em;
}

@media (min-width: 751px) {
    .section__content p {
        font-size: 16px;
    }
}

.section__content p:last-child {
    margin-bottom: 0;
}

.rsv {
    align-items: center;
    background-image: url(../img/omotesando-vegan/omotesando-vegan-reservattion.webp);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    display: flex;
    flex-flow: row nowrap;
    height: 200px;
    justify-content: stretch;
    margin: 0 -30px 60px;
    position: relative;
    width: auto;
}

@media (min-width: 751px) {
    .rsv {
        height: 234px;
        margin: 0 min(-30px, 335px - 50vw + 50px) 90px;
    }
}

@media (min-width: 1100px) {
    .rsv {
        margin: 0 -165px 90px;
    }
}

.rsv-inner {
    width: 100%;
}

.rsv__title {
    margin: 0 0 24px;
}

.rsv__title__en {
    filter: drop-shadow(3px 3px 5px rgba(0, 0, 0, 0.35));
    font-size: 10px;
    line-height: 1.2;
    margin: 0 0 10px;
    text-align: center;
}

.rsv__title__en img {
    height: 24px;
    width: auto !important;
}

@media (min-width: 751px) {
    .rsv__title__en img {
        height: 27px;
    }
}

.rsv__title__ja {
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.02em;
    line-height: 1.2;
    margin: 0;
    text-align: center;
}

@media (min-width: 751px) {
    .rsv__title__ja {
        font-size: 16px;
    }
}

.rsv__action a {
    align-items: center;
    background-color: #ffffff;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
    color: #4F3913 !important;
    display: flex;
    flex-flow: row nowrap;
    font-family: "Noto Sans JP";
    font-size: 14px;
    font-weight: 500;
    height: 48px;
    justify-content: center;
    letter-spacing: 0.02em;
    margin: 0 auto;
    max-width: 220px;
    position: relative;
    text-decoration: none !important;
    transition: background-color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition: background-color var(--duration) var(--cubic) 0s, color var(--duration) var(--cubic) 0s;
    width: 100%;
}

@media (min-width: 751px) {
    .rsv__action a {
        height: 60px;
        max-width: 240px;
    }
}

.rsv__action a:after {
    background-color: #000000;
    bottom: 0;
    content: "";
    display: block;
    height: 14px;
    left: auto;
    margin: auto;
    -webkit-mask-image: url(../img/icons/icon-external-link-arrow-black.svg);
    mask-image: url(../img/icons/icon-external-link-arrow-black.svg);
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    position: absolute;
    right: 18px;
    top: 0;
    transition: background-color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition: background-color var(--duration) var(--cubic) 0s;
    width: 14px;
}

@media (min-width: 751px) {
    .rsv__action a:after {
        height: 16px;
        width: 16px;
    }
}

.rsv__action a:focus {
    background-color: #950000;
    color: #fff !important;
}

.rsv__action a:focus:after {
    background-color: #fff;
}

@media (hover: hover) and (pointer: fine) {
    .rsv__action a:hover {
        background-color: #950000;
        color: #fff !important;
    }

    .rsv__action a:hover:after {
        background-color: #fff;
    }
}

.shop {
    border: 1px solid #373737;
    margin: 0;
    padding: 30px 20px 20px;
}

@media (min-width: 751px) {
    .shop {
        margin: 0 0 100px;
        padding: 44px 50px 50px;
    }
}

.shop__title,
.shop h3.shop__title {
    border-bottom: 1px solid #000000;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.2;
    margin: 0 auto 35px;
    padding: 0 0 8px;
    text-align: center;
    width: -moz-fit-content;
    width: fit-content;
}

@media (min-width: 751px) {
    .shop__title,
  .shop h3.shop__title {
        font-size: 20px;
    }
}

.shop__fig {
    margin: 0 0 30px;
    text-align: center;
}

.shop__item-wrapper {
    margin: 0 0 30px;
}

.shop__item {
    margin: 0 0 40px;
}

.shop__item:last-child {
    margin-bottom: 0;
}

.shop__item__title,
.shop__item h4.shop__item__title {
    border-left: 3px solid #000000;
    font-family: "Noto Sans JP";
    font-size: 14px;
    font-weight: 400;
    line-height: 1.4;
    margin: 0 0 12px;
    padding: 0 0 0 6px;
}

@media (min-width: 751px) {
    .shop__item__title,
  .shop__item h4.shop__item__title {
        border-left-width: 4px;
        font-size: 16px;
        margin: 0 0 12px;
        padding: 0 0 0 7px;
    }
}

.shop__item__info {
    font-family: "Noto Sans JP";
}

.shop__item__info__address,
.shop__item__info address.shop__item__info__address {
    display: block;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 1.8;
    margin: 0 0 8px;
}

@media (min-width: 751px) {
    .shop__item__info__address,
  .shop__item__info address.shop__item__info__address {
        font-size: 16px;
    }
}

.shop__item__info__map a {
    align-items: center;
    color: #000000 !important;
    display: flex;
    flex-flow: row nowrap;
    font-size: 14px;
    justify-content: flex-start;
    padding: 0 20px 0 0;
    position: relative;
    text-decoration: underline !important;
    text-decoration-color: #000;
    transition: color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, text-decoration-color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition: color var(--duration) var(--cubic) 0s, text-decoration-color var(--duration) var(--cubic) 0s;
    width: -moz-fit-content;
    width: fit-content;
}

@media (min-width: 751px) {
    .shop__item__info__map a {
        font-size: 16px;
    }
}

.shop__item__info__map a:after {
    background-color: #000000;
    bottom: 0;
    content: "";
    display: block;
    height: 14px;
    left: auto;
    margin: auto;
    -webkit-mask-image: url(../img/icons/icon-external-link-arrow-black.svg);
    mask-image: url(../img/icons/icon-external-link-arrow-black.svg);
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    position: absolute;
    right: 18px;
    right: 0;
    top: 1px;
    transition: background-color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition: background-color var(--duration) var(--cubic) 0s;
    width: 14px;
}

@media (min-width: 751px) {
    .shop__item__info__map a:after {
        height: 16px;
        width: 16px;
    }
}

.shop__item__info__map a:focus {
    color: #950000 !important;
    text-decoration-color: transparent !important;
}

.shop__item__info__map a:focus:after {
    background-color: #950000;
}

@media (hover: hover) and (pointer: fine) {
    .shop__item__info__map a:hover {
        color: #950000 !important;
        text-decoration-color: transparent !important;
    }

    .shop__item__info__map a:hover:after {
        background-color: #950000;
    }
}

.shop__item__biz {
    font-family: "Noto Sans JP";
}

.shop__item__biz__item {
    margin: 0 0 14px;
}

.shop__item__biz__item:last-child {
    margin-bottom: 0;
}

.shop__item__biz__item__title,
.shop__item__biz__item h5.shop__item__biz__item__title {
    font-size: 14px;
    font-weight: 400;
    line-height: 1.8;
    margin: 0;
}

@media (min-width: 751px) {
    .shop__item__biz__item__title,
  .shop__item__biz__item h5.shop__item__biz__item__title {
        font-size: 16px;
    }
}

.shop__item__biz__item__title em,
.shop__item__biz__item h5.shop__item__biz__item__title em {
    font-style: normal;
    font-weight: 700;
}

.shop__item__biz__item__content ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0;
}

.shop__item__biz__item__content ul > li {
    font-size: 14px;
    font-weight: 400;
    line-height: 1.8;
    margin: 0;
    padding: 0 0 0 8px;
    position: relative;
}

@media (min-width: 751px) {
    .shop__item__biz__item__content ul > li {
        font-size: 16px;
    }
}

.shop__item__biz__item__content ul > li:before {
    background-color: #000;
    border-radius: 50%;
    content: "";
    display: block;
    height: 3px;
    left: 0;
    position: absolute;
    top: 10px;
    width: 3px;
}

.shop__rsv {
    align-items: center;
    background-image: url(../img/omotesando-vegan/omotesando-vegan-reservattion-small.webp);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    display: flex;
    flex-flow: row nowrap;
    height: 166px;
    justify-content: stretch;
    margin: 0;
    position: relative;
    width: auto;
}

.shop__rsv-inner {
    width: 100%;
}

.shop__rsv__title {
    margin: 0 0 12px;
}

.shop__rsv__title__en {
    filter: drop-shadow(3px 3px 5px rgba(0, 0, 0, 0.35));
    font-size: 10px;
    line-height: 1.2;
    margin: 0 0 8px;
    text-align: center;
}

.shop__rsv__title__en img {
    height: 18px;
    width: auto !important;
}

@media (min-width: 751px) {
    .shop__rsv__title__en img {
        height: 20px;
    }
}

.shop__rsv__title__ja {
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.02em;
    line-height: 1.2;
    margin: 0;
    text-align: center;
}

.shop__rsv__action a {
    align-items: center;
    background-color: #ffffff;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
    color: #4F3913 !important;
    display: flex;
    flex-flow: row nowrap;
    font-family: "Noto Sans JP";
    font-size: 12px;
    font-weight: 500;
    height: 44px;
    justify-content: center;
    letter-spacing: 0.02em;
    margin: 0 auto;
    max-width: 170px;
    position: relative;
    text-decoration: none !important;
    transition: background-color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition: background-color var(--duration) var(--cubic) 0s, color var(--duration) var(--cubic) 0s;
    width: 100%;
}

.shop__rsv__action a:after {
    background-color: #000000;
    bottom: 0;
    content: "";
    display: block;
    height: 10px;
    left: auto;
    margin: auto;
    -webkit-mask-image: url(../img/icons/icon-external-link-arrow-black.svg);
    mask-image: url(../img/icons/icon-external-link-arrow-black.svg);
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    position: absolute;
    right: 12px;
    top: 0;
    transition: background-color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition: background-color var(--duration) var(--cubic) 0s;
    width: 10px;
}

@media (min-width: 751px) {
    .shop__rsv__action a:after {
        height: 12px;
        width: 12px;
    }
}

.shop__rsv__action a:focus {
    background-color: #950000;
    color: #fff !important;
}

.shop__rsv__action a:focus:after {
    background-color: #fff;
}

@media (hover: hover) and (pointer: fine) {
    .shop__rsv__action a:hover {
        background-color: #950000;
        color: #fff !important;
    }

    .shop__rsv__action a:hover:after {
        background-color: #fff;
    }
}

@media (max-width: 750px) {
    .hidden-xs {
        display: none !important;
    }
}

@media (min-width: 751px) {
    .hidden-sm {
        display: none !important;
    }
}

.template-story #article .post_content {
    box-sizing: border-box;
    margin: 0 auto;
    max-width: 730px;
    padding-left: 30px;
    padding-right: 30px;
    width: 100%;
}