@import url(https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@400;500;600;700;800&family=Zen+Kaku+Gothic+Antique:wght@300;400;500;700;900&display=swap);
@charset "utf-8";
:root {
    --color--black: #000;
    --color--dark_gray: #1C1C1C;
    --color--white: #fff;
    --color--gray: #868686;
    --color--brown: #716458;
    --10px: calc((10 / 1280) * 100vw);
    --12px: calc((12 / 1280) * 100vw);
    --13px: calc((13 / 1280) * 100vw);
    --14px: calc((14 / 1280) * 100vw);
    --16px: calc((16 / 1280) * 100vw);
    --18px: calc((18 / 1280) * 100vw);
    --20px: calc((20 / 1280) * 100vw);
    --24px: calc((24 / 1280) * 100vw);
    --26px: calc((26 / 1280) * 100vw);
    --30px: calc((30 / 1280) * 100vw);
    --36px: calc((36 / 1280) * 100vw)
}
@media all and (max-width:768px) {
    :root {
        --10px: calc((10 / 375) * 100vw);
        --12px: calc((12 / 375) * 100vw);
        --13px: calc((13 / 375) * 100vw);
        --14px: calc((14 / 375) * 100vw);
        --16px: calc((16 / 375) * 100vw);
        --18px: calc((18 / 375) * 100vw);
        --20px: calc((20 / 375) * 100vw);
        --22px: calc((22 / 375) * 100vw);
        --24px: calc((24 / 375) * 100vw);
        --26px: calc((26 / 375) * 100vw);
        --28px: calc((28 / 375) * 100vw);
        --30px: calc((30 / 375) * 100vw);
        --36px: calc((36 / 375) * 100vw)
    }
}
body {
    min-height: 100vh;
    margin: 0;
    padding: 0;
    background-color: #F2F3EC;
    scroll-behavior: smooth;
    text-rendering: optimizeSpeed;
    color: #000;
    font-family: "Shippori Mincho B1", serif;
    font-weight: 500;
    font-style: normal;
    line-height: 1.8;
    letter-spacing: .05em
}
.zen {
    font-family: "Zen Kaku Gothic Antique", sans-serif
}
body.scroll-stop {
    overflow: hidden
}
.lenis.lenis-smooth {
    scroll-behavior: auto !important
}
.lenis.lenis-smooth [data-lenis-prevent] {
    overscroll-behavior: contain
}
.lenis.lenis-stopped {
    overflow: hidden
}
.lenis.lenis-smooth iframe {
    pointer-events: none
}
#wrap {
    transition: .4s
}
#wrap.opacity0 {
    opacity: 0
}
#l_wrapper {
    width: 100%;
    height: auto;
    overflow: hidden
}
header {
    width: 100%;
    height: 0;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 200
}
.hamburger {
    width: 125px;
    height: 86px;
    position: absolute;
    top: 30px;
    right: 30px
}
.hbg_btn {
    display: block;
    width: 100%;
    height: 100%;
    padding: 0;
    outline: none;
    cursor: pointer
}
.hbg_btn__bg {
    width: 100%;
    height: 100%
}
.hbg_btn_line {
    width: calc((52 / 1280) * 100vw);
    height: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1
}
.global_nav {
    display: none;
    width: 100%;
    height: 100vh;
    background-color: var(--color--dark_gray);
    overflow: hidden;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 201
}
.global_nav__bg {
    width: 100%;
    height: 100%;
    background-image: url(../image/global_nav-bg.webp);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    mix-blend-mode: multiply;
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 3
}
.global_nav__close {
    width: 125px;
    height: 86px;
    cursor: pointer;
    position: absolute;
    top: 30px;
    right: 30px;
    z-index: 2
}
.global_nav__contents {
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 1
}
.global_nav__menu {
    width: 100%;
    height: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}
.global_nav__menu__list {
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    align-items: flex-start;
    column-gap: calc((55 / 1280) * 100vw);
    width: 100%;
    height: auto;
    font-size: var(--30px);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .2em;
    white-space: nowrap
}
.global_nav__menu__list__item {
    width: auto;
    height: auto;
    -webkit-writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -ms-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    position: relative
}
.global_nav__menu__list__item::before {
    font-size: var(--16px);
    font-weight: 400;
    line-height: 1;
    letter-spacing: .05em;
    color: var(--color--gray);
    position: absolute;
    top: calc(((30 / 1280) * 100vw) * 1.2);
    right: calc((20 / 1280) * -100vw);
    pointer-events: none
}
.global_nav__menu__list__item.news::before {
    content: 'news'
}
.global_nav__menu__list__item.store::before {
    content: 'store'
}
.global_nav__menu__list__item.contact::before {
    content: 'contact'
}
.global_nav__menu__list__item.reservation::before {
    content: 'reservation'
}
.global_nav__menu__list__item.sns::before {
    content: 'link'
}
.global_nav__menu__list__item a {
    color: var(--color--white)
}
.global_nav__copy {
    width: calc((56 / 1280) * 100vw);
    height: auto;
    position: absolute;
    bottom: calc((90 / 1280) * 100vw);
    right: calc((90 / 1280) * 100vw);
    z-index: 1
}
.global_nav__logo {
    width: calc((111.37 / 1280) * 100vw);
    height: auto;
    position: absolute;
    bottom: calc((83.2 / 1280) * 100vw);
    left: 50%;
    transform: translate(-50%, 0%)
}
.global_nav__copyright {
    -webkit-writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -ms-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    font-size: var(--12px);
    font-weight: 400;
    line-height: 1.3;
    letter-spacing: .05em;
    color: var(--color--white);
    position: absolute;
    bottom: calc((83 / 1280) * 100vw);
    left: calc((88 / 1280) * 100vw)
}
footer {
    width: 100%;
    height: auto;
    background-color: var(--color--black);
    padding: calc((80 / 1280) * 100vw) 0 calc((74.5 / 1280) * 100vw)
}
.footer__inner {
    display: flex;
    flex-direction: row-reverse;
    justify-content: flex-start;
    align-items: flex-start;
    width: calc((1100 / 1280) * 100%);
    height: auto;
    margin: 0 auto;
    position: relative
}
.footer__logo {
    width: calc((138.36 / 1280) * 100vw);
    height: auto;
    margin: 0 0 0 calc((86 / 1280) * 100vw)
}
.footer__menu {
    width: auto;
    height: auto;
    padding-top: calc((44 / 1280) * 100vw)
}
.footer__menu__list {
    display: flex;
    flex-direction: row-reverse;
    justify-content: flex-start;
    align-items: flex-start;
    column-gap: calc((63 / 1280) * 100vw);
    width: auto;
    height: auto
}
.footer__menu__list__item {
    width: auto;
    height: auto;
    -webkit-writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -ms-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    font-size: var(--24px);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .2em;
    position: relative
}
.footer__menu__list__item::before {
    font-size: var(--16px);
    font-weight: 400;
    line-height: 1;
    letter-spacing: .05em;
    color: var(--color--gray);
    position: absolute;
    top: 0;
    right: calc((20 / 1280) * -100vw);
    pointer-events: none
}
.footer__menu__list__item.top::before {
    content: 'top'
}
.footer__menu__list__item.news::before {
    content: 'news'
}
.footer__menu__list__item.store::before {
    content: 'store'
}
.footer__menu__list__item.contact::before {
    content: 'contact'
}
.footer__menu__list__item.sns::before {
    content: 'link'
}
.footer__menu__list__item a {
    color: var(--color--white)
}
.footer__copyright {
    -webkit-writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -ms-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    font-size: var(--18px);
    font-weight: 400;
    line-height: 1.333;
    letter-spacing: .05em;
    text-align: center;
    color: var(--color--white);
    white-space: nowrap;
    position: absolute;
    top: 50%;
    left: calc((9 / 1280) * -100vw);
    transform: translate(-100%, -50%)
}
.btn {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: 100%
}
.btn_diamond {
    width: calc((51 / 1280) * 100vw);
    height: auto;
    aspect-ratio: 51 / 34.91;
    position: relative
}
.btn_diamond::before {
    content: '';
    display: block;
    width: calc((6.4 / 1280) * 100vw);
    height: auto;
    aspect-ratio: 6.4 / 7.89;
    background-image: url(../image/icon-btn_arrow.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1
}
.white .btn_diamond::before {
    background-image: url(../image/icon-btn_arrow_w.svg)
}
.btn_txt {
    font-size: var(--18px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: .05em
}
#store {
    width: 100%;
    height: auto;
    background-image: url(../image/page-bg@pc.webp);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover
}
.store__inner {
	width: calc((1100 / 1280) * 100%);
    height: auto;
	padding: calc((105 / 1280) * 100vw) 0 calc((40 / 1280) * 100vw);
	margin: 0 auto;
}
.store__heading {
    width: auto;
    height: auto
}
.store__heading__txt {
    width: auto;
    height: auto;
    margin: 0 auto calc((57 / 1280) * 100vw);
    -webkit-writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -ms-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    font-size: var(--30px);
    font-weight: 500;
    line-height: 2;
    letter-spacing: .28em;
    color: var(--color--black);
    position: relative
}
.store__heading__txt::before {
    content: 'store';
    font-size: var(--16px);
    font-weight: 400;
    line-height: 1;
    letter-spacing: .05em;
    color: var(--color--gray);
    position: absolute;
    top: 0;
    right: calc((16 / 1280) * -100vw)
}
.store__list {
	display: flex;
	/* justify-content: space-between; */
    justify-content: center;
	align-items: flex-start;
	width: 100%;
    height: auto;
	margin: 0 auto;
}
.store__list__item {
    /* width: calc((510 / 1100) * 100%); */
    width: 100%;
    max-width: 800px;
    height: auto;
}
.store__list__item__map {
    width: 100%;
    height: auto;
	margin: 0 auto 46px;
	aspect-ratio: 510 / 360;
}
.store__list__item__map iframe {
    width: 100%;
    height: 100%
}
.store__list__item__details {
	width: 100%;
	height: auto;
}
.store__list__item__details__name {
    width: 100%;
    height: auto;
    padding-bottom: calc((15 / 1280) * 100vw);
    margin-bottom: calc((15 / 1280) * 100vw);
    border-bottom: solid 1px var(--color--black)
}
.store__list__item__details__name__ja {
    width: 100%;
    height: auto;
    font-size: var(--18px);
    font-weight: 400;
    line-height: 1.444;
    letter-spacing: .06em
}
.store__list__item__details__name__en {
    width: 100%;
    height: auto;
    font-size: var(--12px);
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: .08em
}
.store__list__item__details__info {
    width: 100%;
    height: auto;
	margin: 0 auto 38px;
}
.store__list__item__details__info__item {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    height: auto
}
.store__list__item__details__info__item:not(:last-of-type) {
    margin-bottom: calc((10 / 1280) * 100vw)
}
.store__list__item__details__info__item dt {
    width: calc((95 / 1280) * 100vw);
    height: auto;
    font-size: var(--12px);
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: .08em
}
.store__list__item__details__info__item dd {
    flex: 1;
    height: auto;
    font-size: var(--12px);
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: .08em
}
.store__list__item__details__info__item dd small {
    display: inline-block;
    margin-top: calc((6 / 1280) * 100vw);
    font-size: var(--10px);
    line-height: 1.4
}
.store__list__item__details__btn_wrap {
    width: calc((111.5 / 1280) * 100vw);
    height: auto;
    margin: 0 auto 0 0;
    aspect-ratio: 111.5 / 34.91
}
.store__list__item__details__btn {
    color: var(--color--black)
}
#reservation {
    width: 100%;
    height: 300px;
    overflow: hidden
}
.reservation__inner {
    width: 100%;
    height: 100%
}
.reservation__btn {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    background-color: var(--color--brown);
    position: relative
}
@media (any-hover:hover) {
    .reservation__btn {
        transition: .4s
    }
    .reservation__btn:hover {
        background-color: #33271D
    }
}
.reservation__btn::after {
    content: '';
    display: block;
    width: 100%;
    height: calc(100% + 2px);
    background-image: url(../image/logomark.webp);
    background-position: center;
    background-repeat: repeat;
    background-size: 160px 92px;
    opacity: .08;
    position: absolute;
    top: -1px;
    left: 0;
    z-index: 1
}
.reservation__btn__txt_ja {
    margin-bottom: 9px;
    font-size: 50px;
    font-weight: 400;
    line-height: 1.44;
    letter-spacing: 0em;
    color: var(--color--white);
    text-align: center;
    position: relative;
    z-index: 2
}
.reservation__btn__txt_en {
    font-size: 40px;
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0em;
    color: var(--color--white);
    text-align: center;
    position: relative;
    z-index: 2
}
@media all and (min-width:769px) {
    .tablet, .sp {
        display: none
    }
    .pc {
        display: inline-block
    }
    .view_sp {
        display: none
    }
    .view_tablet {
        display: none
    }
    .view_pc {
        display: block
    }
}
@media all and (max-width:768px) {
    .pc, .sp {
        display: none
    }
    .tablet {
        display: inline-block
    }
    .view_pc {
        display: none
    }
    .view_sp {
        display: none
    }
    .view_tablet {
        display: block
    }
    .hamburger {
        width: calc((76 / 375) * 100vw);
        height: calc((52.21 / 375) * 100vw);
        top: calc((20 / 375) * 100vw);
        right: calc((20 / 375) * 100vw)
    }
    .hbg_btn_line {
        width: calc((34 / 375) * 100vw)
    }
    .global_nav {
        height: 100dvh
    }
    .global_nav__close {
        width: calc((76 / 375) * 100vw);
        height: calc((52.21 / 375) * 100vw);
        top: calc((20 / 375) * 100vw);
        right: calc((20 / 375) * 100vw)
    }
    .global_nav__menu {
        top: calc((295 / 667) * 100%)
    }
    .global_nav__menu__list {
        column-gap: calc((30 / 375) * 100vw);
        font-size: var(--24px)
    }
    .global_nav__menu__list__item::before {
        top: calc(((24 / 375) * 100vw) * 1.2);
        right: calc((14 / 375) * -100vw)
    }
    .global_nav__copy {
        width: calc((75 / 375) * 100vw);
        bottom: calc((30 / 375) * 100vw);
        right: calc((30 / 375) * 100vw)
    }
    .global_nav__logo {
        width: calc((111.37 / 375) * 100vw);
        bottom: calc((30 / 375) * 100vw);
        left: calc((30 / 375) * 100vw);
        transform: translate(0%, 0%)
    }
    .global_nav__copyright {
        display: none
    }
    footer {
        padding: 50px 0 25px
    }
    .footer__inner {
        display: block;
        width: 100%
    }
    .footer__logo {
        width: 100px;
        margin: 0 auto 60px
    }
    .footer__menu {
        display: flex;
        justify-content: center;
        padding-top: 0;
        margin: 0 auto 94px
    }
    .footer__menu__list {
        column-gap: 20px
    }
    .footer__menu__list__item {
        padding-right: 18px;
        font-size: 20px
    }
    .footer__menu__list__item::before {
        font-size: 14px;
        right: 0
    }
    .footer__copyright {
        -webkit-writing-mode: initial;
        -moz-writing-mode: initial;
        -ms-writing-mode: initial;
        -ms-writing-mode: initial;
        writing-mode: initial;
        font-size: var(--12px);
        text-align: center;
        position: initial;
        transform: initial
    }
    .btn_diamond {
        width: 51px;
        aspect-ratio: 51 / 34.91
    }
    .btn_diamond::before {
        width: 5.25px;
        aspect-ratio: 5.25 / 6.32
    }
    .btn_txt {
        font-size: 18px
    }
    #store {
        background-image: url(../image/page-bg@sp.webp)
    }
	.store__inner {
		width: 100%;
		padding: 50px 0 0;
	}
    .store__heading__txt {
        margin: 0 auto 30px;
        font-size: 24px
    }
    .store__heading__txt::before {
        font-size: 12px;
        right: -10px
    }
	.store__list {
		flex-direction: column;
		justify-content: flex-start;
		align-items: center;
		gap: 60px;
	}
	.store__list__item {
		display: flex;
		flex-direction: column;
		width: 100%;
	}
	.store__list__item__map {
		margin: 50px auto 0;
		aspect-ratio: 1 / 1;
		order: 3;
	}
	.store__list__item__details {
		width: calc((315 / 375) * 100vw);
		margin: 0 auto;
		order: 1;
	}
	.store__list__item__details__name {
        padding-bottom: 16px;
        margin-bottom: 16px
	}
	.store__list__item__details__name__ja {
		font-size: 18px
	}
	.store__list__item__details__name__en {
		font-size: 12px
	}
	.store__list__item__details__info {
		width: 100%;
		height: auto;
		margin: 0 auto 30px;
	}
	.store__list__item__details__info__item {
		display: flex;
		justify-content: flex-start;
		align-items: flex-start;
		width: 100%;
		height: auto
	}
	.store__list__item__details__info__item:not(:last-of-type) {
		margin-bottom: 10px
	}
    .store__list__item__details__info__item dt {
        width: 112px;
        font-size: 12px
    }
    .store__list__item__details__info__item dd {
        font-size: 12px
    }
	.store__list__item__details__info__item dd small {
        display: inline-block;
        margin-top: 6px;
        font-size: 10px
	}
	.store__list__item__details__btn_wrap {
        width: 111.5px;
        aspect-ratio: 111.5 / 34.91;
        margin: 0 auto;
		order: 2;
    }
	.store__list__item__details__btn {
		color: var(--color--black)
	}
    #reservation {
        height: 180px
    }
    .reservation__btn::after {
        background-size: 80px 46px
    }
    .reservation__btn__txt_ja {
        margin-bottom: 4px;
        font-size: 32px
    }
    .reservation__btn__txt_en {
        font-size: 16px
    }
}
@media all and (max-width:575px) {
    .pc, .tablet {
        display: none
    }
    .sp {
        display: inline-block
    }
    .view_pc {
        display: none
    }
    .view_tablet {
        display: none
    }
    .view_sp {
        display: block
    }
}