@font-face {
    font-family: "Montreal Mono Regular";
    src:
        local("Montreal Mono Regular"), local("Montreal Mono"),
        local("PP Neue Montreal Mono"), local("PPNeueMontrealMono-Regular"),
        local("Neue Montreal Mono");
    font-style: normal;
    font-weight: 400;
}

:root {
    --header-bg: #eee8e0;
    --ink: #233241;
    --muted: #6b747e;
    --line: #ddd6cb;
    --card-line: #d8d1c6;
    --panel-bg: #f8f8f8;
    --accent: #b9b4aa;
    --active: #2b3340;
    --cart-width: 30vw;
    --cart-sticky-top: 22px;
    --font-primary:
        "Montreal Mono Regular", "Montreal Mono", "PP Neue Montreal Mono",
        "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

* {
    box-sizing: border-box;
    font-family: var(--font-primary);
}

html {
    scroll-behavior: smooth;
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
}

body {
    margin: 0;
    background: var(--header-bg);
    color: var(--ink);
    overflow-x: hidden;
    width: 100%;
    max-width: 100%;
}

body.modal-open {
    overflow: hidden;
}

a {
    color: inherit;
}

.is-hidden {
    display: none !important;
}

.site-header {
    position: relative;
    padding: 0 16px 16px;
    background: var(--header-bg);
    border-top: 1px solid rgba(255, 255, 255, 0.92);
    border-bottom: 1px solid #d7d0c4;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.95),
        0 1px 0 rgba(255, 255, 255, 0.85),
        0 6px 14px rgba(33, 34, 35, 0.08);
    width: 100%;
}

.header-layout {
    display: grid;
    grid-template-columns: minmax(520px, 1.35fr) minmax(320px, 1fr);
    gap: 20px;
    align-items: start;
    margin-top: 8px;
    padding-right: 84px;
    position: relative;
}

.header-left,
.header-right {
    min-width: 0;
}

.header-left-title {
    margin: 14px 0 6px;
    display: flex;
    align-items: center;
    gap: 0;
}

.header-left h1 {
    margin: 0;
    font-size: clamp(1.2rem, 1.7vw, 1.95rem);
    letter-spacing: 0.02em;
    font-weight: 800;
    text-transform: uppercase;
}

.lumina-description {
    margin: 0 0 4px;
    font-size: 0.9rem;
    color: rgba(35, 50, 65, 0.82);
}

.address {
    margin: 0;
    font-size: 0.92rem;
    color: rgba(35, 50, 65, 0.86);
}

.lumina-opening-status {
    margin: 8px 0 0;
    width: fit-content;
    padding: 6px 11px;
    border-radius: 999px;
    font-size: 0.78rem;
    letter-spacing: 0.02em;
    font-weight: 700;
    color: #233241;
    background: #d9d1c4;
    border: 1px solid rgba(35, 50, 65, 0.18);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.75),
        0 2px 5px rgba(19, 24, 30, 0.12);
}

.lumina-status-row {
    margin-top: 6px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.lumina-status-row .lumina-opening-status {
    margin: 0;
}

.lumina-callwaiter-form {
    margin: 0;
}

.lumina-callwaiter-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(35, 50, 65, 0.18);
    background: #d9d1c4;
    color: #233241;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    cursor: pointer;
    text-decoration: none;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.75),
        0 2px 5px rgba(19, 24, 30, 0.12);
}

.lumina-callwaiter-btn:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

#modal-form {
    position: fixed;
    inset: 0;
    background: rgba(16, 20, 24, 0.46);
    z-index: 130;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

#modal-form.lumina-waiter-open {
    display: flex;
}

#modal-form .modal-dialog {
    width: min(430px, 96vw);
    margin: 0;
}

#modal-form .modal-content {
    background: #efebe3;
    border: 1px solid #ded7cb;
    border-radius: 34px;
    box-shadow: 0 22px 44px rgba(20, 24, 30, 0.24);
    overflow: hidden;
}

#modal-form .card {
    background: transparent !important;
    border: 0;
    box-shadow: none !important;
}

#modal-form .card-header {
    background: transparent !important;
    border-bottom: 1px solid #ddd5ca;
    padding: 14px 16px 10px;
}

#modal-form .card-header h4 {
    margin: 0;
    color: #233241;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

#modal-form .modal-header {
    padding: 22px 22px 10px;
    border-bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

#modal-form .modal-header h6 {
    margin: 0;
    color: #233241;
    font-size: 1.55rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

#modal-form .modal-header .close {
    position: absolute;
    right: 16px;
    top: 14px;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid #ddd6ca;
    background: #e5e0d8;
    color: #8d8f93;
    font-size: 1.95rem;
    line-height: 1;
    display: grid;
    place-items: center;
    padding: 0 0 2px;
    cursor: pointer;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.72),
        0 2px 8px rgba(20, 24, 30, 0.08);
}

#modal-form .modal-header .close:hover {
    background: #dad4ca;
}

#modal-form .modal-header .close span {
    display: inline-block;
    transform: translateY(-1px);
}

#modal-form .modal-header .close:not(:disabled):not(.disabled):focus,
#modal-form .modal-header .close:focus {
    border: 0;
    outline: 0;
    box-shadow: 0 0 0 3px rgba(201, 194, 182, 0.46);
}

#modal-form .card-body {
    padding: 14px 16px 16px !important;
}

#modal-form .modal-body {
    padding: 10px 26px 22px !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}

#modal-form .modal-body .form-group,
#modal-form .modal-body .col,
#modal-form .modal-body .col-12,
#modal-form .modal-body .col-md-12 {
    width: 100%;
    max-width: 280px;
    margin-left: auto;
    margin-right: auto;
}

#modal-form .modal-footer {
    border-top: 0;
    padding: 18px 20px 20px;
    background: transparent;
}

#modal-form .modal-footer .footer-area {
    width: 100%;
    border-radius: 30px;
    background: #f6f3ee;
    border: 1px solid #e3ddd1;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.74);
    padding: 18px 16px;
}

#modal-form .modal-footer .quantity-btn {
    width: 100%;
    display: block !important;
}

#modal-form .modal-footer .quantity-btn > div {
    width: 100%;
}

#modal-form .form-control,
#modal-form .form-control-alternative,
#modal-form select,
#modal-form input {
    height: 58px !important;
    background: #efebe3 !important;
    border: 2px solid #d2cbc0 !important;
    color: #2a3a49 !important;
    border-radius: 13px !important;
    box-shadow: inset 0 1px 2px rgba(20, 24, 30, 0.05) !important;
    font-size: 0.98rem !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
}

#modal-form .form-control:focus,
#modal-form .form-control-alternative:focus,
#modal-form select:focus,
#modal-form input:focus {
    border-color: #bdb4a5 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(191, 181, 166, 0.22) !important;
}

#modal-form label,
#modal-form .form-control-label {
    color: #3b4a58 !important;
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 10px;
    text-align: center;
    width: 100%;
    display: block;
}

#modal-form .btn-primary {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 62px;
    padding: 0 20px;
    line-height: 1;
    white-space: nowrap;
    text-align: center;
    border-radius: 999px;
    border: 1px solid rgba(35, 50, 65, 0.22);
    background: #d9d1c4 !important;
    color: #233241 !important;
    font-size: 1.22rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.78),
        0 6px 14px rgba(19, 24, 30, 0.16);
}

#modal-form .btn-primary:hover {
    background: #cfc6b8 !important;
}

#modal-form .btn-primary:focus {
    box-shadow:
        0 0 0 3px rgba(191, 181, 166, 0.26),
        inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

@media (max-width: 760px) {
    #modal-form {
        padding: 12px;
    }

    #modal-form .modal-dialog {
        width: min(420px, 100%);
    }

    #modal-form .modal-content {
        border-radius: 28px;
    }

    #modal-form .modal-header {
        padding: 18px 16px 8px;
    }

    #modal-form .modal-header h6 {
        font-size: 1.32rem;
    }

    #modal-form .modal-header .close {
        right: 12px;
        top: 10px;
        width: 38px;
        height: 38px;
        font-size: 1.72rem;
    }

    #modal-form .modal-body {
        padding: 8px 16px 18px !important;
    }

    #modal-form .modal-body .form-group,
    #modal-form .modal-body .col,
    #modal-form .modal-body .col-12,
    #modal-form .modal-body .col-md-12 {
        max-width: 100%;
    }

    #modal-form .form-control,
    #modal-form .form-control-alternative,
    #modal-form select,
    #modal-form input {
        height: 54px !important;
    }

    #modal-form .modal-footer {
        padding: 12px 12px 14px;
    }

    #modal-form .modal-footer .footer-area {
        padding: 14px 12px;
        border-radius: 22px;
    }

    #modal-form .btn-primary {
        height: 54px;
        font-size: 1.04rem;
    }
}

.lumina-opening-status.is-open {
    color: #233241;
    background: #d9d1c4;
    border: 1px solid rgba(35, 50, 65, 0.18);
}

.lumina-opening-status.is-closed {
    color: #233241;
    background: #d9d1c4;
    border: 1px solid rgba(35, 50, 65, 0.18);
}

.search-wrap {
    margin-top: 22px;
    padding: 10px 0;
    border-top: 1px solid rgba(35, 50, 65, 0.62);
    border-bottom: 1px solid rgba(35, 50, 65, 0.62);
    display: flex;
    align-items: center;
    gap: 12px;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.72),
        inset 0 -1px 0 rgba(255, 255, 255, 0.72);
}

.search-icon {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #d9d3c8;
    color: rgba(35, 50, 65, 0.65);
    font-size: 14px;
    flex-shrink: 0;
    border: 1px solid rgba(255, 255, 255, 0.9);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.search-icon svg,
.search-icon i {
    width: 14px;
    height: 14px;
    font-size: 14px;
    line-height: 1;
    display: block;
}

.search-input {
    width: 100%;
    border: 0;
    outline: none;
    background: transparent;
    color: var(--ink);
}

#headerSearch {
    font-size: 1.9rem;
    font-family: var(--font-primary);
}

.search-input::placeholder {
    color: rgba(35, 50, 65, 0.72);
}

.category-nav {
    margin-top: 12px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 20px;
}

.header-category-nav {
    padding-bottom: 7px;
}

.nav-link {
    text-decoration: none;
    color: rgba(35, 50, 65, 0.76);
    font-size: 1rem;
    line-height: 1;
    padding: 8px 0;
    position: relative;
    white-space: nowrap;
    transition: color 0.18s ease;
}

.nav-link:hover {
    color: var(--active);
}

.nav-link.active {
    color: #cfc8be;
    font-weight: 600;
    border-bottom: 3px solid #cfc8be;
}

.nav-link.active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -8px;
    height: 4px;
    background: #cfc8be;
    border-radius: 2px;
}

.header-right {
    margin-top: 6px;
    text-align: center;
    padding-right: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 112px;
    position: relative;
    gap: 10px;
    filter: none;
}

.restorant-logo {
    display: block;
    width: 48px;
    height: 48px;
    object-fit: cover;
    object-position: center;
    border-radius: 50%;
    border: 1px solid rgba(35, 50, 65, 0.22);
    box-shadow: 0 2px 6px rgba(20, 25, 33, 0.12);
    flex-shrink: 0;
}

.restorant-logo-mobile {
    display: none;
}

.header-right-brand {
    width: min(620px, 100%);
    min-height: 190px;
    height: 190px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 6px 10px;
    transform: translateX(0);
}

.header-right-brand img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    display: block;
}

.logo-top {
    margin: 0;
    line-height: 0.8;
    font-family: var(--font-primary);
    font-size: clamp(2rem, 3vw, 3.4rem);
    letter-spacing: 0.05em;
}

.logo-main {
    margin: 0;
    line-height: 0.93;
    font-family: var(--font-primary);
    font-size: clamp(2.6rem, 5.6vw, 6.2rem);
    letter-spacing: 0.01em;
    white-space: nowrap;
    display: inline-block;
}

.header-actions {
    position: fixed;
    top: 20px;
    right: 10px;
    z-index: 40;
}

.lumina-lang-switcher {
    position: relative;
}

.lumina-lang-toggle {
    min-width: 96px;
    height: 42px;
    border: 1px solid rgba(35, 50, 65, 0.18);
    border-radius: 10px;
    background: #d9d1c4;
    color: #233241;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.75),
        0 4px 9px rgba(19, 24, 30, 0.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 12px;
    cursor: pointer;
    font-size: 0.85rem;
    letter-spacing: 0.02em;
}

.lumina-lang-caret {
    width: 8px;
    height: 8px;
    border-right: 1.6px solid rgba(35, 50, 65, 0.9);
    border-bottom: 1.6px solid rgba(35, 50, 65, 0.9);
    transform: rotate(45deg) translateY(-1px);
    transition: transform 0.2s ease;
}

.lumina-lang-switcher.is-open .lumina-lang-caret {
    transform: rotate(-135deg) translateY(-1px);
}

.lumina-lang-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 188px;
    border: 1px solid rgba(35, 50, 65, 0.14);
    border-radius: 10px;
    background: #f3ede3;
    box-shadow: 0 10px 24px rgba(18, 23, 28, 0.18);
    padding: 8px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-6px);
    transition:
        opacity 0.18s ease,
        transform 0.18s ease,
        visibility 0.18s ease;
}

.lumina-lang-switcher.is-open .lumina-lang-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
}

.lumina-lang-menu-title {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6a7480;
    padding: 6px 8px;
}

.lumina-lang-menu a {
    display: block;
    border-radius: 7px;
    padding: 9px 8px;
    text-decoration: none;
    font-size: 0.9rem;
    color: #273645;
}

.lumina-lang-menu a:hover {
    background: rgba(203, 195, 182, 0.4);
}

.lumina-offers-btn {
    position: fixed;
    right: 0;
    top: 48%;
    transform: translateY(-50%);
    writing-mode: vertical-rl;
    text-orientation: mixed;
    text-decoration: none;
    background: #d9d1c4;
    color: #233241;
    border: 1px solid rgba(35, 50, 65, 0.18);
    border-right: 0;
    border-radius: 10px 0 0 10px;
    padding: 12px 8px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    z-index: 30;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.75),
        0 4px 12px rgba(19, 24, 30, 0.14);
}

.lumina-offers-panel {
    position: fixed;
    inset: 0;
    z-index: 120;
    pointer-events: none;
}

.lumina-offers-panel-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(14, 17, 20, 0.4);
    opacity: 0;
    transition: opacity 0.2s ease;
}

.lumina-offers-panel-content {
    position: absolute;
    top: 0;
    right: 0;
    width: min(420px, 92vw);
    height: 100%;
    background: #f2ece3;
    border-left: 1px solid #d6cec1;
    transform: translateX(104%);
    transition: transform 0.24s ease;
    box-shadow: -6px 0 24px rgba(0, 0, 0, 0.16);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
}

.lumina-offers-panel-header {
    padding: 14px 14px;
    border-bottom: 1px solid #dfd8cc;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.lumina-offers-panel-header h6 {
    margin: 0;
    font-size: 1rem;
}

.lumina-offers-panel-close {
    color: #394b5d;
}

.lumina-offers-panel-body {
    overflow-y: auto;
    padding: 14px;
}

.lumina-offer-row {
    display: flex;
    gap: 12px;
    align-items: center;
    border: 1px solid #d8d0c4;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.42);
    padding: 10px;
    margin-bottom: 10px;
}

.lumina-offer-row img {
    width: 70px;
    height: 70px;
    object-fit: cover;
    border-radius: 8px;
}

.lumina-offer-title {
    margin: 0 0 4px;
    font-size: 0.9rem;
    color: #2e3f50;
}

.lumina-offer-price del {
    opacity: 0.62;
    margin-right: 6px;
}

.lumina-offer-price strong {
    color: #2e3f50;
}

.lumina-offers-panel-open {
    pointer-events: auto;
}

.lumina-offers-panel-open .lumina-offers-panel-backdrop {
    opacity: 1;
}

.lumina-offers-panel-open .lumina-offers-panel-content {
    transform: translateX(0);
}

.floating-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 28;
    border-top: 1px solid #d9d2c7;
    border-bottom: 1px solid #d9d2c7;
    background: var(--header-bg);
    transform: translateY(-110%);
    opacity: 0;
    pointer-events: none;
    transition:
        transform 0.2s ease,
        opacity 0.2s ease;
    box-shadow: none;
}

.floating-nav.visible {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.floating-nav-inner {
    min-height: 56px;
    padding: 0 calc(var(--cart-width) + 24px) 0 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.floating-search-toggle {
    border: 0;
    background: transparent;
    color: var(--ink);
    font-size: 17px;
    line-height: 1;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    cursor: pointer;
    display: grid;
    place-items: center;
    transform: translateX(-20px);
    opacity: 0;
    transition:
        transform 0.25s ease,
        opacity 0.25s ease,
        background 0.16s ease;
}

.floating-search-toggle:hover {
    background: #dfd7cb;
}

.floating-nav.visible .floating-search-toggle {
    transform: translateX(0);
    opacity: 1;
}

.floating-search-wrap {
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    transition:
        max-width 0.24s ease,
        opacity 0.2s ease,
        margin-right 0.24s ease;
    margin-right: 0;
}

.floating-search-wrap.open {
    max-width: 320px;
    opacity: 1;
    margin-right: 8px;
}

#floatingSearch {
    width: 300px;
    height: 38px;
    border: 1px solid #d8d0c4;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.75);
    padding: 0 12px;
    font-size: 0.95rem;
}

.floating-category-nav {
    margin: 0;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 14px;
    scrollbar-width: none;
}

.floating-category-nav::-webkit-scrollbar {
    display: none;
}

.page-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--cart-width);
    gap: 26px;
    align-items: stretch;
    padding: 12px 0 36px 0;
    width: 100%;
}

.menu-column {
    min-width: 0;
    padding-left: 14px;
    width: 100%;
    align-self: start;
}

.cart-column {
    border-left: 1px solid var(--line);
    min-height: 100%;
    align-self: stretch;
    position: sticky;
    top: var(--cart-sticky-top);
    height: calc(100vh - var(--cart-sticky-top));
}

.cart-sticky {
    position: static;
    height: 100%;
    overflow-y: auto;
    overscroll-behavior: auto;
    padding: 22px 18px 20px 18px;
}

body.floating-nav-visible {
    --cart-sticky-top: 78px;
}

.cart-icon {
    font-size: 66px;
    line-height: 1;
    text-align: center;
    color: #3e3e40;
}

.cart-icon svg {
    display: block;
    width: 66px;
    height: 66px;
    margin: 0 auto;
    fill: currentColor;
}

.cart-empty {
    margin: 26px 0 36px;
    text-align: center;
    font-size: 0.95rem;
    color: var(--muted);
}

.cart-title {
    margin: 0 0 16px;
    font-size: 2rem;
    font-family: var(--font-primary);
    font-weight: 500;
    color: var(--ink);
}

.cart-items {
    margin-bottom: 16px;
}

.cart-item {
    border-bottom: 1px solid #e2ddd4;
    padding: 12px 0;
}

.cart-item.is-expandable {
    cursor: pointer;
}

.cart-item.is-expandable:hover {
    background: rgba(255, 255, 255, 0.16);
}

.cart-item-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}

.cart-item-main {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.cart-item-name {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.96rem;
    line-height: 1.3;
}

.cart-item-reduce {
    width: 24px;
    height: 24px;
    border-radius: 4px;
    border: 0;
    background: #d0c9be;
    color: #ffffff;
    font-size: 1.05rem;
    line-height: 1;
    cursor: pointer;
    flex-shrink: 0;
}

.cart-item-reduce:hover {
    background: #bfb7ab;
}

.cart-item-toggle-indicator {
    font-size: 0.64rem;
    color: #68727c;
}

.cart-item-price {
    font-size: 0.95rem;
    color: #55606b;
    white-space: nowrap;
}

.cart-item-details {
    margin: 8px 0 0;
    padding: 8px 10px;
    border: 1px solid #ddd6ca;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.3);
    color: #6f7a85;
}

.cart-item-details-label {
    margin: 0 0 6px;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #76808a;
}

.cart-item-details-list {
    margin: 0;
    padding-left: 16px;
    display: grid;
    gap: 4px;
    font-size: 0.76rem;
    line-height: 1.42;
}

.cart-item-details-list li {
    margin: 0;
}

.cart-summary {
    border-top: 1px solid #e6e2db;
    padding-top: 16px;
}

.cart-clear-btn {
    width: 100%;
    height: 38px;
    border-radius: 6px;
    border: 1px solid rgba(35, 50, 65, 0.18);
    background: rgba(217, 209, 196, 0.55);
    color: #233241;
    font-size: 0.86rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    cursor: pointer;
    margin: 0 0 12px;
}

.cart-clear-btn:hover {
    background: rgba(207, 198, 184, 0.85);
}

.summary-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 10px;
    font-size: 1rem;
    margin-bottom: 6px;
    color: #495867;
}

.total-row {
    font-size: 0.93rem;
    font-weight: 700;
}

.menu-section {
    margin-top: 18px;
    scroll-margin-top: 82px;
}

.section-title {
    margin: 0 0 16px;
    font-size: clamp(1.65rem, 3.2vw, 2rem);
    font-weight: 500;
    font-family: var(--font-primary);
}

.product-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.single-card {
    grid-template-columns: minmax(230px, 420px);
}

.product-card {
    position: relative;
    border: 1px solid var(--card-line);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.08);
    padding: 16px;
    min-height: 370px;
    display: flex;
    flex-direction: column;
}

.plate {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    margin: 0 auto 16px;
    border: 6px solid rgba(245, 244, 237, 0.95);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.14);
}

.plate-a {
    background: radial-gradient(
        circle at 40% 35%,
        #9cd16d 0 26%,
        #de684f 26% 40%,
        #7ea84a 40% 56%,
        #e2ca86 56% 76%,
        #6a9146 76% 100%
    );
}
.plate-b {
    background: radial-gradient(
        circle at 35% 35%,
        #4b8a45 0 28%,
        #e8d494 28% 44%,
        #7ec9b8 44% 63%,
        #b4715a 63% 79%,
        #668849 79% 100%
    );
}
.plate-c {
    background: radial-gradient(
        circle at 40% 35%,
        #7cb05c 0 30%,
        #efe7b8 30% 48%,
        #bc4b48 48% 62%,
        #4e7f3f 62% 80%,
        #f2d57f 80% 100%
    );
}
.plate-d {
    background: radial-gradient(
        circle at 45% 30%,
        #9a3f38 0 24%,
        #5e823d 24% 44%,
        #e4c76f 44% 60%,
        #733730 60% 78%,
        #4f6f3a 78% 100%
    );
}
.plate-e {
    background: radial-gradient(
        circle at 45% 35%,
        #976633 0 24%,
        #e2b860 24% 44%,
        #5b8544 44% 62%,
        #603820 62% 78%,
        #95b870 78% 100%
    );
}
.plate-f {
    background: radial-gradient(
        circle at 42% 32%,
        #6eab59 0 28%,
        #d8e4a8 28% 46%,
        #3c8453 46% 66%,
        #f2df9f 66% 82%,
        #518d4f 82% 100%
    );
}
.plate-g {
    background: radial-gradient(
        circle at 42% 38%,
        #c08b3d 0 26%,
        #6b8f4d 26% 48%,
        #b05e2d 48% 65%,
        #d8c47f 65% 84%,
        #507344 84% 100%
    );
}
.plate-h {
    background: radial-gradient(
        circle at 45% 34%,
        #87603b 0 25%,
        #d1b985 25% 45%,
        #5b7340 45% 62%,
        #8e5f37 62% 80%,
        #405e39 80% 100%
    );
}
.plate-i {
    background: radial-gradient(
        circle at 44% 36%,
        #7aa060 0 24%,
        #e0c36f 24% 46%,
        #4f7a48 46% 66%,
        #d57f5e 66% 83%,
        #3d6138 83% 100%
    );
}
.plate-j {
    background: radial-gradient(
        circle at 43% 36%,
        #cf7e46 0 25%,
        #e4d085 25% 45%,
        #6f8a43 45% 63%,
        #9f4d2f 63% 81%,
        #58753e 81% 100%
    );
}
.plate-k {
    background: radial-gradient(
        circle at 40% 35%,
        #9a4060 0 23%,
        #d9ba72 23% 44%,
        #4f7841 44% 62%,
        #c0894a 62% 80%,
        #49673b 80% 100%
    );
}
.plate-l {
    background: radial-gradient(
        circle at 42% 34%,
        #83b058 0 28%,
        #e4d68d 28% 46%,
        #5f8e46 46% 66%,
        #bfd07a 66% 84%,
        #476a3a 84% 100%
    );
}
.plate-dessert {
    background: radial-gradient(
        circle at 50% 50%,
        #7d5a42 0 22%,
        #f2efde 22% 64%,
        #ded9c6 64% 100%
    );
}

.product-card h3 {
    margin: 0 0 8px;
    font-size: 1.22rem;
    font-family: var(--font-primary);
    letter-spacing: 0.02em;
}

.product-card p {
    margin: 0;
    font-size: 0.84rem;
    line-height: 1.42;
    color: var(--muted);
}

.product-allergens {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
}

.product-allergen {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 26px;
    height: 26px;
    padding: 0;
    border: 0;
    background: transparent;
    border-radius: 50%;
    flex-shrink: 0;
}

.product-allergen img {
    width: auto;
    height: 25px;
    max-width: 34px;
    max-height: 25px;
    object-fit: contain;
    border-radius: 50%;
    display: block;
}

.allergen-icons {
    margin-top: 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.allergen-badge {
    --badge-color: #8f8b84;
    --badge-bg: rgba(255, 255, 255, 0.28);
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid var(--badge-color);
    background: var(--badge-bg);
    color: var(--badge-color);
    display: grid;
    place-items: center;
    font-size: 0.9rem;
    line-height: 1;
}

.allergen-gluten {
    --badge-color: #c4a14d;
    --badge-bg: rgba(228, 205, 145, 0.2);
}

.allergen-vegan-option {
    --badge-color: #67ad4d;
    --badge-bg: rgba(135, 190, 115, 0.18);
}

.allergen-peanuts,
.allergen-tree-nuts {
    --badge-color: #b98653;
    --badge-bg: rgba(201, 159, 122, 0.2);
}

.allergen-sesame {
    --badge-color: #c9ba8b;
    --badge-bg: rgba(213, 199, 157, 0.22);
}

.allergen-dairy,
.allergen-egg,
.allergen-soy {
    --badge-color: #8f959c;
    --badge-bg: rgba(191, 198, 205, 0.24);
}

.allergen-fish {
    --badge-color: #6f9ebb;
    --badge-bg: rgba(141, 179, 201, 0.2);
}

.allergen-shellfish {
    --badge-color: #cb8f68;
    --badge-bg: rgba(216, 157, 124, 0.2);
}

.product-meta {
    margin-top: auto;
    padding-top: 14px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.price {
    font-size: 0.96rem;
    color: #6a7078;
    white-space: nowrap;
}

.add-btn {
    width: 24px;
    height: 24px;
    border-radius: 4px;
    border: 0;
    background: #d0c9be;
    color: #ffffff;
    font-size: 1.05rem;
    line-height: 1;
    cursor: pointer;
    flex-shrink: 0;
}

.add-btn:hover {
    background: #bfb7ab;
}

.lumina-offer-indicator {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 3;
    min-width: 42px;
    height: 22px;
    padding: 0 7px;
    border-radius: 999px;
    background: #d9d1c4;
    color: #233241;
    border: 1px solid rgba(35, 50, 65, 0.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.7),
        0 3px 8px rgba(28, 30, 36, 0.14);
}

.list-block {
    border: 1px solid var(--card-line);
    border-radius: 10px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.08);
}

.list-row {
    padding: 18px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
}

.list-row + .list-row {
    border-top: 1px solid #e4dfd5;
}

.row-name {
    margin: 0;
    font-size: 0.94rem;
    letter-spacing: 0.01em;
}

.row-meta {
    display: flex;
    align-items: center;
    gap: 12px;
}

.menu-footer {
    min-height: 540px;
    display: grid;
    place-items: center;
    text-align: center;
    color: #b5bcc3;
}

.footer-inner {
    display: grid;
    gap: 14px;
    justify-items: center;
    padding-bottom: 24px;
}

.lumina-hours {
    width: min(440px, 96vw);
    border: 1px solid #dcd5ca;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.45);
    padding: 14px 14px 12px;
    text-align: left;
    position: static;
}

.lumina-hours h4 {
    margin: 0 0 10px;
    font-size: 1rem;
    color: #2f3f4f;
}

.lumina-hours-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 7px;
}

.lumina-hours-list li {
    display: grid;
    grid-template-columns: minmax(120px, 1fr) 1fr;
    gap: 12px;
    align-items: center;
    font-size: 0.9rem;
    color: #4d5b69;
}

.lumina-hours-day {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.lumina-hours-badge {
    width: 18px;
    height: 18px;
    border-radius: 6px;
    background: rgba(124, 208, 175, 0.28);
    display: inline-block;
    position: relative;
}

.lumina-hours-badge::before {
    content: "";
    position: absolute;
    left: 7px;
    top: 5px;
    width: 0;
    height: 0;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 5px solid #2a8f6f;
}

.lumina-hours-range {
    text-align: right;
    color: #5a6876;
}

.lumina-hours-list .is-today .lumina-hours-day,
.lumina-hours-list .is-today .lumina-hours-range {
    font-weight: 700;
    color: #334556;
}

.souse-badge {
    border: 4px solid #aeb4ba;
    border-radius: 10px;
    padding: 10px 18px;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    line-height: 1;
    color: #aeb4ba;
}

.footer-links {
    margin: 0;
    font-size: 0.98rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
}

.footer-links a {
    color: #b2b9c0;
    text-decoration: none;
}

.footer-links a:hover {
    text-decoration: underline;
}

.footer-version {
    margin: 0;
    font-size: 0.9rem;
    color: #bcc2c8;
}

.mobile-checkout {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: max(10px, env(safe-area-inset-bottom));
    height: 52px;
    border: 0;
    border-radius: 8px;
    background: #c7c0b5;
    color: #263544;
    z-index: 36;
    display: none;
    align-items: center;
    justify-content: space-between;
    padding: 0 12px;
    font-size: 0.96rem;
    font-weight: 500;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.18);
}

.mobile-checkout.active {
    background: #b8b0a3;
}

.mobile-count {
    min-width: 44px;
    height: 24px;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.72);
    display: grid;
    place-items: center;
    font-size: 0.88rem;
}

.mobile-total {
    font-weight: 600;
    white-space: nowrap;
}

.mobile-cart-popover {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: calc(max(10px, env(safe-area-inset-bottom)) + 60px);
    border: 1px solid #d7d0c4;
    border-radius: 10px;
    background: rgba(247, 243, 238, 0.98);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
    padding: 10px 12px 12px;
    z-index: 35;
    display: none;
    opacity: 0;
    transform: translateY(16px) scale(0.98);
    transform-origin: bottom center;
    pointer-events: none;
    transition:
        opacity 0.22s ease,
        transform 0.22s ease;
}

.mobile-cart-popover.open {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

.mobile-cart-popover-title {
    margin: 0 0 8px;
    font-size: 1rem;
    font-family: var(--font-primary);
    font-weight: 700;
    color: #2b3a49;
}

.mobile-cart-items {
    max-height: 176px;
    overflow-y: auto;
    display: grid;
    gap: 7px;
    margin-bottom: 10px;
    padding-right: 2px;
}

.mobile-cart-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    font-size: 0.82rem;
    color: #4d5b68;
}

.mobile-cart-item + .mobile-cart-item {
    border-top: 1px solid #e2ddd3;
    padding-top: 7px;
}

.mobile-cart-row.is-expandable {
    cursor: pointer;
}

.mobile-cart-row-name {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    line-height: 1.35;
}

.mobile-cart-reduce {
    width: 22px;
    height: 22px;
    border-radius: 4px;
    border: 0;
    background: #d0c9be;
    color: #ffffff;
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    flex-shrink: 0;
    display: grid;
    place-items: center;
}

.mobile-cart-reduce:hover {
    background: #bfb7ab;
}

.mobile-cart-toggle-indicator {
    font-size: 0.6rem;
    color: #66727d;
}

.mobile-cart-row-price {
    white-space: nowrap;
    font-weight: 500;
}

.mobile-cart-details {
    margin-top: 6px;
    border: 1px solid #ddd5c9;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.35);
    padding: 7px 8px;
    color: #64717d;
}

.mobile-cart-details-label {
    margin: 0 0 5px;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.mobile-cart-details-list {
    margin: 0;
    padding-left: 15px;
    display: grid;
    gap: 3px;
    font-size: 0.72rem;
    line-height: 1.32;
}

.mobile-cart-popover-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.79rem;
    color: #5d6a78;
    border-top: 1px solid #ddd5c9;
    padding-top: 9px;
    margin-bottom: 10px;
}

.mobile-cart-clear-btn {
    width: 100%;
    height: 34px;
    border-radius: 6px;
    border: 1px solid rgba(35, 50, 65, 0.18);
    background: rgba(217, 209, 196, 0.55);
    color: #233241;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    cursor: pointer;
    margin: 0 0 8px;
}

.mobile-cart-clear-btn:hover {
    background: rgba(207, 198, 184, 0.85);
}

.mobile-order-btn {
    width: 100%;
    height: 40px;
    border: 0;
    border-radius: 7px;
    background: #c4bcaf;
    color: #263544;
    font-size: 0.86rem;
    letter-spacing: 0.05em;
    font-weight: 700;
    cursor: pointer;
}

.mobile-order-btn:hover {
    background: #b5ad9f;
}

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(14, 17, 20, 0.5);
    backdrop-filter: blur(3px);
    z-index: 90;
    display: grid;
    place-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
    padding: 24px;
}

.modal-overlay.open {
    opacity: 1;
    pointer-events: auto;
}

.item-modal {
    width: min(920px, 95vw);
    max-height: min(88vh, 980px);
    background: var(--header-bg);
    border-radius: 12px;
    border: 1px solid #d0c8bc;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.34);
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    overflow: hidden;
    position: relative;
}

.modal-close-top {
    position: absolute;
    top: 16px;
    right: 16px;
    z-index: 3;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 0;
    background: #aeaba5;
    color: #f6f4ef;
    font-size: 2rem;
    line-height: 1;
    cursor: pointer;
}

.item-modal-scroll {
    overflow-y: auto;
    padding: 20px 22px 8px;
}

.modal-image-wrap {
    margin: 4px auto 10px;
    width: fit-content;
}

.modal-image {
    width: min(92vw, 360px);
    height: min(92vw, 360px);
    max-width: 360px;
    max-height: 360px;
    object-fit: cover;
    border-radius: 0;
    border: 0;
    box-shadow: none;
    background: transparent;
}

.modal-plate {
    width: min(92vw, 360px);
    height: min(92vw, 360px);
    max-width: 360px;
    max-height: 360px;
    border-radius: 50%;
    border: 7px solid rgba(245, 244, 237, 0.95);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.14);
}

.modal-plate.plate-extra,
.modal-plate.plate-coffee,
.modal-plate.plate-tea,
.modal-plate.plate-cold,
.modal-plate.plate-water {
    background: radial-gradient(
        circle at 46% 40%,
        #c8ab7c 0 28%,
        #7a9e54 28% 48%,
        #d6c58a 48% 66%,
        #50653f 66% 84%,
        #b37a4e 84% 100%
    );
}

.modal-head {
    margin-top: 10px;
}

.modal-title {
    margin: 0;
    font-family: var(--font-primary);
    font-size: 2rem;
    font-weight: 500;
    letter-spacing: 0.02em;
}

.modal-subtitle {
    margin: 6px 0 0;
    font-size: 0.83rem;
    color: #7f898f;
    text-transform: uppercase;
}

.modal-description {
    margin: 8px 0 0;
    font-size: 0.88rem;
    line-height: 1.45;
    color: #65707a;
}

.modal-allergen-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.modal-allergen-pill {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid #d7cfbf;
    background: rgba(255, 255, 255, 0.35);
    font-size: 0.78rem;
    color: #566372;
}

.food-configurator {
    margin-top: 18px;
}

.option-group {
    margin-top: 20px;
}

.option-group-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.05rem;
    margin: 0 0 12px;
    color: #464f5a;
}

.option-group-title::after {
    content: "";
    flex: 1;
    height: 1px;
    border-bottom: 1px dashed #d7d1c6;
}

.option-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.option-item {
    border: 1px solid #ddd7cc;
    border-radius: 10px;
    padding: 14px 14px;
    background: rgba(255, 255, 255, 0.2);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
}

.option-item-name {
    margin: 0;
    font-size: 0.98rem;
    color: #46505b;
}

.option-item-price {
    margin: 4px 0 0;
    font-size: 0.86rem;
    color: #6e7982;
}

.option-check {
    width: 20px;
    height: 20px;
    border: 2px solid #ccc4b8;
    border-radius: 2px;
    flex-shrink: 0;
    margin-top: 2px;
    background: transparent;
}

.option-item.selected {
    border-color: #b7ae9f;
    background: rgba(182, 173, 158, 0.18);
}

.option-item.selected .option-check {
    background: #9ea6ad;
    border-color: #9ea6ad;
}

.simple-configurator {
    margin-top: 10px;
}

.modal-quantity-wrap {
    margin: 22px 0 8px;
    display: grid;
    place-items: center;
}

.qty-control {
    display: inline-flex;
    border: 1px solid #b7b8b7;
    border-radius: 6px;
    overflow: hidden;
}

.qty-btn {
    width: 52px;
    height: 46px;
    border: 0;
    background: #d8dde0;
    color: #35414d;
    font-size: 1.45rem;
    line-height: 1;
    cursor: pointer;
}

.qty-btn:hover {
    background: #cad1d5;
}

.qty-value {
    width: 74px;
    height: 46px;
    display: grid;
    place-items: center;
    border-left: 1px solid #b7b8b7;
    border-right: 1px solid #b7b8b7;
    font-size: 1.6rem;
    font-family: var(--font-primary);
}

.modal-footer {
    display: flex;
    justify-content: center;
    align-items: center;
}

.modal-back-btn {
    border: 0;
    border-radius: 6px;
    background: #cdc6bb;
    color: #263544;
    font-size: 2.3rem;
    line-height: 1;
    cursor: pointer;
    display: grid;
    place-items: center;
    padding-bottom: 4px;
}

.modal-add-btn {
    border: 0;
    border-radius: 6px;
    background: #c6c0b5;
    color: #263544;
    font-size: 0.98rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    cursor: pointer;
    padding: 0 14px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.modal-add-btn:hover {
    background: #b8b1a5;
}

.searchable-item.hidden-by-search {
    display: none !important;
}

.menu-section.hidden-by-search {
    display: none !important;
}

@media (max-width: 1320px) {
    .product-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1200px) {
    .site-header {
        padding: 0 12px 0;
    }

    .header-layout {
        grid-template-columns: 1fr;
        gap: 0;
        margin-top: 0;
        padding-right: 0;
    }

    .header-right {
        order: -1;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 12px 72px;
        min-height: 94px;
        margin: 0 -12px 10px;
        border-bottom: 1px solid #dfd9ce;
        filter: none;
    }

    .header-left-title {
        display: none;
    }

    .restorant-logo-mobile {
        display: block;
        position: absolute;
        left: 12px;
        top: 50%;
        transform: translateY(-50%);
        width: 42px;
        height: 42px;
        object-fit: cover;
        object-position: center;
        border-radius: 50%;
        border: 1px solid rgba(35, 50, 65, 0.22);
        box-shadow: 0 2px 6px rgba(20, 25, 33, 0.12);
        z-index: 13;
    }

    .header-actions {
        position: absolute;
        top: 12px;
        right: 12px;
        transform: none;
        margin: 0;
        z-index: 12;
    }

    .lumina-lang-toggle {
        min-width: 74px;
        height: 32px;
        padding: 0 8px;
        gap: 6px;
        font-size: 0.7rem;
    }

    .lumina-lang-caret {
        width: 7px;
        height: 7px;
    }

    .lumina-lang-menu {
        min-width: 150px;
    }

    .restorant-logo {
        width: 42px;
        height: 42px;
    }

    .header-right-brand {
        width: min(540px, 100%);
        min-height: 190px;
        height: 190px;
        transform: translateX(0);
    }

    .logo-top {
        font-size: clamp(1.7rem, 4.8vw, 2.5rem);
    }

    .logo-main {
        font-size: clamp(2.35rem, 8.2vw, 4.2rem);
        letter-spacing: 0.02em;
        margin-left: auto;
        margin-right: auto;
    }

    .header-left h1 {
        margin-top: 0;
        padding-right: 0;
    }

    .search-wrap {
        margin-top: 14px;
        padding: 9px 0;
    }

    .header-category-nav {
        margin-top: 0;
        padding-bottom: 10px;
        border-bottom: 1px solid #dfd9ce;
        flex-wrap: nowrap;
        overflow-x: auto;
        scrollbar-width: none;
    }

    .header-category-nav::-webkit-scrollbar {
        display: none;
    }
}

@media (max-width: 1040px) {
    :root {
        --cart-width: 0px;
    }

    .floating-nav-inner {
        padding-right: 12px;
    }

    .page-layout {
        grid-template-columns: 1fr;
        gap: 0;
        padding-bottom: 84px;
    }

    .menu-column {
        padding-left: 12px;
        padding-right: 12px;
    }

    .cart-column {
        display: none;
    }

    .mobile-checkout {
        display: flex;
    }

    .mobile-cart-popover {
        display: block;
    }

    .item-modal {
        width: min(96vw, 760px);
    }

    .lumina-offers-btn {
        top: auto;
        bottom: 88px;
        transform: none;
        writing-mode: horizontal-tb;
        border-right: 1px solid rgba(35, 50, 65, 0.18);
        border-radius: 10px;
        right: 10px;
        padding: 8px 10px;
    }
}

@media (max-width: 760px) {
    .header-right {
        padding: 10px 56px;
        min-height: 82px;
    }

    .restorant-logo-mobile {
        left: 10px;
        top: 50%;
        transform: translateY(-50%);
        width: 38px;
        height: 38px;
    }

    .header-actions {
        position: absolute;
        top: 12px;
        right: 12px;
        transform: none;
        margin: 0;
        z-index: 12;
    }

    .restorant-logo {
        width: 38px;
        height: 38px;
    }

    .header-left-title {
        gap: 8px;
    }

    .header-right-brand {
        min-height: 150px;
        height: 150px;
        width: 100%;
        max-width: 100%;
        padding: 10px 12px;
        transform: translateX(0);
        margin-right: 0;
    }

    .logo-top {
        font-size: clamp(1.65rem, 7vw, 2.3rem);
    }

    .logo-main {
        font-size: clamp(1.9rem, 10.2vw, 3.2rem);
        letter-spacing: 0.02em;
    }

    .header-left h1 {
        margin-top: 0;
        padding-right: 0;
        font-size: clamp(0.95rem, 4.2vw, 1.08rem);
    }

    .address {
        font-size: 0.82rem;
    }

    .lumina-opening-status {
        font-size: 0.72rem;
        padding: 4px 9px;
    }

    .lumina-status-row {
        gap: 8px;
    }

    .lumina-callwaiter-btn {
        height: 31px;
        padding: 0 10px;
        font-size: 0.72rem;
    }

    #headerSearch {
        font-size: clamp(1.06rem, 5.2vw, 1.32rem);
    }

    .category-nav {
        gap: 8px 12px;
    }

    .header-category-nav .nav-link {
        font-size: 0.84rem;
    }

    .floating-nav-inner {
        min-height: 48px;
        gap: 6px;
        padding-left: 8px;
        padding-right: 8px;
    }

    .floating-nav .nav-link {
        font-size: 0.88rem;
    }

    .floating-search-wrap.open {
        max-width: 58vw;
    }

    #floatingSearch {
        width: 56vw;
        min-width: 130px;
    }

    .page-layout {
        padding-top: 10px;
    }

    .menu-column {
        padding-left: 10px;
        padding-right: 10px;
    }

    .section-title {
        margin-bottom: 12px;
    }

    .product-grid {
        grid-template-columns: 1fr;
    }

    .product-card {
        min-height: 344px;
    }

    .plate {
        width: 150px;
        height: 150px;
    }

    .list-row {
        padding: 14px 12px;
    }

    .menu-footer {
        min-height: 360px;
    }

    .souse-badge {
        font-size: 1.2rem;
        padding: 8px 14px;
    }

    .footer-links {
        font-size: 0.88rem;
    }

    .footer-version {
        font-size: 0.82rem;
    }

    .lumina-hours {
        margin-top: 35px;
        width: 100%;
        padding: 12px 10px 10px;
        position: static;
        top: auto;
        right: auto;
        left: auto;
    }

    .lumina-hours-list li {
        grid-template-columns: 1fr;
        gap: 2px;
    }

    .lumina-hours-range {
        text-align: left;
    }

    .modal-overlay {
        padding: 10px;
    }

    .item-modal {
        width: 100%;
        max-height: 93vh;
        border-radius: 10px;
    }

    .item-modal-scroll {
        padding: 16px 12px 8px;
    }

    .modal-close-top {
        top: 8px;
        right: 8px;
        width: 40px;
        height: 40px;
    }

    .modal-plate {
        width: min(76vw, 260px);
        height: min(76vw, 260px);
    }

    .modal-image {
        width: min(76vw, 260px);
        height: min(76vw, 260px);
    }

    .modal-title {
        font-size: 1.5rem;
    }

    .option-grid {
        grid-template-columns: 1fr;
    }

    .modal-footer {
        grid-template-columns: 46px minmax(0, 1fr);
        padding: 8px 10px 10px;
    }

    .modal-back-btn {
        font-size: 2rem;
    }

    .modal-add-btn {
        font-size: 0.88rem;
    }
}

@media (max-width: 420px) {
    .logo-main {
        font-size: clamp(1.55rem, 9.5vw, 2.55rem);
    }

    .header-right {
        padding-left: 8px;
        padding-right: 8px;
    }

    .search-icon {
        width: 31px;
        height: 31px;
        font-size: 13px;
    }

    .mobile-checkout {
        height: 50px;
        font-size: 0.9rem;
        padding: 0 10px;
    }

    .mobile-cart-popover {
        bottom: calc(max(10px, env(safe-area-inset-bottom)) + 58px);
    }

    .mobile-count {
        min-width: 40px;
        height: 22px;
    }

    .mobile-cart-popover-title {
        font-size: 0.94rem;
    }

    .mobile-order-btn {
        height: 38px;
        font-size: 0.82rem;
    }
}
.product-card img {
    width: 100%;
    max-width: 180px;
    height: 180px;
    object-fit: cover;
    margin: 0 auto 12px;
    display: block;
}

@media (max-width: 760px) {
    .product-card img {
        max-width: 150px;
        height: 150px;
    }
}
