@charset "UTF-8";
/* ==========================================================================
   Setting
========================================================================== */ :root {
    --white: #FFF;
    --l-gray: #F7F7F7;
    --l-gray2: #F4F4F4;
    --gray: #9E9E9E;
    --d-gray: #5D5D5D;
    --dd-gray: #231F20;
    --black: #000;
    --border1: #DDD;
    --border2: #BFBFBF;
    --color1: #447473;
    --color1-h: #366766;
    --color2: #34877F;
    --color2-h: #22726A;
    --red: #DB3636;
    --font1: "Cormorant Garamond", serif;
    --font2: "Libre Baskerville", serif;
    --font3: "EB Garamond", serif;
    --mincho: "Noto Serif JP", serif;
}
/* ==========================================================================
   Loading
========================================================================== */
body #container::before {
    content: "";
    width: 100%;
    height: 100%;
    background: var(--l-gray2) url(../img/loading.svg) no-repeat center center / 5em;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 994;
    transition: 1s cubic-bezier(0.39, 0.575, 0.565, 1);
}
body.loaded #container::before {
    opacity: 0;
    pointer-events: none;
}
@keyframes fadein {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
/*  Animation
================ */
.iv {
    opacity: 0;
    filter: blur(1.5em);
    transform: translateY(2em);
    transition: .8s ease-out;
    transition-property: opacity, filter, transform;
}
.iv.show {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0);
}
@keyframes fadeinup {
    0% {
        opacity: 0;
        filter: blur(1.5em);
        transform: translateY(2em);
    }
    100% {
        opacity: 1;
        filter: blur(0);
        transform: translateY(0);
    }
}
/* ==========================================================================
   Base
========================================================================== */
html {
    font-family: var(--mincho);
    font-size: 81.3%;
    font-weight: 400;
    line-height: 2.15;
    letter-spacing: .05em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}
@media (max-width: 374px) {
    html {
        font-size: 3.466vw;
    }
}
body {
    color: var(--black);
}
body.navOpen {
    height: 100%;
    overflow: hidden;
}
@media (min-width: 992px) {
    body.pagegroup__basic.navOpen, body.pagegroup__restaurant.navOpen {
        height: auto;
        overflow: auto;
    }
}
#inner-content {
    padding-top: 5.385rem;
    padding-bottom: 5rem;
}
#mv + #inner-content {
    padding-top: 0;
}
@media (min-width: 992px) {
    #inner-content {
        padding-top: 6.153rem;
        padding-bottom: 6.5rem;
    }
}
#content, #content ~ * {
    position: relative;
    z-index: 2;
}
#main-content {
    position: relative;
    z-index: 2;
}
@media (max-width: 991px) {
    ._pc {
        display: none !important;
    }
}
@media (min-width: 992px) {
    ._sp {
        display: none !important;
    }
}
/* ==========================================================================
   Header
========================================================================== */
#siteHeader {
    color: var(--black);
    height: 6.77rem;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 990;
    transition: opacity 1s cubic-bezier(0.16, 1, 0.3, 1), height .6s cubic-bezier(0.16, 1, 0.3, 1);
}
#siteHeader.standby {
    opacity: 0;
}
#siteHeader:has(.gNav.on), #siteHeader.fixed {
    height: 5.385rem;
    position: fixed;
}
#siteHeader:has(.on) {
    position: fixed !important;
    opacity: 1 !important;
}
#siteHeader::before {
    content: '';
    background: var(--white);
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    transform: translateY(-101%);
    transition: transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}
#siteHeader.fixed::before {
    transform: translateY(0);
}
body:has(#mv) #siteHeader:not(.fixed) {
    color: var(--white);
}
body:has(#mv) #siteHeader:not(.fixed)::after {
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background: currentColor;
    opacity: .2;
    position: absolute;
    bottom: 0;
}
@media (min-width: 992px) {
    #siteHeader {
        height: 7.692rem;
    }
    #siteHeader.fixed {
        height: 6.153rem;
    }
}
.inner-header {
    height: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    position: relative;
}
.header-l {
    position: relative;
    z-index: 6;
}
.header-logo {
    display: flex;
    align-items: center;
    height: 100%;
    margin: 0;
    padding: 0 7vw;
    line-height: 1;
    position: relative;
}
.header-logo .logo__inner {
    display: block;
    width: 18em;
    color: inherit;
    transition: none;
}
.header-logo .logo__inner img {
    display: inline-block;
    vertical-align: middle;
    width: 100%;
    height: 100%;
    object-fit: contain;
}
body:has(#mv):not(.gNavOpen) #siteHeader:not(.fixed) .header-logo .logo__inner {
    background: url(../img/logo-w.svg) no-repeat center center / contain;
}
body:has(#mv):not(.gNavOpen) #siteHeader:not(.fixed) .header-logo .logo__inner img {
    visibility: hidden;
}
.header-r {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: 100%;
    position: relative;
    z-index: 5;
}
@media (min-width: 576px) {
    .header-logo {
        padding: 0 1.75rem;
    }
}
@media (min-width: 992px) {
    .inner-header {
        font-size: min(1rem, 1.1vw);
        padding: 0 min(3rem, 2.25vw);
    }
    .header-logo {
        padding: 0 1.125rem;
    }
    .header-r {
        flex-basis: 100%;
    }
}
/* ==========================================================================
   Navigation
========================================================================== */
nav ul {
    display: flex;
    flex-direction: row;
    border-bottom: 0;
    margin: 0;
}
nav ul li {
    position: relative;
}
nav ul li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .75em;
    color: inherit;
    text-decoration: none;
    line-height: 1.5;
    position: relative;
    text-decoration: none;
}
nav ul li a span {
    display: block;
}
nav ul li a svg {
    display: inline-block;
    width: .8077em;
    height: .8077em;
    object-fit: contain;
}
nav ul li a:hover {
    opacity: 0.5;
}
.navBar ul li a {
    padding: 1rem 1.125rem;
}
ul.sns-nav {
    font-family: var(--font1);
    margin-top: 1em;
}
ul.sns-nav li a {
    display: inline-flex;
    gap: .75em;
    padding: .5em 0;
    align-items: center;
}
ul.sns-nav li a svg {
    width: 1.5em;
    height: 1.5em;
}
@media (max-width: 991px) {
    .navBar ul {
        margin-bottom: 2rem;
        flex-direction: column;
    }
    ul.main-nav li:first-child::before, ul.main-nav li::after, ul.main-nav li.has-children > a::after {
        content: '';
        display: block;
        width: 100%;
        height: 1px;
        background: currentColor;
        opacity: .1;
        position: absolute;
        bottom: 0;
    }
    ul.main-nav li:first-child::before {
        top: 0;
    }
    ul.main-nav li a {
        padding: 1.125em 0;
    }
    ul.main-nav li a::before {
        content: '';
        display: block;
        width: 12px;
        height: 12px;
        position: absolute;
        right: 1.25em;
        background-repeat: no-repeat;
        background-position: right center;
        background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2012%208%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%20stroke%3D%22%23447473%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%3Cpath%20d%3D%22m.5%204h11%22%2F%3E%3Cpath%20d%3D%22m8%207.5%203.5-3.5-3.5-3.5%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E');
        background-size: contain;
    }
    #siteFooter ul.main-nav li a::before {
        background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2012%208%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%20stroke%3D%22%23FFF%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%3Cpath%20d%3D%22m.5%204h11%22%2F%3E%3Cpath%20d%3D%22m8%207.5%203.5-3.5-3.5-3.5%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E');
    }
    ul.main-nav .sub-manu {
        padding: 0 0 0 1.5em;
    }
    ul.main-nav .sub-manu ul {
        margin-bottom: 0;
    }
    ul.main-nav .sub-manu ul li:first-child::before, ul.main-nav .sub-manu ul li:last-child::after {
        display: none;
    }
    ul.sub-nav li a {
        padding: .75em 0;
    }
}
@media (min-width: 992px) {
    .navBar ul {
        justify-content: flex-end;
    }
}
.gNav__inner {
    display: flex;
    width: 100%;
    height: 100%;
}
.gNav nav {
    display: flex;
    width: 100%;
}
/* ==========================================================================
   PC Navigation
========================================================================== */
@media (min-width: 992px) {
    .gNav {
        flex: 1 1 100%;
        max-width: 100%;
        height: 100%;
        position: relative;
        z-index: 5;
        display: block !important;
    }
    .gNav nav {
        justify-content: flex-end;
    }
    .gNav ul.main-nav, .gNav ul.main-nav li {
        height: 100%;
        align-items: center;
    }
    .gNav ul.main-nav li a {
        display: flex;
        height: 100%;
        align-items: center;
        white-space: nowrap;
    }
    .gNav .navBar_inner {
        display: flex;
        align-items: center;
        height: 100%;
    }
    .gNav ul.main-nav .sub-manu {
        min-width: 100%;
        background: rgba(255, 255, 255, .1);
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translate(-50%, -1em);
        opacity: 0;
        pointer-events: none;
        transition: .4s;
        transition-property: transform, opacity;
    }
    #siteHeader.fixed .gNav ul.main-nav .sub-manu {
        background: rgba(255, 255, 255, 1);
    }
    .gNav ul.main-nav li:hover .sub-manu {
        transform: translate(-50%, 0);
        opacity: 1;
        pointer-events: auto;
    }
    .gNav ul.main-nav .sub-manu ul {
        display: block;
    }
    .nav-btn {
        display: none;
    }
}
/* ==========================================================================
   SP Navigation
========================================================================== */
@media (max-width: 991px) {
    .gNav__inner {
        width: 100%;
        background: var(--white);
        color: var(--black);
        position: fixed;
        top: 0;
        bottom: 0;
        right: 0;
        padding-top: 7rem;
        opacity: 0;
        pointer-events: none;
        transition: opacity .6s cubic-bezier(0.19, 1, 0.22, 1);
    }
    .gNav nav {
        flex-direction: column;
        justify-content: flex-start;
    }
    .gNav .navBar_inner {
        height: 100%;
        overflow-y: auto;
        padding: 0 1.5em;
    }
    .gNav ul.main-nav li:first-child::before {
        display: none;
    }
    .gNav__bottom {
        border-top: 1px solid rgba(0, 0, 0, .1);
    }
    /* OPEN */
    .gNav.on {
        display: block;
    }
    .gNav.on .gNav__inner {
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }
    /* Nav Btn */
    .nav-btn {
        background: transparent;
        color: inherit;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        width: 5.385rem;
        height: 5.385rem;
        position: absolute;
        top: 9px;
        right: 0;
        z-index: 999;
        cursor: pointer;
    }
    #siteHeader:has(.gNav.on) .nav-btn, #siteHeader.fixed .nav-btn {
        top: 0;
    }
    .nav-btn i {
        display: block;
        background: currentColor;
        width: 35%;
        height: 1px;
        position: absolute;
        right: 0;
        left: 0;
        margin: -.5px auto 0;
        transition: transform .2s, top .2s .2s;
    }
    .nav-btn i:nth-of-type(1) {
        top: 50%;
    }
    .nav-btn i:nth-of-type(2) {
        top: calc(50% - 7px);
    }
    .nav-btn i:nth-of-type(3) {
        top: calc(50% + 7px);
    }
    .gNav.on .nav-btn {
        position: fixed;
        color: var(--black);
    }
    .gNav.on .nav-btn i {
        transition: transform .2s .2s, top .2s;
    }
    .gNav.on .nav-btn i:nth-of-type(1) {
        transform: scaleX(0);
    }
    .gNav.on .nav-btn i:nth-of-type(2) {
        top: 50%;
        transform: rotate(45deg);
    }
    .gNav.on .nav-btn i:nth-of-type(3) {
        top: 50%;
        transform: rotate(-45deg);
    }
    .gNav.on .nav-btn::after {
        opacity: 0;
    }
}
/* ==========================================================================
   Book Navigation
========================================================================== */
.bookNav {
    width: 100%;
    position: fixed !important;
    right: 0;
    bottom: 0;
    z-index: 666 !important;
}
.bookNav__inner {
    display: block;
    width: 100%;
    background: var(--white);
    padding: 4.286rem 0 7.286rem;
    position: fixed;
    right: 0;
    bottom: 0;
    opacity: 0;
    transform: translateY(10vh);
    pointer-events: none;
    transition: opacity .4s cubic-bezier(0.19, 1, 0.22, 1), transform .4s cubic-bezier(0.19, 1, 0.22, 1);
}
.bookNav .book-close {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 3em;
    height: 3em;
    font-size: 1.5em;
    cursor: pointer;
    position: absolute;
    top: 0;
    right: 0;
}
.bookNav.on .bookNav__inner {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
.bookNav__buttons {
    display: flex;
}
.book-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--color1);
    color: var(--white);
    letter-spacing: .01em;
    white-space: nowrap;
    width: 100%;
    height: 4.75rem;
    padding: 0 5%;
    cursor: pointer;
}
.restaurant_book-btn {
    margin: 0 auto;
    width: 86vw;
    background: var(--color2);
}
.bookNav__buttons .book-btn:last-child {
    background: var(--color2);
}
.book-btn > * {
    transition: opacity .2s;
}
.book-btn:hover > * {
    opacity: .5;
}
#book-widget {
    display: block;
}
@media (min-width: 576px) {
    .bookNav {
        width: auto;
    }
    .book-btn {
        width: 16rem;
        height: 4.75rem;
        padding: 0 2.25rem;
    }
    .bookNav__inner {
        padding: 3rem 0;
    }
    #book-widget {
        margin: 0 auto;
        display: flex;
        justify-content: center;
        align-items: center;
    }
}
/* ==========================================================================
   Information
========================================================================== */
.information {
    padding: 2.5rem 0;
}
.information p {
    margin: .6em 0;
    line-height: 1.65;
}
.information p a {
    display: inline-block;
}
/* ==========================================================================
   Sidebar
========================================================================== */
.sidebar .side_ttl {
    font-family: var(--font1);
    line-height: 1.25;
    letter-spacing: .05em;
    margin-bottom: .75em;
}
.sidebar ul li a {
    display: block;
    padding: .5em 0;
}
.sidebar ul li a:hover {
    opacity: .5;
}
@media (max-width: 991px) {
    .content:has(.sidebar-sticky .sp-acc) {
        margin: .5rem 0;
    }
}
@media (min-width: 992px) {
    .sidebar-sticky {
        position: sticky;
        top: 100px;
    }
    .sidebar .side_box {
        margin-bottom: 3rem;
    }
}

/* ==========================================================================
   Group Link
========================================================================== */
.footer-group-links {
    background-color: var(--l-gray);
    overflow: hidden;
}
ul.group-links li {
    margin: .375rem 0;
}
ul.group-links li a {
    display: block;
}
ul.group-links li:last-child {
    border-right: 0!important;
}
@media (max-width: 767px) {
    ul.group-links {
        margin: 0;
    }
    ul.group-links li {
        padding: 0;
    }
}
@media (max-width: 575px) {
    ul.group-links li:nth-of-type(odd) {
        border-right: 1px solid var(--border1);
    }
}
@media (min-width: 576px) and (max-width: 991px) {
    ul.group-links li:nth-of-type(3n - 1),
    ul.group-links li:nth-of-type(3n + 1) {
        border-right: 1px solid var(--border1);
    }
}
@media (min-width: 992px) {
    ul.group-links li {
        border-right: 1px solid var(--border1);
    }
}

/* ==========================================================================
   Footer
========================================================================== */
#siteFooter {
    background-color: var(--color1);
    color: var(--white);
    clear: both;
    overflow: hidden;
    padding: 3.5rem 0;
}
#siteFooter .inner-footer {
    padding: 3.5rem 0 .5rem;
}
#siteFooter a:hover {
    opacity: 0.5;
}
#siteFooter .footer-bottom {
    font-size: .857em;
    padding: 0 0 3.5rem;
}
#siteFooter .copyright p {
    margin-top: 0;
}
@media (min-width: 992px) {
    #siteFooter {
        font-size: min(1rem, 1.1vw);
        padding: 5rem 0;
    }
    #siteFooter .inner-footer {
        padding: 4rem 0;
    }
    #siteFooter .information {
        padding-bottom: 0;
    }
    .fNav, .fNav .fNav__inner, .fNav .fNav__inner nav {
        height: 100%;
    }
    .fNav {
        max-width: 48em;
        margin-left: auto;
    }
    .fNav .navBar_inner {
        height: 100%;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }
    .fNav nav ul {
        flex-wrap: wrap;
    }
    .fNav ul.main-nav .sub-manu {
        display: none !important;
    }
    #siteFooter .footer-bottom {
        text-align: center;
        border-top: 1px solid rgba(255, 255, 255, .1);
        padding: 2rem 0 4rem;
    }
}