@charset "UTF-8";
:root{
  --border-color:#000;
  --list-line:#9c9c9c;
}

.retty-menu{
  width: min(100%,90rem);
  margin-inline: auto;
}

/* 以下RETTYより */
.content:nth-child(n+2) {
    margin-top: 40px
}

.content__title {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding: 0 0 12px;
    border-bottom: 2px solid var(--border-color);
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 2rem;

}

.content__title+* {
    margin-top: 20px
}

.content__title--sub {
    color: #2e2e3b;
    font-size: 1.8rem;
    font-weight: 700
}

.content__title--sub:nth-child(n+2) {
    margin-top: 40px
}

.content__title--sub+* {
    margin-top: 20px
}

.content__title--small {
    font-size: 1.6rem;
    font-weight: 400
}

.content__title--small:nth-child(n+2) {
    margin-top: 20px
}

.content__title--no-border {
    padding: 0;
    border: 0
}

.content__title--no-border+* {
    margin-top: 12px
}

.content__title-supplement {
    color: #62626c;
    font-size: 1.4rem;
    font-weight: 400
}



.restaurant-top-banner__inner {
    display: flex;
    justify-content: center;
    line-height: 0
}

.restaurant-top-banner__image {
    width: 1140px;
    height: 80px
}

.restaurant-top-banner+.restaurant-summary {
    margin-top: 10px
}

.content-columns {
    display: flex;
    justify-content: space-between
}

.content-columns:nth-child(n+2) {
    margin-top: 16px
}

.content-columns__item--sidebar {
    flex-basis: 300px
}

.content-columns__item--restaurants {
    min-width: 0;
    flex-basis: 788px
}

.navigation {
    padding: 30px 10px 0
}

.restaurant-detail__header {
    padding: 20px 10px 0
}

.restaurant-detail__navigation {
    position: relative;
    z-index: 80;
    width: 100%;
    min-width: 1140px;
    box-sizing: border-box;
    padding: 0 10px;
    background-color: #f4f4f5;
    transition: box-shadow .6s ease-out
}

.restaurant-detail__navigation:nth-child(n+2) {
    margin-top: 20px
}

.restaurant-detail__navigation[data-stuck=true] {
    padding: 0;
    box-shadow: 0 2px 2px 0 rgba(0,0,0,.2)
}

.restaurant-detail__content {
    padding: 24px 10px 0
}

.restaurant-detail__supplement {
    color: #2e2e3b;
    font-size: 1.4rem
}

.restaurant-detail__supplement:nth-child(n+2) {
    margin-top: 32px
}

.restaurant-detail__information:nth-child(n+2) {
    margin-top: 84px
}

.restaurant-detail__listing-info {
    color: #62626c
}

.restaurant-detail__listing-info:nth-child(n+2) {
    margin-top: 16px
}

.restaurant-detail__report-list>li:first-child {
    border-top: 0
}

.restaurant-detail__report-list:nth-child(n+2) {
    margin-top: 16px
}

.restaurant-detail__report {
    padding-top: 0
}

.restaurant-detail__report:nth-child(n+2) {
    margin-top: 24px
}

.restaurant-detail__menu:nth-child(n+2) {
    margin-top: 0
}

.restaurant-detail__tab-content {
    padding-top: 216px;
    margin-top: -216px
}

.restaurant-detail__tab-content:nth-child(n+2) {
    margin-top: -184px
}

.restaurant-detail__reservation {
    display: flex;
    justify-content: space-around
}

.restaurant-detail__reservation:nth-child(n+2) {
    margin-top: 32px
}

.restaurant-detail__course-info:nth-child(n+2) {
    margin-top: 24px
}

.restaurant-detail__reservation-button {
    width: 264px;
    padding: 16px 0
}

.restaurant-detail__map {
    height: 512px
}

.restaurant-detail__footer {
    margin-top: 32px;
    text-align: right
}

.restaurant-summary {
    display: flex;
    align-items: flex-start
}

.restaurant-summary hr {
    align-self: stretch;
    border: 1px solid var(--border-color);
    border-width: 1px 0 0;
    margin: 0
}

.restaurant-summary__inner {
    flex: 1 0 0%
}

.restaurant-summary__content {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.restaurant-summary__name {
    display: inline-block
}

.restaurant-summary__label {
    display: inline-block;
    margin-left: 6px;
    margin-bottom: -1px;
    vertical-align: text-bottom
}

.restaurant-summary__display-name {
    display: inline;
    color: #2e2e3b;
    font-size: 2.6rem;
    font-weight: 700;
    line-height: 1.4
}

.restaurant-summary__kana-name {
    flex: 0 0 auto;
    margin-bottom: 4px;
    color: #62626c;
    font-size: 1.4rem;
    line-height: 1.2;
    text-align: left
}

.restaurant-summary__topuser-catchtopy {
    color: #c19129;
    font-weight: 700
}

.restaurant-summary__information {
    width: 636px;
    flex-shrink: 0
}

.restaurant-summary__readmore-list {
    display: flex;
    justify-content: flex-end
}

.restaurant-summary__readmore-item {
    cursor: pointer;
    display: flex;
    flex-shrink: 0;
    align-items: center;
    padding: 2px;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1
}

.restaurant-summary__readmore-item i {
    position: relative;
    left: 0;
    display: inline-block;
    width: 8px;
    height: 8px;
    margin-left: 5.3333333333px;
    transform: rotate(135deg)
}

.restaurant-summary__readmore-item i:after,.restaurant-summary__readmore-item i:before {
    position: absolute;
    top: 0;
    left: 0;
    background-color: #2d88d9;
    border-radius: 2px;
    content: "";
    transition: all .6s ease-out;
    vertical-align: sub
}

.restaurant-summary__readmore-item i:before {
    width: 100%;
    height: 2px
}

.restaurant-summary__readmore-item i:after {
    width: 2px;
    height: 100%
}

.restaurant-summary__readmore-item i {
    transform: translateY(-25%) rotate(225deg)
}

.restaurant-summary__readmore-item:hover {
    opacity: .8
}

.restaurant-summary__readmore-item i {
    margin-left: 8px
}

.restaurant-summary__readmore-item:nth-child(n+2) {
    margin-left: 16px
}

.restaurant-summary__readmore-link {
    color: #2d88d9
}

.restaurant-summary__actions {
    width: 384px
}

.restaurant-summary__actions:nth-child(n+2) {
    margin-left: 56px
}

.restaurant-summary-labels {
    display: flex;
    flex-wrap: wrap
}

.restaurant-summary-labels__item {
    position: relative;
    display: flex;
    height: 24px;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
    padding: 6px 17px 6px 8px;
    border: 1px solid;
    border-radius: 3px;
    font-weight: 700;
    font-size: 1.1rem;
    line-height: 1
}

.restaurant-summary-labels__item:after {
    position: absolute;
    top: 50%;
    right: 8px;
    width: 6px;
    height: 6px;
    border-top: 2px solid;
    border-right: 2px solid;
    content: "";
    transform: translateY(-50%)
}

.restaurant-summary-labels__item--primary {
    border-color: var(--border-color);
    color: #2e2e3b
}

.restaurant-summary-labels__item--primary:after {
    border-color: var(--border-color);
    transform: translateY(-50%) rotate(45deg)
}

.restaurant-summary-labels__item--primary:before {
    display: inline-block;
    content: "";
    width: 12px;
    height: 12px;
    padding-right: 4px;
    margin-right: 4px;
    border-right: 1px solid var(--border-color);
    background-image: url("https://assets.retty.me/v-202604161413-ab0f6e8c1c9832ee668873d78dfec1a026a5b0ba/images/pancake/ic_paypay.svg");
    background-size: contain;
    background-repeat: no-repeat
}

.restaurant-summary-labels__item--hygiene-measure {
    padding-right: 21px;
    border-color: var(--border-color);
    color: #62626c
}

.restaurant-summary-labels__item--hygiene-measure:after {
    border-color: #8c8c93;
    transform: translateY(-60%) rotate(135deg)
}

.speciality-label-list-skeleton {
    min-height: 30px
}

.recommended-users {
    display: flex;
    align-items: center
}

.recommended-users:nth-child(n+2) {
    margin-top: 10px
}

.recommended-users__photos {
    display: inline-flex;
    flex-shrink: 0
}

.recommended-users__item {
    overflow: hidden;
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    border-radius: 50%
}

.recommended-users__item:nth-child(n+2) {
    margin-left: 2px
}

.recommended-users__item a {
    display: block
}

.recommended-users__item img {
    width: 100%;
    height: 100%
}

.recommended-users__description .styled-link,.recommended-users__description:nth-child(n+2) {
    margin-left: 8px
}

.recommended-users__count {
    color: #62626c;
    font-size: 1.3rem;
    font-weight: 700
}

.restaurant-status {
    display: flex;
    flex-wrap: wrap
}

.restaurant-status__label-list {
    margin-top: -8px;
    margin-left: -16px
}

.restaurant-status__label-item {
    display: inline-block;
    flex: 0 0 auto;
    margin-top: 8px;
    margin-left: 16px
}

.restaurant-status__link {
    display: inline;
    margin-top: 8px;
    font-size: 1.1rem
}

.restaurant-status__link:nth-child(n+2) {
    margin-left: 16px
}

.restaurant-status__links {
    display: block;
    font-size: 1.1rem
}

.restaurant-status__links:nth-child(n+2) {
    margin-top: 8px
}

.restaurant-status__description {
    display: inline;
    color: #d70025;
    font-size: 1.4rem;
    line-height: 1.4
}

.restaurant-status__description:nth-child(n+2) {
    margin-left: 8px
}

@keyframes show-sticky-restaurant-actions {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.restaurant-actions {
    z-index: 90;
    box-sizing: border-box;
    background-color: transparent
}

.restaurant-actions-box {
    display: grid;
    background-color: #f4f4f5;
    border-radius: 4px;
    padding: 16px 12px
}

.restaurant-actions-box--prepare-stuck {
    transition: box-shadow .6s ease-out;
    box-shadow: 0 2px 2px 0 rgba(0,0,0,.2)
}

.restaurant-actions-box--summary {
    margin-top: -10px
}

.restaurant-actions-box__content {
    display: grid;
    row-gap: 6px;
    margin-top: 12px
}

.restaurant-actions-box__reservation {
    padding: 15px 0;
    font-weight: 700;
    line-height: 1;
    font-size: 1.6rem;
    border-radius: 4px
}

.restaurant-actions-box__reservation:before {
    content: "\F123";
    margin: -2px 8px 0 0;
    font-size: 24px
}

.restaurant-actions-box__telephone {
    display: flex;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
    padding: 8px 0;
    background-color: #fff;
    border-radius: 4px;
    column-gap: 4px;
    line-height: 1;
    font-size: 1.8rem
}

.restaurant-actions-box__telephone i {
    display: flex;
    width: 20px;
    height: 20px;
    color: #2e2e3b
}

.restaurant-actions-box__telephone i:before {
    content: "\F174";
    font-size: 20px;
    vertical-align: text-bottom
}

.restaurant-actions-box__tel-number {
    color: #62626c;
    font-weight: 700
}

.restaurant-actions-box__sub-actions {
    margin-top: 8px
}

.restaurant-actions-box__reservation~.restaurant-actions-box__telephone {
    margin-top: 12px;
    padding: 0;
    background-color: unset
}

.restaurant-actions-box__reservation~.restaurant-actions-box__sub-actions {
    margin-top: 16px
}

.restaurant-actions-box__title {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.4;
    color: #2e2e3b
}

.reservation-speech-balloon {
    position: relative;
    box-sizing: border-box;
    display: flex;
    text-align: center;
    width: fit-content;
    padding: 8px 24px;
    margin: 0 auto;
    font-weight: 700;
    border-radius: 4px;
    background-color: #2e2e3b;
    color: #fff;
    line-height: 1.4;
    z-index: 1
}

.reservation-speech-balloon:after {
    position: absolute;
    right: 0;
    bottom: -10px;
    left: 0;
    width: 0;
    height: 0;
    border-width: 10px 10px 0;
    border-style: solid;
    border-color: #2e2e3b transparent transparent;
    margin: auto;
    content: ""
}

.reservation-speech-balloon--emphasis {
    color: #ffc814;
    font-style: normal
}

.reservation-speech-balloon--today-dinner-availability:before {
    content: "\F165";
    font-size: 1.8rem;
    line-height: 1.3;
    color: #ffc814;
    vertical-align: middle
}

.restaurant-navigation-bar {
    display: flex;
    background-color: #f4f4f5
}

.restaurant-navigation-bar__item {
    position: relative;
    box-sizing: border-box;
    flex: 0 0 190px;
    color: #62626c
}

.restaurant-navigation-bar__item:nth-child(n+2) .restaurant-navigation-bar__link>span {
    border-left: 1px solid #8c8c93
}

.restaurant-navigation-bar__item--active:after {
    position: absolute;
    bottom: 0;
    display: block;
    width: 190px;
    height: 3px;
    background-color: #ffa014;
    content: ""
}

.restaurant-navigation-bar__item--disabled {
    color: #8c8c93;
    font-weight: 400;
    pointer-events: none
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:first-of-type:hover .restaurant-navigation-bar__child-nav {
    max-height: 500px
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:first-of-type:hover .restaurant-navigation-bar__child-nav>ul {
    transform: translateY(0)
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(2):hover .restaurant-navigation-bar__child-nav {
    max-height: 500px
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(2):hover .restaurant-navigation-bar__child-nav>ul {
    transform: translateY(0)
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(3):hover .restaurant-navigation-bar__child-nav {
    max-height: 500px
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(3):hover .restaurant-navigation-bar__child-nav>ul {
    transform: translateY(0)
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(4):hover .restaurant-navigation-bar__child-nav {
    max-height: 500px
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(4):hover .restaurant-navigation-bar__child-nav>ul {
    transform: translateY(0)
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(5):hover .restaurant-navigation-bar__child-nav {
    max-height: 500px
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(5):hover .restaurant-navigation-bar__child-nav>ul {
    transform: translateY(0)
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(6):hover .restaurant-navigation-bar__child-nav {
    max-height: 500px
}

.restaurant-navigation-bar .restaurant-navigation-bar__item:nth-of-type(6):hover .restaurant-navigation-bar__child-nav>ul {
    transform: translateY(0)
}

.restaurant-navigation-bar__link {
    cursor: pointer;
    display: flex;
    padding: 16px 0;
    color: inherit;
    font-size: 1.3rem;
    font-weight: 700
}

.restaurant-navigation-bar__link:hover {
    opacity: .8
}

.restaurant-navigation-bar__link>span {
    display: inline-block;
    width: 100%;
    box-sizing: border-box;
    padding: 4px 8px;
    text-align: center
}

.restaurant-navigation-bar--item--active .restaurant-navigation-bar__link {
    font-weight: 700
}

.restaurant-navigation-bar__child-nav {
    position: absolute;
    top: 100%;
    overflow: hidden;
    width: 190px;
    max-height: 0;
    padding: 0 6px 6px;
    transform: translateX(-6px);
    transition: max-height .5s ease .2s
}

.restaurant-navigation-bar__item:hover .restaurant-navigation-bar__child-nav {
    transition-delay: 0s;
    transition-duration: .2s
}

.restaurant-navigation-bar__child-nav>ul {
    transform: translateY(-100%);
    transition: transform .5s ease .2s,box-shadow .6s ease-out
}

.restaurant-navigation-bar__item:hover .restaurant-navigation-bar__child-nav>ul {
    transition: transform .2s ease 0s,box-shadow .6s ease-out
}

[data-stuck=true] .restaurant-navigation-bar__item:hover .restaurant-navigation-bar__child-nav>ul {
    box-shadow: 0 2px 2px 0 rgba(0,0,0,.2)
}

.restaurant-navigation-bar__child-item>a {
    display: block;
    box-sizing: border-box;
    padding: 16px 30px;
    border-right: 1px solid var(--border-color);
    border-left: 1px solid var(--border-color);
    background-color: #fff;
    color: #2d88d9
}

.restaurant-navigation-bar__child-item>a:hover {
    background-color: #fafafa
}

.restaurant-navigation-bar__child-item:nth-child(n+2)>a {
    border-top: 1px dashed var(--border-color)
}

.restaurant-navigation-bar__child-item:last-child>a {
    border-bottom: 1px solid var(--border-color)
}

.restaurant-navigation-bar__child-item--disabled>a {
    color: #8c8c93;
    pointer-events: none
}

.restaurant-navigation-bar__label {
    margin-left: 4px;
    font-size: 1.2rem
}

.restaurant-info-heading {
    display: flex;
    align-items: center;
    padding: 0 0 12px;
    border-bottom: 1px solid var(--border-color)
}

.restaurant-info-heading__title {
    color: #2e2e3b;
    font-size: 2rem;
    font-weight: 700
}

.restaurant-info-heading__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    appearance: none;
    border-radius: 2px;
    cursor: pointer;
    outline: 0;
    text-align: center;
    transition: all .3s ease-out;
    border: 1px solid #62626c;
    background-color: #fff;
    color: #62626c;
    flex-shrink: 0;
    padding: 4px 14px;
    margin-left: auto;
    font-size: 1.4rem;
    font-weight: 400
}

.restaurant-info-heading__button--fill-parent {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 6px 0
}

.restaurant-info-heading__button--rounder {
    border-radius: 4px
}

.restaurant-info-heading__button:hover {
    background-color: #62626c;
    color: #fff
}

.restaurant-info-heading__button:before {
    content: "\F127";
    margin: 0 4px -2px 0;
    color: #62626c;
    font-size: 13px;
    transition: all .3s ease-out
}

.restaurant-info-heading__button:hover:before {
    color: #fff
}

.restaurant-info-heading+.content {
    margin-top: 20px
}

.restaurant-info-table__detail-list {
    display: flex;
    flex-wrap: wrap
}

.restaurant-info-table__detail-list li {
    flex-shrink: 0
}

.restaurant-info-table__detail-list li:not(:last-child):after {
    content: "\3001"
}

.restaurant-info-table__budgets>dt {
    display: inline-block
}

.restaurant-info-table__budgets>dt:after {
    content: "\FF1A"
}

.restaurant-info-table__budgets>dd {
    display: inline
}

.restaurant-info-table__budgets>dd:after {
    display: block;
    width: 100%;
    content: ""
}

.credit-card-list {
    display: flex
}

.credit-card-list__item {
    display: flex;
    flex: 0 1 90px;
    flex-direction: column;
    align-items: center;
    font-size: 1.2rem
}

.credit-card-list__item:before {
    display: block;
    height: 36px;
    margin-bottom: 4px
}

.credit-card-list__item:nth-child(n+2) {
    margin-left: 20px
}

.credit-card-list__item--visa:before {
    width: 57px;
    content: url("https://assets.retty.me/v-202604161413-ab0f6e8c1c9832ee668873d78dfec1a026a5b0ba/images/pancake/ic_visa.svg")
}

.credit-card-list__item--mastercard:before {
    width: 44px;
    content: url("https://assets.retty.me/v-202604161413-ab0f6e8c1c9832ee668873d78dfec1a026a5b0ba/images/pancake/ic_mastercard.svg")
}

.credit-card-list__item--jcb:before {
    width: 47px;
    content: url("https://assets.retty.me/v-202604161413-ab0f6e8c1c9832ee668873d78dfec1a026a5b0ba/images/pancake/ic_jcb.svg")
}

.credit-card-list__item--amex:before {
    width: 41px;
    content: url("https://assets.retty.me/v-202604161413-ab0f6e8c1c9832ee668873d78dfec1a026a5b0ba/images/pancake/ic_amex.svg")
}

.credit-card-list__item--diners:before {
    width: 49px;
    content: url("https://assets.retty.me/v-202604161413-ab0f6e8c1c9832ee668873d78dfec1a026a5b0ba/images/pancake/ic_diners.svg")
}

.other-payment-list {
    display: flex
}

.other-payment-list__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-size: 1.2rem
}

.other-payment-list__item:before {
    display: block;
    height: 36px;
    margin-bottom: 4px
}

.other-payment-list__item:nth-child(n+2) {
    margin-left: 20px
}

.other-payment-list__item--paypay:before {
    width: 40px;
    height: 40px;
    background-image: url("https://assets.retty.me/v-202604161413-ab0f6e8c1c9832ee668873d78dfec1a026a5b0ba/images/pancake/ic_paypay.png");
    background-size: cover;
    content: ""
}

.restaurant-info-table-caption {
    background-color: #f4f4f5;
    padding: 8px 16px
}

.restaurant-info-table {
    display: flex;
    box-sizing: border-box;
    flex-wrap: wrap;
    align-items: stretch;
    padding: 0 16px
}

.restaurant-info-table:nth-child(n+2) {
    margin-top: 12px
}

.restaurant-info-table__tbody {
    flex-grow: 1
}

.restaurant-info-table__row {
    display: flex;
    flex-direction: row
}

.restaurant-info-table__row:not(:last-of-type) {
    border-bottom: 1px solid #eaeaea
}

.restaurant-info-table__title {
    flex: 0 0 180px;
    align-items: center;
    color: #2e2e3b;
    font-weight: 700
}

.restaurant-info-table__body,.restaurant-info-table__title {
    display: flex;
    box-sizing: border-box;
    padding: 16px 8px;
    font-size: 1.6rem
}

.restaurant-info-table__body {
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    overflow: hidden;
    min-height: 80px;
    flex-basis: calc(100% - 212px);
    flex-grow: 1;
    flex-shrink: 0;
    color: #62626c
}

.restaurant-info-table__body:not(:last-of-type) {
    border-bottom: 1px solid #eaeaea
}

.restaurant-info-table__body--supplement {
    font-size: 1.3rem
}

.restaurant-info-table__body--supplement:nth-child(n+2) {
    margin-top: 4px
}

.restaurant-info-table__body--additional-note {
    margin-top: 8px;
    color: rgba(46,46,59,.8);
    font-size: 1.4rem
}

.restaurant-info-table__body--additional-note>a {
    color: #2d88d9
}

.restaurant-info-table__body--pre-line {
    white-space: pre-line
}

.restaurant-info-table__notice {
    color: #d70025
}

.restaurant-info-table__column {
    display: block;
    width: 100%
}

.restaurant-info-table__link {
    cursor: pointer;
    color: #2d88d9
}

.restaurant-info-table__link:hover {
    opacity: .8
}

.restaurant-info-table__map {
    display: flex;
    width: 100%;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between
}

.restaurant-info-table__map-link {
    cursor: pointer;
    color: #2d88d9
}

.restaurant-info-table__map-link i {
    position: relative;
    left: 0;
    display: inline-block;
    width: 8px;
    height: 8px;
    margin-left: 5.3333333333px;
    transform: rotate(135deg)
}

.restaurant-info-table__map-link i:after,.restaurant-info-table__map-link i:before {
    position: absolute;
    top: 0;
    left: 0;
    background-color: #2d88d9;
    border-radius: 2px;
    content: "";
    transition: all .6s ease-out;
    vertical-align: sub
}

.restaurant-info-table__map-link i:before {
    width: 100%;
    height: 2px
}

.restaurant-info-table__map-link i:after {
    width: 2px;
    height: 100%
}

.restaurant-info-table__map-link i {
    transform: translateX(25%) rotate(135deg)
}

.restaurant-info-table__map-link:hover {
    opacity: .8
}

.restaurant-info-table__map-link>i {
    margin-bottom: 1px
}

.restaurant-info-table__map-frame {
    display: block;
    width: 100%;
    margin-top: 6px
}

.restaurant-info-table__available {
    font-size: 1.8rem;
    font-weight: 700
}

.restaurant-info-table__available--true {
    color: #02a49f
}

.restaurant-info-table__available--true:before {
    content: "\25CB"
}

.restaurant-info-table__available--false {
    color: #8c8c93
}

.restaurant-info-table__available--false:before {
    margin-right: 2px;
    content: "\2212"
}

.restaurant-info-table__list {
    list-style: none
}

.restaurant-info-table__list li:nth-child(n+2) {
    margin-top: 8px
}

.restaurant-info-table__reservation-button {
    padding: 8px 16px
}

.restaurant-info-table__reservation-button--disabled {
    padding: 0
}

.restaurant-info-table__card-list:nth-child(n+2),.restaurant-info-table__other-payment-list:nth-child(n+2) {
    margin-top: 6px
}

.restaurant-info-table pre {
    white-space: pre-line
}

.restaurant-info-table__name {
    font-size: 1.6rem;
    color: #2e2e3b;
    line-height: 1.6
}

.restaurant-info-table__kana {
    font-size: 1.4rem;
    line-height: 1.6;
    color: #62626c
}

.restaurant-info-message-box {
    padding: 16px;
    margin-top: 40px;
    background-color: #f4f4f5;
    font-size: 1.4rem
}

.restaurant-info-message-box:nth-child(n+2) {
    margin-top: 16px
}

.restaurant-info-message-box__title {
    font-weight: 700
}

.restaurant-info-message-box__body {
    display: flex;
    width: 100%;
    justify-content: space-between
}

.restaurant-info-message-box__detail-link {
    cursor: pointer;
    color: #2d88d9
}

.restaurant-info-message-box__detail-link i {
    position: relative;
    left: 0;
    display: inline-block;
    width: 8px;
    height: 8px;
    margin-left: 5.3333333333px;
    transform: rotate(135deg)
}

.restaurant-info-message-box__detail-link i:after,.restaurant-info-message-box__detail-link i:before {
    position: absolute;
    top: 0;
    left: 0;
    background-color: #2d88d9;
    border-radius: 2px;
    content: "";
    transition: all .6s ease-out;
    vertical-align: sub
}

.restaurant-info-message-box__detail-link i:before {
    width: 100%;
    height: 2px
}

.restaurant-info-message-box__detail-link i:after {
    width: 2px;
    height: 100%
}

.restaurant-info-message-box__detail-link i {
    transform: translateX(25%) rotate(135deg)
}

.restaurant-info-message-box__detail-link:hover {
    opacity: .8
}

.hygiene-measures:nth-child(n+2) {
    margin-top: 24px
}

.hygiene-measures__title:before {
    content: "\25A0"
}

.hygiene-measures__free-text {
    white-space: pre-line
}

.hygiene-measures__body:before {
    content: "\30FB"
}

.hygiene-measures__body:first-of-type {
    margin-top: 4px
}

.hygiene-measures__body:nth-of-type(n+2) {
    margin-top: 13px
}

#home-meal-replacement1,#home-meal-replacement2 {
    padding-top: 60px;
    margin-top: -60px
}

#anchor-hygiene-measures-info {
    padding-top: 120px;
    margin-top: -120px
}

.message-to-owner {
    padding: 30px 60px 0
}

.course-list-heading {
    display: flex;
    align-items: center;
    padding: 0 0 12px
}

.course-list-heading__title {
    max-width: calc(100% - 300px);
    flex-shrink: 0;
    color: #2e2e3b;
    font-size: 2rem;
    font-weight: 700
}

.course-list-heading__supplement {
    align-self: flex-end;
    padding-left: 10px;
    margin-left: auto;
    color: #62626c;
    font-size: 1.4rem;
    font-weight: 400
}

.course-list__item {
    display: flex;
    flex-direction: column;
    border-bottom: 1px solid var(--border-color)
}

.course-list__item:first-child {
    border-top: 1px solid var(--border-color)
}

.course-list-item {
    display: flex;
    width: 100%;
    min-height: 80px;
    align-items: center;
    padding: 16px 0
}

.course-list-item__thumbnail {
    flex-shrink: 0
}

.course-list-item__thumbnail img {
    width: 80px;
    height: 80px;
    background-color: #f4f4f5;
    object-fit: cover
}

.course-list-item__detail {
    flex: 1 1 auto
}

.course-list-item__detail:nth-child(n+2) {
    margin-left: 12px
}

.course-list-item__title {
    color: #2e2e3b;
    font-size: 1.6rem;
    font-weight: 700
}

.course-list-item__title:nth-child(n+2) {
    margin-top: 6px
}

.course-list-item__description {
    color: #8c8c93;
    font-size: 1.4rem
}

.course-list-item__footer {
    display: flex
}

.course-list-item__price {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #d70025;
    font-size: 1.8rem;
    font-weight: 700
}

.course-list-item__label {
    display: inline-block;
    padding: 1px 11px;
    border: 1px solid #ffa014;
    background-color: #fff;
    border-radius: 2px;
    color: #fff;
    color: #ffa014;
    font-size: 1.2rem;
    font-weight: 400;
    vertical-align: top
}

.course-list-item__label--discount {
    border-color: #d70025;
    background: #d70025;
    color: #fff
}

.course-list-item__before-discount {
    display: inline-flex;
    align-items: center;
    color: #2e2e3b;
    font-size: 1.6rem;
    font-weight: 400;
    text-decoration: line-through
}

.course-list-item__discount-arrow {
    margin: 0 4px;
    color: #2e2e3b;
    font-weight: 400;
    text-decoration: none
}

.course-list-item__tax {
    display: inline;
    align-self: auto;
    color: #d70025;
    font-size: 1.4rem
}

.course-list-item__term {
    display: flex;
    align-items: center;
    margin-left: 12px;
    color: #2e2e3b;
    font-size: 1.1rem
}

.course-list-item__actions-list {
    display: flex;
    flex: 0 0 150px;
    flex-direction: column;
    align-items: center;
    justify-content: center
}

.course-list-item__action {
    display: flex;
    width: 96px;
    justify-content: center
}

.course-list-item__action:nth-child(n+2) {
    margin-top: 12px
}

.course-list-item__button {
    width: 96px;
    padding: 6px 0;
    font-size: 1.4rem;
    font-weight: 700
}

.seat-only-course__row {
    margin-bottom: 24px;
    padding: 10px 0;
    border: 1px solid var(--border-color);
    border-radius: 2px;
    height: 62px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.seat-only-course__text {
    margin-left: 14px;
    font-size: 1.6rem;
    font-weight: 700
}

.course-summary {
    display: flex
}

.course-summary:nth-child(n+2) {
    margin-top: 10px
}

.course-summary__label {
    width: 100%;
    flex: 0 0 100%
}

.course-summary__photo {
    width: 184px;
    height: 184px;
    flex: 0 0 184px;
    align-self: flex-start;
    object-fit: cover
}

.course-summary__body:nth-child(n+2) {
    margin-left: 16px;
    font-size: 1.6rem
}

.course-summary-label {
    display: block
}

.course-info-list {
    display: flex;
    flex-wrap: wrap;
    border-bottom: 1px solid #eaeaea;
    font-size: 1.6rem
}

.course-info-list__description,.course-info-list__title {
    border-top: 1px solid #eaeaea
}

.course-info-list__title {
    box-sizing: border-box;
    padding: 16px 24px;
    max-width: 216px;
    flex: 0 0 216px;
    background-color: #fafafa
}

.course-info-list__description {
    box-sizing: border-box;
    padding: 16px 24px;
    max-width: calc(100% - 216px);
    flex-basis: calc(100% - 216px);
    flex-grow: 1;
    flex-shrink: 0
}

.course-info-list__description--pre {
    white-space: pre-line;
    word-break: break-all
}

.course-info-list__description--strong {
    color: #d70025;
    font-size: 1.8rem;
    font-weight: 700
}

.course-info-list__before-discount {
    display: inline-flex;
    align-items: center;
    color: #2e2e3b;
    font-size: 1.6rem;
    font-weight: 400;
    text-decoration: line-through
}

.course-info-list__discount-arrow {
    margin: 0 4px;
    color: #2e2e3b;
    font-weight: 400;
    text-decoration: none
}

.course-info-list__tax {
    display: inline;
    align-self: auto;
    color: #d70025;
    font-size: 1.4rem
}

.restaurant-coupon-heading {
    display: flex;
    align-items: center;
    padding: 0 0 12px;
    border-bottom: 1px solid var(--border-color)
}

.restaurant-coupon-heading__title {
    max-width: calc(100% - 300px);
    flex-shrink: 0;
    color: #2e2e3b;
    font-size: 2rem;
    font-weight: 700
}

.restaurant-coupon-heading__supplement {
    align-self: flex-end;
    padding-left: 10px;
    margin-left: auto;
    color: #62626c;
    font-size: 1.4rem;
    font-weight: 400
}

.restaurant-coupon-list {
    border: 1px solid var(--border-color)
}

.restaurant-coupon-list:nth-child(n+2) {
    margin-top: 20px
}

.restaurant-coupon-list__item:nth-child(n+2) {
    border-top: 1px dashed var(--border-color)
}

.restaurant-coupon {
    display: flex
}

.restaurant-coupon:before {
    display: block;
    min-height: 80px;
    flex: 0 0 48px;
    background: url("https://assets.retty.me/v-202604161413-ab0f6e8c1c9832ee668873d78dfec1a026a5b0ba/images/pancake/ic_coupon.svg") #ffa014;
    background-position: 50%;
    background-repeat: no-repeat;
    content: ""
}

.restaurant-coupon--marked {
    position: relative
}

.restaurant-coupon--marked:after {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 0;
    height: 0;
    border-width: 8px;
    border-style: solid;
    border-color: #ffc814 transparent transparent #ffc814;
    content: ""
}

.restaurant-coupon__body {
    flex: 1 1 auto;
    padding: 18px 20px
}

.restaurant-coupon__title {
    color: #2e2e3b;
    font-size: 1.8rem;
    font-weight: 700
}

.restaurant-coupon__description {
    color: #62626c;
    font-size: 1.1rem
}

.restaurant-coupon__description:nth-child(n+2) {
    margin-top: 4px
}

.restaurant-coupon__supplement {
    display: flex;
    box-sizing: border-box;
    flex: 0 0 200px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 12px 16px
}

.restaurant-coupon__supplement:nth-child(n+2) {
    border-left: 1px dashed var(--border-color)
}

.restaurant-coupon__expiration {
    color: #62626c;
    font-size: 1.4rem
}

.restaurant-coupon__link {
    cursor: pointer;
    color: #2d88d9;
    font-size: 1.4rem
}

.restaurant-coupon__link:hover {
    opacity: .8
}

.restaurant-coupon__link--external {
    display: flex;
    align-items: center
}

.restaurant-coupon__link--external:after {
    content: "\F12A";
    font-size: 1.8rem
}

@keyframes show-sticky-actions {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.restaurant-sidebar {
    width: 300px;
    flex-direction: column
}

.restaurant-sidebar__prepare-stuck {
    z-index: 90;
    display: none
}

.restaurant-sidebar__prepare-stuck[data-stuck=true] {
    display: flex;
    animation: show-sticky-actions .1s ease-out
}

.restaurant-sidebar__campaign-banner {
    z-index: 90;
    padding-top: 12px
}

.menu-price-list {
    font-size: 1.6rem
}

.menu-price-list__row {
    display: flex;
    padding: 16px
}
@media screen and (max-width: 767px){
  .menu-price-list__row {
    padding: 10px;
  }
}

.menu-price-list__row:nth-child(n+2) {
    border-top: 1px solid var(--list-line);
}

.menu-price-list__image {
    margin-right: 24px;
}

.menu-price-list__image img {
    border-radius: 4px;
}

.menu-price-list__wrapper-in-wrapper {
    display: flex;
}
@media screen and (max-width: 767px){
  .menu-price-list__wrapper-in-wrapper{
    flex-direction: column;
  }
}


.menu-price-list__name {
    font-weight: 500;
    flex: 1
}

.menu-price-list__supplement {
    color: #62626c;
    font-weight: 400;
    font-size: 1.4rem;
    margin-top: 4px
}

.menu-price-list__price {
    font-weight: 500;
    text-align: right;
    flex: 0 content;
    min-width: 72px
}

.menu-price-list__wrapper {
    display: flex;
    flex-direction: column;
    width: 100%
}

.menu-price-list__label {
    font-size: 1.4rem;
    font-weight: 700;
    color: #8B0000;
    border: 1px solid #8B0000;
    border-radius: 2px;
    padding: 2px 8px;
    width: fit-content;
    margin-bottom: 4px
}

.menu-price-list__label--orange {
    color: #fff;
    background-color: #B22222;
    border-color: #B22222
}

.restaurant-update-info__updaters {
    display: flex
}

.restaurant-update-info__updaters:nth-child(n+2) {
    margin-top: 20px
}

.restaurant-update-info__updater {
    flex-shrink: 0;
    padding-right: 28px
}

.restaurant-update-info__updater:nth-child(n+2) {
    padding-left: 28px;
    border-left: 1px solid var(--border-color)
}

.restaurant-update-info__title {
    color: #8c8c93;
    font-size: 1.4rem;
    font-weight: 700
}

.restaurant-update-info__detail {
    display: flex
}

.restaurant-update-info__detail:nth-child(n+2) {
    margin-top: 8px
}

.restaurant-update-info__user-link {
    cursor: pointer;
    flex-shrink: 0;
    color: #2d88d9
}

.restaurant-update-info__user-link:hover {
    opacity: .8
}

.restaurant-update-info__date {
    flex-shrink: 0
}

.restaurant-update-info__date:nth-child(n+2) {
    margin-left: 4px
}

.restaurant-update-info__supplement {
    color: #62626c;
    font-size: 1.4rem
}

.restaurant-update-info__supplement:nth-child(n+2) {
    margin-top: 20px
}

.restaurant-update-info__supplement a {
    cursor: pointer;
    color: #2d88d9
}

.restaurant-update-info__supplement a:hover {
    opacity: .8
}


.button--post:before,.button--share:before,.hourly-budget--dinner:before,.hourly-budget--lunch:before,.hourly-budget--morning:before,.information-list__label--category:before,.information-list__label--holiday:before,.reservation-speech-balloon--today-dinner-availability:before,.restaurant-actions-box__reservation:before,.restaurant-actions-box__telephone i:before,.restaurant-coupon__link--external:after,.restaurant-info-heading__button:before,.wannago-button:before,.wannago-button:not(.wannago-button--fetching).wannago-button--active:before {
    font-family: rettyfont;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-style: normal;
    font-variant: normal;
    font-weight: 400;
    text-decoration: none;
    text-transform: none
}

@keyframes rotation {
    0% {
        transform: rotate(0deg)
    }

    to {
        transform: rotate(1turn)
    }
}

/* .navigation,.restaurant-detail__content,.restaurant-detail__header,.restaurant-navigation-bar {
    width: 1140px;
    box-sizing: content-box;
    margin: 0 auto
} */

.paid-news-list__item {
    padding: 24px 0;
    border-bottom: 1px solid var(--border-color)
}

.paid-news-list__item:first-child {
    border-top: 1px solid var(--border-color)
}

.paid-news-list__title {
    font-size: 1.8rem;
    font-weight: 700
}

.paid-news-list__date {
    color: #62626c
}

.paid-news-list__date:nth-child(n+2) {
    margin-top: 2px
}

.paid-news-list__images:nth-child(n+2) {
    margin-top: 12px
}

.paid-news-list__images>ul {
    display: flex
}

.paid-news-list__image-item {
    height: 196px;
    flex: 0 0 196px
}

.paid-news-list__image-item:nth-child(n+2) {
    margin-left: 2px
}

.paid-news-list__image-item>img {
    width: 100%;
    height: 100%;
    background-color: #f4f4f5;
    object-fit: cover
}

.paid-news-list__detail {
    font-size: 1.6rem;
    white-space: pre-line
}

.paid-news-list__detail:nth-child(n+2) {
    margin-top: 12px
}

.paid-news-list__image-item {
    cursor: pointer
}

.paid-news-list__image-item:hover {
    opacity: .8
}

.paid-news-list--sidebar__item {
    padding: 24px 0;
    border-bottom: 1px solid var(--border-color)
}

.paid-news-list--sidebar__item:first-child {
    border-top: 1px solid var(--border-color)
}

.paid-news-list--sidebar__title {
    font-size: 1.8rem;
    font-weight: 700
}

.paid-news-list--sidebar__date {
    color: #62626c
}

.paid-news-list--sidebar__date:nth-child(n+2) {
    margin-top: 2px
}

.paid-news-list--sidebar__images:nth-child(n+2) {
    margin-top: 12px
}

.paid-news-list--sidebar__images>ul {
    display: flex
}

.paid-news-list--sidebar__image-item {
    height: 196px;
    flex: 0 0 196px
}

.paid-news-list--sidebar__image-item>img {
    background-color: #f4f4f5;
    object-fit: cover
}

.paid-news-list--sidebar__detail {
    font-size: 1.6rem;
    white-space: pre-line
}

.paid-news-list--sidebar__detail:nth-child(n+2) {
    margin-top: 12px
}

.paid-news-list--sidebar__item {
    padding: 20px 0
}

.paid-news-list--sidebar__images {
    width: 100%
}

.paid-news-list--sidebar__image-item {
    position: relative;
    height: auto;
    flex-basis: calc((100% - 2px) / 2);
    flex-shrink: 0
}

.paid-news-list--sidebar__image-item:before {
    display: block;
    padding-top: 100%;
    content: ""
}

.paid-news-list--sidebar__image-item:nth-child(n+2) {
    margin-left: 2px
}

.paid-news-list--sidebar__image-item:only-of-type {
    margin-right: auto;
    margin-left: auto
}

.paid-news-list--sidebar__image-item>img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.paid-news-list--sidebar__title:nth-child(n+2) {
    margin-top: 16px
}

.paid-news-list--sidebar__detail {
    font-size: 1.4rem
}

.paid-news-list--sidebar__date {
    color: #8c8c93;
    font-size: 1.4rem;
    text-align: right
}

[v-cloak] {
    visibility: hidden
}

.restaurant-menu__title {
    font-size: 1.8rem;
    font-weight: 700;
    margin-top: 4rem;
    padding-left: 12px;
    border-left: 4px solid var(--main);
    line-height: 1.4
}

.restaurant-menu__title:nth-child(n+2) {
    margin-top: 5rem;
}

.restaurant-menu__body {
    border-bottom: 1px solid var(--border-color)
}

.restaurant-menu__body:nth-child(n+2) {
    margin-top: 16px;
    /* border-top: 1px solid #eaeaea */
}
