:root {
    /* Spot v5 — Янтарная палитра: тепло, гостеприимство, вечер */
    --font-sans: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --font-display: "Outfit", var(--font-sans);

    /* Тёплый off-white фон (как старая бумага или лён) */
    --bg: #faf9f6;
    --bg-soft: #f3ede0;
    --surface: #ffffff;

    /* Типографика: тёплые тона, не холодный zinc */
    --ink: #1c1007;
    --text: #2a1e0c;
    --muted: #78716c;
    --faint: #a8a29e;
    --panel: rgba(255, 255, 255, 0.98);
    --panel-strong: #ffffff;

    /* Разделители: тёплые */
    --line: #e8dece;
    --line-strong: #d4c4a8;

    /* Янтарный акцент — главный цвет бренда */
    --accent: #d97706;
    --accent-soft: rgba(217, 119, 6, 0.1);
    --accent-glow: rgba(217, 119, 6, 0.22);
    --accent-border: rgba(217, 119, 6, 0.28);
    --accent-2: #0f766e;
    --accent-2-soft: rgba(15, 118, 110, 0.1);
    --link: #b45309;
    --link-hover: #92400e;

    /* Primary button: тёмно-коричневый (янтарь на hover/focus) */
    --btn-primary-bg: #18130a;
    --btn-primary-text: #faf9f6;
    --btn-primary-hover: #0e0a04;
    --accent-pill: var(--accent);
    --accent-pill-text: #18130a;

    --tap-min: 44px;
    --radius-island: 12px;
    --radius-pill: 999px;

    --spot-warm: #d97706;
    --spot-warm-soft: rgba(217, 119, 6, 0.12);

    /* Алиасы для формы брони (.bk-submit) — без них фон кнопки не задаётся */
    --amber: #d97706;
    --amber-dark: #b45309;

    /* Тени: тёплый оттенок */
    --shadow-sm: 0 1px 2px rgba(28, 16, 7, 0.05), 0 2px 4px rgba(28, 16, 7, 0.04);
    --shadow-md: 0 4px 6px rgba(28, 16, 7, 0.05), 0 10px 24px rgba(28, 16, 7, 0.08);
    --shadow-elevated: 0 20px 48px rgba(28, 16, 7, 0.12);

    --input-bg: #ffffff;
    --input-border: #d4c4a8;

    --danger: #dc2626;
    --danger-soft: rgba(220, 38, 38, 0.08);
    --success: #16a34a;
    --success-soft: rgba(22, 163, 74, 0.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

.skip-link {
    position: absolute;
    left: -9999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
    z-index: 9999;
}
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.venue-subscribe-panel {
    max-width: 560px;
    margin: 0 auto;
}
.venue-subscribe-title {
    margin-top: 0;
    font-size: 24px;
    letter-spacing: -0.02em;
}
.venue-subscribe-form fieldset {
    border: none;
    padding: 0;
    margin: 0 0 20px;
}
.venue-subscribe-plans {
    display: grid;
    gap: 12px;
}
.venue-subscribe-plan {
    display: block;
    cursor: pointer;
    border-radius: 16px;
    border: 1px solid var(--line);
    margin: 0;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.venue-subscribe-plan:hover {
    border-color: rgba(217, 119, 6, 0.35);
}
.venue-subscribe-plan input {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
}
.venue-subscribe-plan input:focus-visible + .venue-subscribe-plan-inner {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}
.venue-subscribe-plan input:checked + .venue-subscribe-plan-inner {
    border-color: rgba(217, 119, 6, 0.55);
    box-shadow: 0 0 0 1px rgba(217, 119, 6, 0.2);
}
.venue-subscribe-plan--rec {
    border-color: rgba(217, 119, 6, 0.35);
    background: var(--accent-soft);
}
.venue-subscribe-plan-inner {
    display: grid;
    gap: 6px;
    padding: 16px 18px;
    border-radius: 15px;
}
.venue-subscribe-plan-name {
    font-weight: 800;
    font-size: 17px;
    letter-spacing: -0.02em;
}
.venue-subscribe-plan-price {
    font-size: 18px;
    font-weight: 700;
}
.venue-subscribe-plan-tag {
    font-size: 13px;
    line-height: 1.4;
}
.venue-subscribe-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}
.venue-payment-meta {
    margin-top: 12px;
    font-size: 14px;
}

.skip-link:focus {
    left: max(12px, env(safe-area-inset-left, 0px));
    top: max(12px, env(safe-area-inset-top, 0px));
    width: auto;
    height: auto;
    padding: 10px 16px;
    overflow: visible;
    background: var(--ink);
    color: #fff !important;
    font-weight: 700;
    font-size: 14px;
    border-radius: 10px;
    text-decoration: none;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}
a {
    color: var(--link);
}
a:hover {
    color: var(--link-hover);
}
body {
    margin: 0;
    font-family: var(--font-sans);
    color: var(--text);
    background: var(--bg);
    line-height: 1.58;
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "kern" 1, "liga" 1;
}
h1,
h2,
h3,
h4,
.guest-welcome__title,
.guest-panel-head h3,
.auth-main h3,
.auth-side h2,
.venue-admin-right-head h3,
.venue-admin-left-head h3 {
    font-family: var(--font-display);
}
main.container {
    flex: 1 1 auto;
}

@media (max-width: 900px) {
    html,
    body {
        overflow-x: clip;
        max-width: 100%;
    }
}

.app-bg {
    display: none;
}
.shape { display: none; }
.shape-a, .shape-b, .shape-c { display: none; }

.topbar {
    position: sticky;
    top: 0;
    z-index: 12;
    overflow: visible;
    padding: max(0px, env(safe-area-inset-top, 0px)) 0 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    background: #110c03;
}
.topbar-premium {
    position: relative;
    overflow: visible;
}
.topbar-scan {
    display: none;
}
.topbar-inner {
    position: relative;
    overflow: visible !important;
    max-width: 1280px;
    margin: 0 auto;
    padding: 14px max(20px, env(safe-area-inset-right, 0px)) 14px max(20px, env(safe-area-inset-left, 0px));
    border-radius: 0;
    border: none;
    background: transparent;
    box-shadow: none;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    column-gap: 16px;
    row-gap: 10px;
}
.topbar-spacer {
    flex: 1;
    min-width: 0;
}
.topbar-venue-chip {
    grid-column: 2;
    justify-self: center;
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}
.topbar-venue-icon {
    color: #d97706;
    flex-shrink: 0;
    opacity: 0.85;
}
.topbar-venue-name {
    font-size: 15px;
    font-weight: 800;
    color: #f5f0e8;
    letter-spacing: -0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 280px;
}
.topbar-venue-city {
    font-size: 11px;
    color: rgba(255,255,255,0.55);
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 999px;
    padding: 2px 9px;
    white-space: nowrap;
}
.topbar-guest-lk {
    grid-column: 2;
    justify-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-width: 0;
    width: auto;
    max-width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
}
.topbar-guest-lk-id {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}
.topbar-guest-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    background: var(--btn-primary-bg);
    border: 1px solid var(--btn-primary-bg);
    color: var(--btn-primary-text);
}
.topbar-guest-name {
    font-size: 14px;
    font-weight: 600;
    line-height: 1.2;
    color: rgba(255, 255, 255, 0.9);
}
.topbar-guest-phone {
    font-size: 12px;
    line-height: 1.2;
    color: rgba(255, 255, 255, 0.5);
}
.topbar-guest-metrics {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.topbar-guest-chip {
    padding: 3px 9px;
    border-radius: 999px;
    font-size: 11px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.7);
}
.topbar-guest-lk-mobile {
    display: none;
}
.topbar-has-guest {
    padding-top: 8px;
    padding-bottom: 8px;
}
.topbar-inner.topbar-inner-guest {
    grid-template-columns: auto minmax(420px, 1fr) auto;
    padding-top: 6px;
    padding-bottom: 6px;
    row-gap: 6px;
}
.brand {
    color: #ffffff;
    text-decoration: none;
    font-size: 20px;
    font-weight: 700;
    display: inline-flex;
    gap: 8px;
    align-items: center;
    flex-shrink: 0;
    grid-column: 1;
    justify-self: start;
    transition: opacity 0.15s ease;
}
.brand:hover { opacity: 0.85; color: #ffffff; }
.brand-logo {
    width: 36px;
    height: 36px;
    object-fit: contain;
}
/* Янтарный квадратик-акцент перед логотипом */
.brand-mark {
    width: 9px;
    height: 9px;
    border-radius: 3px;
    background: var(--accent);
    flex-shrink: 0;
    display: block;
}
.brand-text {
    background: none;
    -webkit-background-clip: unset;
    background-clip: unset;
    color: #ffffff;
    -webkit-text-fill-color: #ffffff;
    letter-spacing: -0.025em;
    line-height: 1.1;
    font-family: var(--font-display);
    font-weight: 700;
}

/* Ячейка фиксированной высоты в шапке: строка поиска + раскрытие вниз не двигает лого/меню */
.guest-search-slot {
    grid-column: 2;
    justify-self: center;
    align-self: center;
    position: relative;
    width: min(620px, calc(100vw - 48px));
    max-width: 100%;
    min-height: 52px;
    overflow: visible;
    z-index: 10038;
}

/* Поиск гостя в шапке */
.guest-search-wrap {
    flex: 1;
    min-width: 0;
    display: flex;
    justify-content: center;
    position: relative;
}
.guest-search-trigger {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 9px 16px 9px 12px;
    border-radius: 999px;
    border: 1px solid var(--line-strong);
    background: linear-gradient(165deg, #ffffff, #f7f7f7);
    color: var(--text);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.2s ease;
    box-shadow: var(--shadow-sm);
}
.guest-search-trigger:hover {
    transform: translateY(-1px);
    border-color: rgba(217, 119, 6, 0.35);
    box-shadow: var(--shadow-md);
}
.guest-search-trigger-icon {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid rgba(0, 0, 0, 0.25);
    position: relative;
}
.guest-search-trigger-icon::after {
    content: "";
    position: absolute;
    width: 7px;
    height: 2px;
    background: rgba(0, 0, 0, 0.45);
    right: -5px;
    bottom: -2px;
    transform: rotate(42deg);
    border-radius: 1px;
}
.guest-search-panel {
    position: absolute;
    top: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%) translateY(-14px) scale(0.98);
    width: min(420px, calc(100vw - 48px));
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    filter: blur(10px);
    transition:
        opacity 0.22s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.22s cubic-bezier(0.22, 1, 0.36, 1),
        filter 0.22s cubic-bezier(0.22, 1, 0.36, 1),
        visibility 0.22s;
    z-index: 20;
}
.guest-search-panel.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    filter: blur(0);
    transform: translateX(-50%) translateY(0) scale(1);
    animation: guestSearchIn 0.26s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.guest-search-panel::before {
    content: "";
    position: absolute;
    top: -7px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
    width: 12px;
    height: 12px;
    background: #ffffff;
    border-left: 1px solid var(--line);
    border-top: 1px solid var(--line);
}
.guest-search-form {
    display: grid;
    gap: 10px;
    padding: 10px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: linear-gradient(160deg, #ffffff, #fafafa);
    backdrop-filter: blur(12px);
    box-shadow: var(--shadow-md);
}

/* Поиск гостя - "полный" вид прямо в шапке */
.guest-search-full {
    display: flex;
    gap: 8px;
    flex-direction: row;
    align-items: center;
    padding: 10px 12px;
    flex: 0 0 auto;
    min-width: 0;
    max-width: 620px;
    width: 100%;
    border-radius: 14px;
    justify-self: center;
    align-self: center;
    border: 1px solid var(--line);
    background: linear-gradient(160deg, #ffffff, #fafafa);
    backdrop-filter: blur(12px);
    box-shadow: var(--shadow-md);
    animation: guestSearchIn 0.26s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.guest-search-full .guest-search-main {
    min-width: 0;
    display: flex;
    justify-content: center;
    flex: 1 1 auto;
    width: 100%;
    overflow: visible;
}
.guest-search-full .guest-search-filters {
    padding: 0;
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: center;
    flex: 1 1 auto;
    min-width: 0;
}
.guest-search-main {
    display: flex;
    gap: 8px;
    width: 100%;
    justify-content: center;
}
.guest-search-filters {
    display: flex;
    gap: 10px;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    padding: 0;
    justify-content: flex-start;
}
.filter-option {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    width: auto;
    flex-direction: row;
    gap: 8px;
    color: var(--text);
    font-size: 13px;
    font-weight: 600;
    padding: 8px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    user-select: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
    position: relative;
}
.filter-option { white-space: nowrap; }
.filter-option:hover {
    border-color: var(--accent-border);
}
.filter-option span {
    font: inherit;
    font-weight: 600;
}
.filter-option input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    margin: 0;
    padding: 0;
    left: 0;
    top: 0;
    pointer-events: none;
}
.filter-option:has(input:checked) {
    color: #18130a;
    border-color: var(--accent-border);
    box-shadow: 0 0 0 2px var(--accent-glow) inset;
    background: var(--accent-soft);
    font-weight: 700;
}
.filter-option input[type="checkbox"]:checked {
    background: var(--accent-soft);
    border-color: var(--accent-border);
}
.guest-search-input {
    flex: 1 1 auto;
    max-width: none;
    min-width: 0;
    border: 1px solid var(--input-border);
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 14px;
    color: var(--text);
    background: var(--input-bg);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.guest-search-input:focus {
    outline: none;
    border-color: rgba(217, 119, 6, 0.45);
    box-shadow: 0 0 0 3px var(--accent-soft);
}
.guest-search-submit {
    flex-shrink: 0;
    border: 1px solid var(--btn-primary-bg);
    border-radius: var(--radius-pill);
    padding: 10px 18px;
    font-weight: 700;
    font-size: 13px;
    color: var(--btn-primary-text);
    background: var(--btn-primary-bg);
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.guest-search-submit:hover {
    background: var(--btn-primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}
.topbar-nav a {
    color: rgba(255, 255, 255, 0.65);
    margin-left: 4px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    padding: 8px 10px;
    border-radius: 8px;
    transition: color 0.15s ease, background 0.15s ease;
    min-height: var(--tap-min);
    display: inline-flex;
    align-items: center;
}
.topbar-nav a:hover {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
}
.topbar-nav-links a:first-child { margin-left: 0 !important; }

.topbar-nav {
    grid-column: 3;
    justify-self: end;
    align-self: center;
    z-index: 80;
}
.topbar-nav-links {
    display: flex;
    gap: 4px;
    align-items: center;
}
.topbar-burger {
    display: none;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.06);
    cursor: pointer;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 5px;
    z-index: 90;
    position: relative;
}
.topbar-burger span {
    display: block;
    width: 16px;
    height: 1.5px;
    border-radius: 1px;
    background: rgba(255, 255, 255, 0.8);
}
.nav-cta {
    border: 1px solid transparent;
    border-radius: var(--radius-pill);
    padding: 8px 16px;
    min-height: 36px !important;
    color: #18130a !important;
    background: var(--accent);
    font-weight: 600;
    font-size: 14px !important;
    transition: filter 0.15s ease !important;
}
.nav-cta:hover {
    filter: brightness(1.06);
    background: var(--accent) !important;
    color: #18130a !important;
}

.nav-cta--ghost {
    background: transparent !important;
    border-color: var(--line-strong) !important;
    color: var(--muted) !important;
    font-weight: 500 !important;
}

.nav-cta--ghost:hover {
    background: var(--bg-soft) !important;
    color: var(--text) !important;
    filter: none !important;
}

.container {
    max-width: 1200px;
    margin: 34px auto;
    padding: 0 max(16px, env(safe-area-inset-left, 0px)) max(40px, env(safe-area-inset-bottom, 0px))
        max(16px, env(safe-area-inset-right, 0px));
    position: relative;
    z-index: 2;
}

.hero,
.panel,
.auth-shell {
    opacity: 0;
    transform: translateY(8px);
    transition: transform 0.4s ease, opacity 0.4s ease;
}
.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.hero {
    position: relative;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-island);
    padding: 40px 36px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}
.hero::after {
    display: none;
}
.hero-logo {
    width: 64px;
    height: 64px;
    display: block;
    margin-bottom: 12px;
}
.hero h1 { margin-top: 0; font-size: 34px; letter-spacing: -0.02em; line-height: 1.18; }
.hero p { color: var(--muted); max-width: 720px; font-size: 16px; line-height: 1.6; }

.panel {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-island);
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: var(--shadow-sm);
    transition: border-color 0.15s ease;
}
.panel.narrow { max-width: 560px; margin: 0 auto 20px; }
.panel:hover { border-color: var(--line-strong); box-shadow: var(--shadow-sm); }

.grid { display: grid; gap: 16px; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.four { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--tap-min);
    border: 1px solid var(--btn-primary-bg);
    color: var(--btn-primary-text);
    background: var(--btn-primary-bg);
    border-radius: var(--radius-pill);
    padding: 10px 20px;
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
}
.btn:hover {
    background: var(--btn-primary-hover);
    border-color: var(--btn-primary-hover);
    color: var(--btn-primary-text);
    filter: none;
    transform: none;
    box-shadow: none;
}
.btn-ghost {
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--line-strong);
}
.btn-ghost:hover {
    background: var(--bg-soft);
    border-color: var(--line-strong);
    color: var(--text);
}
.btn-danger-ghost {
    background: var(--danger-soft);
    color: var(--danger);
    border-color: rgba(220, 38, 38, 0.3);
}
.btn-small {
    font-size: 13px;
    min-height: 36px;
    padding: 7px 14px;
    border-radius: 8px;
}
@media (max-width: 900px) {
    .btn-small {
        min-height: var(--tap-min);
        padding: 10px 16px;
    }
}

.actions { margin-top: 20px; display: flex; gap: 12px; flex-wrap: wrap; }
.muted { color: var(--muted); }

.form-grid { display: grid; gap: 10px; }
label input:not([type="checkbox"]), label textarea, label select {
    margin-top: 6px;
    width: 100%;
    border: 1px solid var(--input-border);
    border-radius: 10px;
    padding: 9px 10px;
    color: var(--text);
    background: var(--input-bg);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
label input:not([type="checkbox"]):focus, label textarea:focus, label select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
}

.alert {
    background: var(--accent-soft);
    border: 1px solid var(--accent-border);
    padding: 12px 14px;
    border-radius: 8px;
    margin-bottom: 14px;
    font-size: 14px;
    line-height: 1.5;
}
.alert--success {
    background: var(--success-soft);
    border-color: rgba(22, 163, 74, 0.25);
    color: var(--text);
}
.alert--error {
    background: var(--danger-soft);
    border-color: rgba(220, 38, 38, 0.25);
    color: var(--text);
}
.alert--warning {
    background: rgba(217, 119, 6, 0.08);
    border-color: rgba(217, 119, 6, 0.3);
}
.alert--info,
.alert--debug {
    background: var(--accent-soft);
    border-color: var(--accent-border);
}
.row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid var(--line);
    padding: 10px 0;
}
.row-title {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-areas:
        "avatar title"
        "avatar meta";
    column-gap: 10px;
    align-items: center;
}
.row-title strong { grid-area: title; }
.row-title .muted { grid-area: meta; }
.booking-item {
    border-bottom: 1px solid var(--line);
    padding: 10px 0;
}

/* Venue admin panel (бронь + схема столов) */
.venue-admin-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.venue-admin-est-select {
    display: grid;
    gap: 8px;
    justify-items: end;
}
.venue-admin-title-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
}
.venue-admin-title-label {
    font-size: 18px;
    font-weight: 800;
    color: var(--ink);
    letter-spacing: -0.01em;
}
.venue-admin-title-city {
    font-size: 13px;
    color: var(--muted);
    padding: 3px 10px;
    border-radius: 999px;
    background: var(--surface);
    border: 1px solid var(--line);
}
.venue-admin-select {
    min-width: 260px;
    height: 42px;
    border-radius: 12px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--text);
    padding: 0 12px;
}

.venue-admin-shell {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.12fr);
    align-items: stretch;
}
.panel.venue-admin-left {
    display: flex;
    flex-direction: column;
}
.page-venue-dashboard main.container.container--guest-wide {
    max-width: 1680px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: max(16px, env(safe-area-inset-left, 0px)) !important;
    padding-right: max(16px, env(safe-area-inset-right, 0px)) !important;
    box-sizing: border-box !important;
    min-width: 0;
}
.venue-left-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.venue-left-tab {
    flex: 1 1 auto;
    min-width: 120px;
    padding: 10px 14px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.85);
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    color: var(--text);
    transition: background 0.15s ease, border-color 0.15s ease;
}
.venue-left-tab:hover {
    border-color: rgba(217, 119, 6, 0.35);
}
.venue-left-tab.is-active {
    border-color: rgba(217, 119, 6, 0.45);
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}
.venue-left-pane[hidden] {
    display: none !important;
}
.venue-filters-extras {
    margin-top: 10px;
    font-size: 13px;
}
.venue-filters-extras summary {
    cursor: pointer;
    color: var(--muted);
    font-weight: 600;
    user-select: none;
}
.venue-filters-extras-body {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}
.venue-filters-extras-hint {
    font-size: 12px;
}
.venue-filters-details {
    margin-bottom: 10px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.45);
    padding: 0 10px 8px;
}
.venue-filters-details > summary.venue-filters-details-summary {
    cursor: pointer;
    list-style: none;
    font-weight: 700;
    font-size: 13px;
    padding: 10px 4px 6px;
    color: var(--text);
    user-select: none;
}
.venue-filters-details > summary.venue-filters-details-summary::-webkit-details-marker {
    display: none;
}
.venue-filters-details-body {
    padding-bottom: 4px;
}
.venue-left-pane-bookings {
    display: flex;
    flex-direction: column;
    min-height: 0;
    flex: 1 1 auto;
}
.venue-menu-panel {
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.65);
    margin-bottom: 10px;
}
.venue-analytics-panel {
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.65);
    margin-bottom: 10px;
    display: grid;
    gap: 12px;
}
body.venue-analytics-open {
    overflow: hidden;
}
.venue-analytics-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 100120;
    background: rgba(0, 0, 0, 0.58);
    backdrop-filter: blur(4px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 14px;
}
.venue-analytics-modal-overlay.is-open {
    display: flex;
}
.venue-analytics-modal {
    width: min(1500px, calc(100vw - 18px));
    height: calc(100vh - 24px);
    border-radius: 18px;
    border: 1px solid var(--line);
    background: linear-gradient(165deg, #fff, #fafafa);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
}
.venue-analytics-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px 10px;
    border-bottom: 1px solid var(--line);
}
.venue-analytics-modal-head h3 {
    margin: 0 0 4px;
}
.venue-analytics-modal-body {
    flex: 1 1 auto;
    overflow: auto;
    padding: 12px 14px 16px;
    display: grid;
    gap: 12px;
}
.venue-analytics-grid2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.venue-analytics-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}
.venue-analytics-head h4 {
    margin: 0;
    font-size: 15px;
}
.venue-analytics-head-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}
.venue-analytics-head-actions select {
    min-width: 120px;
    height: 34px;
}
.venue-analytics-cards {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}
.venue-analytics-card {
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
    padding: 8px 10px;
}
.venue-analytics-card strong {
    font-size: 18px;
    display: block;
    margin-top: 4px;
}
.venue-analytics-forecast-note {
    font-size: 12px;
    margin: 0 0 12px;
    line-height: 1.45;
}
.venue-analytics-subtitle {
    font-weight: 700;
    margin-bottom: 6px;
}
.venue-analytics-chart {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
    padding: 10px;
    max-height: 300px;
    overflow: auto;
}
.venue-analytics-bar-row {
    display: grid;
    grid-template-columns: 56px 1fr auto;
    gap: 8px;
    align-items: center;
    margin-bottom: 8px;
}
.venue-analytics-bar-label {
    font-size: 12px;
    color: var(--muted);
}
.venue-analytics-bar-track {
    height: 10px;
    border-radius: 999px;
    background: #f1f1f4;
    overflow: hidden;
}
.venue-analytics-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, #f59e0b, #d97706);
    border-radius: inherit;
}
.venue-analytics-bar-meta {
    display: flex;
    gap: 8px;
    font-size: 12px;
}
.venue-analytics-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    border-bottom: 1px dashed rgba(0, 0, 0, 0.08);
    padding: 6px 0;
}
.venue-analytics-top-row:last-child {
    border-bottom: none;
}
.venue-analytics-insights-list {
    margin: 0;
    padding-left: 18px;
    line-height: 1.5;
}
.venue-analytics-guests-table-wrap {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
    overflow: auto;
    max-height: 420px;
}
.venue-analytics-guests-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.venue-analytics-guests-table th,
.venue-analytics-guests-table td {
    text-align: left;
    border-bottom: 1px solid var(--line);
    padding: 8px 10px;
    white-space: nowrap;
}
.venue-analytics-guests-table thead th {
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 1;
    cursor: pointer;
    user-select: none;
}
.venue-analytics-guests-table thead th[data-sort-key]:hover {
    background: #f7f7f7;
}
.venue-analytics-guests-table thead th.sort-asc::after { content: " ↑"; opacity: .6; }
.venue-analytics-guests-table thead th.sort-desc::after { content: " ↓"; opacity: .6; }

.venue-analytics-guests-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 10px;
}
.venue-analytics-guests-head .venue-analytics-subtitle {
    margin: 0;
}
.venue-analytics-guests-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 10px;
}
.venue-seg-filter-btn {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    border-radius: 20px;
    border: 1px solid var(--line);
    background: #fff;
    font-size: 13px;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s;
    color: var(--text);
}
.venue-seg-filter-btn:hover { background: #f2f2f2; }
.venue-seg-filter-btn.is-active {
    background: var(--brand, #e03737);
    border-color: var(--brand, #e03737);
    color: #fff;
}

/* ── Segment badges ─────────────────────────────────────────────── */
.va-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
}
.va-badge-vip    { background: #fff3cd; color: #856404; border: 1px solid #ffc107; }
.va-badge-loyal  { background: #d1e7dd; color: #146c43; border: 1px solid #198754; }
.va-badge-new    { background: #cfe2ff; color: #084298; border: 1px solid #0d6efd; }
.va-badge-sleep  { background: #e9ecef; color: #495057; border: 1px solid #adb5bd; }
.va-badge-cancel { background: #f8d7da; color: #842029; border: 1px solid #dc3545; }
.va-badge-default{ background: #f3f4f6; color: #6b7280; border: 1px solid #d1d5db; }

/* ── Отдельная страница аналитики заведения ─────────────────────── */
.page-venue-analytics .va-page {
    max-width: 1180px;
    margin: 0 auto 48px;
}
.va-page__head {
    margin-bottom: 20px;
}
.va-page__head-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}
.va-page__title {
    font-size: 1.65rem;
    margin: 0 0 4px;
    letter-spacing: -0.02em;
}
.va-page__sub {
    margin: 0;
    font-size: 15px;
}
.va-page__crumb {
    font-size: 13px;
    margin-bottom: 8px;
}
.va-page__crumb a {
    text-decoration: none;
    color: inherit;
    opacity: 0.85;
}
.va-page__crumb a:hover {
    text-decoration: underline;
    opacity: 1;
}
.va-page__toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}
.va-page__label {
    margin-right: 2px;
    font-size: 13px;
}
.va-page__switch {
    margin-top: 12px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.va-page__error {
    color: #842029;
    margin: 12px 0;
    padding: 10px 14px;
    background: #f8d7da;
    border-radius: 10px;
    border: 1px solid #f1aeb5;
}
.va-page__forecast-note {
    font-size: 13px;
    margin: 0 0 16px;
    line-height: 1.45;
}
.va-kpi {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
    gap: 10px;
    margin-bottom: 28px;
}
.va-kpi__card {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 12px 14px;
    background: linear-gradient(165deg, #fff 0%, #f9fafb 100%);
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}
.va-kpi__card .muted {
    font-size: 12px;
}
.va-kpi__card strong {
    font-size: 19px;
    font-weight: 700;
    display: block;
    margin-top: 6px;
    letter-spacing: -0.02em;
}
.va-kpi__sub {
    display: block;
    font-size: 11px;
    margin-top: 4px;
}
.va-section {
    margin-bottom: 28px;
}
.va-section__h {
    font-size: 1.05rem;
    margin: 0 0 12px;
    font-weight: 700;
}
.va-doughnuts {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.va-chart-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 14px 14px 10px;
    background: #fff;
}
.va-chart-card--wide {
    grid-column: 1 / -1;
}
.va-chart-card__title {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 8px;
}
.va-chart-card__canvas-wrap {
    position: relative;
    height: 240px;
}
.va-chart-card__canvas-wrap--line {
    height: 300px;
}
.va-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.va-insights {
    margin: 0;
    padding-left: 20px;
    line-height: 1.55;
    font-size: 14px;
}
.va-top-list {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 8px 12px;
    background: #fff;
    max-height: 280px;
    overflow: auto;
    font-size: 14px;
}
.va-top-list__row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid var(--line);
    align-items: baseline;
}
.va-top-list__row:last-child {
    border-bottom: 0;
}
.va-guests-head {
    margin-bottom: 8px;
}
.va-guest-search {
    margin-bottom: 10px;
    max-width: 420px;
}
.va-guests-table-wrap {
    border: 1px solid var(--line);
    border-radius: 12px;
    overflow: auto;
    max-height: 520px;
    background: #fff;
}
@media (max-width: 900px) {
    .va-doughnuts {
        grid-template-columns: 1fr;
    }
    .va-grid-2 {
        grid-template-columns: 1fr;
    }
    .va-page__toolbar {
        width: 100%;
    }
}

@media (max-width: 900px) {
    .venue-analytics-modal {
        width: calc(100vw - 8px);
        height: calc(100vh - 8px);
        border-radius: 12px;
    }
    .venue-analytics-modal-head {
        flex-direction: column;
    }
    .venue-analytics-grid2 {
        grid-template-columns: 1fr;
    }
    .venue-analytics-cards {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .venue-analytics-bar-row {
        grid-template-columns: 48px 1fr;
    }
    .venue-analytics-bar-meta {
        grid-column: 1 / -1;
    }
}
.venue-menu-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}
.venue-menu-panel-head h4 {
    margin: 0;
    font-size: 15px;
}
.venue-menu-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    justify-content: flex-end;
}
.venue-menu-hint {
    font-size: 12px;
    margin-bottom: 10px;
    line-height: 1.45;
}
.venue-menu-body {
    font-size: 13px;
    max-height: min(70vh, 720px);
    overflow-y: auto;
    padding-right: 4px;
}
.venue-menu-cat-block {
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--line);
}
.venue-menu-cat-block:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}
.venue-menu-cat-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}
.venue-menu-cat-title {
    font-weight: 800;
    font-size: 14px;
}
.venue-menu-cat-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-end;
}
.venue-menu-item-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    padding: 8px 0;
    border-top: 1px dashed rgba(0, 0, 0, 0.08);
}
.venue-menu-item-row:first-child {
    border-top: none;
}
.venue-menu-item-main {
    min-width: 0;
    flex: 1 1 auto;
}
.venue-menu-item-actions {
    flex-shrink: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}
.venue-menu-item-price b {
    color: var(--text);
}
.venue-menu-check label {
    font-size: 14px;
    cursor: pointer;
}
.venue-menu-form .book-field textarea {
    width: 100%;
    min-height: 72px;
    border-radius: 12px;
    border: 1px solid var(--input-border);
    padding: 10px 12px;
    font: inherit;
    box-sizing: border-box;
}
.venue-menu-image-inputs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: stretch;
}
.venue-menu-image-inputs input[type="url"] {
    flex: 1 1 160px;
    min-width: 0;
}
.venue-csv-import-hint {
    font-size: 12px;
    line-height: 1.5;
    color: var(--muted);
    margin-bottom: 12px;
}
.venue-csv-import-hint code {
    font-size: 11px;
    background: rgba(0, 0, 0, 0.04);
    padding: 2px 6px;
    border-radius: 6px;
}
.venue-media-overlay {
    position: fixed;
    inset: 0;
    z-index: 100200;
    background: rgba(0, 0, 0, 0.58);
    backdrop-filter: blur(6px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 14px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 180ms ease, visibility 180ms ease;
}
.venue-media-overlay.is-open {
    display: flex;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}
.venue-media-overlay[hidden] {
    display: none !important;
}
.venue-media-sheet {
    width: min(920px, 100%);
    max-height: min(88vh, 900px);
    border-radius: 18px;
    border: 1px solid var(--line);
    background: linear-gradient(165deg, #fff, #faf8f5);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.venue-media-sheet-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px 12px;
    border-bottom: 1px solid var(--line);
}
.venue-media-sheet-head h4 {
    margin: 0 0 4px;
    font-size: 17px;
}
.venue-media-sheet-sub {
    font-size: 13px;
    color: var(--muted);
    margin: 0;
    line-height: 1.4;
}
.venue-media-sheet-body {
    padding: 12px 16px 16px;
    overflow-y: auto;
    flex: 1 1 auto;
}
.venue-media-upload {
    display: grid;
    gap: 10px;
    margin-bottom: 14px;
    padding: 12px;
    border-radius: 14px;
    border: 1px dashed rgba(0, 0, 0, 0.14);
    background: rgba(255, 255, 255, 0.7);
}
.venue-media-upload-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
.venue-media-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 10px;
}
.venue-media-tile {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--line);
    background: #eee;
    aspect-ratio: 1;
    cursor: pointer;
    transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.venue-media-tile:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}
.venue-media-tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.venue-media-tile-del {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 28px;
    height: 28px;
    border-radius: 8px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    background: rgba(255, 255, 255, 0.92);
    cursor: pointer;
    font-size: 16px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}
.venue-media-tile-del:hover {
    background: #fee2e2;
    color: #991b1b;
}
.venue-media-empty {
    text-align: center;
    padding: 24px 12px;
    color: var(--muted);
    font-size: 14px;
}
.venue-admin-select-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: center;
    gap: 12px 16px;
    margin: 4px 0 18px;
}
.venue-admin-topbar-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 6px 0 16px;
    flex-wrap: wrap;
}
.venue-admin-topbar-row .venue-sub-compact {
    flex: 1 1 auto;
    max-width: none;
}
.venue-admin-topbar-row .venue-admin-screen {
    margin-left: auto;
    flex-shrink: 0;
}
.venue-invite-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.venue-sub-compact {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
    padding: 8px 14px;
    border-radius: 999px;
    border: 1px solid rgba(217, 119, 6, 0.22);
    background: linear-gradient(135deg, rgba(217, 119, 6, 0.07), rgba(255, 255, 255, 0.95));
    box-shadow: var(--shadow-sm);
    max-width: min(100%, 420px);
    font-size: 13px;
    line-height: 1.35;
    color: var(--text);
}
.venue-sub-compact__badge {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 999px;
    border: 1px solid rgba(0, 0, 0, 0.06);
}
.venue-sub-compact__badge--trial {
    background: rgba(255, 193, 7, 0.35);
    color: #5d4a00;
}
.venue-sub-compact__badge--paid {
    background: rgba(34, 197, 94, 0.22);
    color: #14532d;
}
.venue-sub-compact__badge--idle {
    background: rgba(217, 119, 6, 0.2);
    color: #7c2d12;
}
.venue-sub-compact__text {
    font-weight: 600;
    color: var(--text);
}
.venue-sub-compact__link {
    font-weight: 700;
    color: var(--accent) !important;
    text-decoration: none;
    margin-left: 4px;
    padding: 4px 8px;
    border-radius: 8px;
}
.venue-sub-compact__link:hover {
    background: var(--accent-soft);
    color: var(--link-hover) !important;
}
@media (max-width: 520px) {
    .venue-sub-compact {
        flex: 1 1 100%;
        max-width: none;
        justify-content: center;
        text-align: center;
    }
}

/* ── Онбординг-чеклист ── */
.venue-onboarding {
    background: linear-gradient(135deg, #fffbf0 0%, #fff7e0 100%);
    border: 1px solid rgba(217,119,6,0.2);
    border-radius: 16px;
    padding: 14px 18px 16px;
    margin-bottom: 16px;
}
.venue-onboarding__top {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}
.venue-onboarding__meta {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
}
.venue-onboarding__title {
    font-size: 13px;
    font-weight: 700;
    color: var(--ink);
}
.venue-onboarding__counter {
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 999px;
    background: rgba(217,119,6,0.12);
    color: var(--link);
    letter-spacing: 0.02em;
}
.venue-onboarding__close {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--muted);
    padding: 4px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    flex-shrink: 0;
    opacity: 0.6;
    transition: opacity 0.15s;
}
.venue-onboarding__close:hover { opacity: 1; }
.venue-onboarding__bar {
    height: 4px;
    background: rgba(217,119,6,0.12);
    border-radius: 99px;
    margin-bottom: 14px;
    overflow: hidden;
}
.venue-onboarding__bar-fill {
    height: 100%;
    border-radius: 99px;
    background: linear-gradient(90deg, #f59e0b, #d97706);
    transition: width 0.5s ease;
}
.venue-onboarding__steps {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 20px;
}
.venue-onboarding__step {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 12.5px;
}
.venue-onboarding__step-icon {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 1.5px solid rgba(217,119,6,0.35);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--link);
    transition: background 0.2s, border-color 0.2s;
}
.venue-onboarding__dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: rgba(217,119,6,0.4);
    display: block;
}
.venue-onboarding__step.is-done .venue-onboarding__step-icon {
    background: #10b981;
    border-color: #10b981;
    color: #fff;
}
.venue-onboarding__step-label {
    color: var(--muted);
    font-weight: 500;
}
.venue-onboarding__step.is-done .venue-onboarding__step-label {
    text-decoration: line-through;
    color: var(--muted);
    opacity: 0.6;
}
a.venue-onboarding__step-label {
    color: var(--ink);
    text-decoration: none;
    font-weight: 600;
}
a.venue-onboarding__step-label:hover { color: var(--link); }

.venue-sub-banner {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px 20px;
    margin: 0 auto 18px;
    max-width: min(1200px, 100%);
    padding: 16px 18px;
    border-radius: var(--radius-island);
    border: 1px solid rgba(217, 119, 6, 0.22);
    background: linear-gradient(135deg, rgba(217, 119, 6, 0.08), rgba(255, 255, 255, 0.96));
    box-shadow: var(--shadow-sm);
}
.venue-sub-banner-main {
    flex: 1 1 240px;
    min-width: 0;
}
.venue-sub-banner-line {
    margin: 0 0 8px;
    font-size: 14px;
    line-height: 1.5;
    color: var(--text);
}
.venue-sub-banner-line:last-of-type {
    margin-bottom: 0;
}
.venue-sub-banner-hint {
    margin: 10px 0 0;
    font-size: 13px;
    line-height: 1.45;
}
.venue-sub-banner-badge {
    display: inline-block;
    margin-right: 8px;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    vertical-align: middle;
}
.venue-sub-banner-badge--trial {
    background: rgba(255, 193, 7, 0.35);
    color: #5d4a00;
    border: 1px solid rgba(0, 0, 0, 0.06);
}
.venue-sub-banner-badge--paid {
    background: rgba(34, 197, 94, 0.22);
    color: #14532d;
    border: 1px solid rgba(34, 197, 94, 0.35);
}
.venue-sub-banner-warn {
    margin-left: 8px;
    font-size: 12px;
    font-weight: 700;
    color: #b45309;
}
.venue-sub-banner-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    flex-shrink: 0;
}

/* Смена / сотрудники / фильтры броней (панель заведения) */
.venue-staff-panel {
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.65);
    margin-bottom: 10px;
}
.venue-staff-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
}
.venue-staff-panel-head h4 {
    margin: 0;
    font-size: 15px;
}
.venue-staff-list {
    font-size: 13px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.venue-staff-card {
    padding: 8px 10px;
    border-radius: 10px;
    background: rgba(0, 0, 0, 0.03);
    border: 1px solid var(--line);
}
.venue-staff-duty {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    background: rgba(217, 119, 6, 0.12);
    color: #d97706;
    font-size: 11px;
    font-weight: 600;
}
.venue-staff-shifts {
    margin-top: 6px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}
.venue-staff-shift {
    font-size: 12px;
}
.venue-staff-card-actions {
    margin-top: 8px;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.venue-filters.panel-inner {
    padding: 10px 12px;
    margin-bottom: 10px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.55);
}
.venue-filters-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    align-items: end;
    margin-bottom: 8px;
}
.venue-filters-row:last-child {
    margin-bottom: 0;
}
.venue-filter-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 12px;
}
.venue-filter-field-grow {
    flex: 1 1 180px;
    min-width: 140px;
}
.venue-filter-field input,
.venue-filter-field select {
    min-height: 36px;
    padding: 6px 10px;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: #fff;
}
.venue-filters-actions {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-left: auto;
}
.venue-audit-block {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--line);
    font-size: 12px;
}
.venue-audit-title {
    font-weight: 700;
    margin-bottom: 8px;
}
.venue-audit-line {
    margin-bottom: 6px;
    line-height: 1.5;
}
.venue-audit-time {
    color: var(--muted);
    margin-right: 6px;
}

.venue-admin-screen {
    margin-left: 12px;
    display: flex;
    align-items: end;
    gap: 8px;
}
.venue-admin-right-head-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

/* Fullscreen для панели заведения */
body.venue-admin-fullscreen {
    overflow: hidden;
}

/* Скрываем все лишнее — остаются только брони+схема */
body.venue-admin-fullscreen .app-bg { display: none; }
body.venue-admin-fullscreen .topbar { display: none; }
body.venue-admin-fullscreen .venue-admin-select-row { display: none; }

body.venue-admin-fullscreen .container {
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 0;
}

body.venue-admin-fullscreen #venueAdminPanel {
    position: fixed;
    inset: 0;
    z-index: 500;
    padding: 10px;
    background: radial-gradient(circle at 20% 10%, rgba(217, 119, 6, 0.06), transparent 40%),
                linear-gradient(180deg, #f7f7f8 0%, #ececf0 100%);
}

body.venue-admin-fullscreen .venue-admin-shell {
    height: 100%;
    gap: 10px;
}
body.venue-admin-fullscreen .venue-admin-left,
body.venue-admin-fullscreen .venue-admin-right {
    min-height: 0;
    height: 100%;
}
body.venue-admin-fullscreen .venue-admin-board-wrap {
    min-height: 0;
    height: 100%;
}
body.venue-admin-fullscreen .table-board {
    min-height: 0;
    height: 100%;
}

.venue-fs-exit {
    display: none;
}
body.venue-admin-fullscreen .venue-fs-exit {
    display: inline-flex;
    position: fixed;
    top: 10px;
    right: 10px;
    z-index: 520;
    border: 1px solid var(--line);
    background: #ffffff;
    color: var(--text);
    border-radius: 12px;
    padding: 8px 12px;
    cursor: pointer;
    backdrop-filter: blur(8px);
    box-shadow: var(--shadow-sm);
}
.venue-admin-left,
.venue-admin-right {
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 650px;
}
.venue-admin-left-head,
.venue-admin-right-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.venue-admin-mode {
    display: flex;
    gap: 10px;
}
.venue-admin-mode .btn.is-active {
    border-color: rgba(217, 119, 6, 0.35);
    box-shadow: 0 0 0 2px var(--accent-soft) inset;
    color: var(--text);
}

/* Переключатель режима схемы (фиксация ↔ редактирование) */
.venue-board-mode {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
.venue-board-mode-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--muted);
    cursor: pointer;
    user-select: none;
    transition: color 0.2s ease;
}
.venue-board-mode-label.is-active {
    color: var(--link);
}
.venue-mode-switch {
    position: relative;
    display: inline-flex;
    width: 48px;
    height: 26px;
    flex-shrink: 0;
    cursor: pointer;
}
.venue-mode-switch input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    margin: 0;
}
.venue-mode-switch-track {
    position: absolute;
    inset: 0;
    border-radius: 999px;
    background: #e4e4e8;
    border: 1px solid var(--line);
    transition: background 0.2s ease, box-shadow 0.2s ease;
}
.venue-mode-switch input:checked + .venue-mode-switch-track {
    background: var(--ink);
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08) inset;
}
.venue-mode-switch-track::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #ffffff;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
    transition: transform 0.22s ease;
}
.venue-mode-switch input:checked + .venue-mode-switch-track::after {
    transform: translateX(22px);
}
.venue-mode-switch input:focus-visible + .venue-mode-switch-track {
    outline: 2px solid var(--link);
    outline-offset: 2px;
}

.venue-admin-list {
    flex: 1 1 auto;
    min-height: 0;
    max-height: min(58vh, 640px);
    overflow-x: hidden;
    overflow-y: auto;
    padding: 20px;
    border-radius: var(--radius-island);
    border: 1px solid var(--line);
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}

.venue-admin-tablepane {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 18px 20px;
    border-radius: var(--radius-island);
    border: 1px solid var(--line);
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}
.venue-tablepane-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    flex-shrink: 0;
}
.venue-tablepane-head-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
    max-width: 220px;
}
.venue-tablepane-bookings-scroll {
    flex: 1 1 auto;
    min-height: 120px;
    max-height: min(52vh, 520px);
    overflow-y: auto;
    margin-top: 10px;
    padding-right: 6px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    scrollbar-width: thin;
    scrollbar-color: rgba(217, 119, 6, 0.65) rgba(0, 0, 0, 0.06);
}
.venue-tablepane-bookings-scroll::-webkit-scrollbar {
    width: 8px;
}
.venue-tablepane-bookings-scroll::-webkit-scrollbar-thumb {
    background: rgba(217, 119, 6, 0.55);
    border-radius: 8px;
}
.venue-tablepane-loading {
    padding: 12px 0;
}
.venue-tablepane-empty {
    padding: 8px 0;
}
.venue-tablepane-title {
    font-weight: 900;
    letter-spacing: 0.2px;
}
.venue-tablepane-meta {
    color: var(--muted);
    font-size: 13px;
    margin-top: 6px;
}
.venue-tablepane-photo {
    margin-top: 12px;
    width: 100%;
    height: 140px;
    border-radius: 14px;
    object-fit: cover;
    border: 1px solid var(--line);
    background: #f0f0f2;
}
.venue-tablepane-actions {
    margin-top: 12px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.venue-tablepane-actions .btn {
    width: 100%;
    text-align: center;
}
.venue-tablepane-actions .btn-wide {
    grid-column: 1 / -1;
}

/* Стиль формы редактирования брони в левом блоке */
.venue-admin-tablepane .book-field label {
    display: block;
    font-size: 14px;
    color: var(--muted);
    margin-bottom: 6px;
}
.venue-admin-tablepane .book-field input,
.venue-admin-tablepane .book-field select,
.venue-admin-tablepane .book-field textarea {
    width: 100%;
    height: 42px;
    border-radius: 12px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--text);
    padding: 10px 12px;
    box-sizing: border-box;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.venue-admin-tablepane .book-field textarea {
    min-height: 84px;
    height: auto;
    resize: vertical;
}
.venue-admin-tablepane .book-field input:focus,
.venue-admin-tablepane .book-field select:focus,
.venue-admin-tablepane .book-field textarea:focus {
    outline: none;
    border-color: rgba(217, 119, 6, 0.45);
    box-shadow: 0 0 0 3px var(--accent-soft);
}
.venue-admin-detail {
    display: none;
}
.venue-order-editor {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 10px;
    background: #fff;
}
.venue-order-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
}
.venue-order-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.venue-order-row {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) 126px auto 40px;
    gap: 8px;
    align-items: center;
}
.venue-order-item-select {
    min-width: 0;
    width: 100%;
    max-width: 100%;
    font-size: 13px;
}
.venue-order-qty-wrap {
    display: grid;
    grid-template-columns: 34px 46px 34px;
    align-items: center;
    gap: 4px;
}
.venue-order-row .venue-order-item-qty {
    text-align: center;
    height: 34px;
    width: 46px;
    min-width: 46px;
    padding: 6px 4px;
    font-weight: 600;
    -moz-appearance: textfield;
}
.venue-order-row .venue-order-item-qty::-webkit-outer-spin-button,
.venue-order-row .venue-order-item-qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.venue-order-qty-btn {
    width: 34px;
    height: 34px;
    padding: 0;
    line-height: 1;
    font-size: 18px;
}
.venue-order-line-total {
    font-size: 12px;
    white-space: nowrap;
}
.venue-order-foot {
    margin-top: 8px;
    font-size: 13px;
}
@media (max-width: 900px) {
    .venue-order-row {
        grid-template-columns: 1fr 126px;
    }
    .venue-order-line-total {
        grid-column: 1 / 2;
    }
    .venue-order-row [data-order-remove] {
        grid-column: 2 / 3;
    }
}

/* Кастомный скрол для списка броней */
.venue-admin-list {
    scrollbar-width: thin;
    scrollbar-color: rgba(217, 119, 6, 0.65) rgba(0, 0, 0, 0.06);
}
.venue-admin-list::-webkit-scrollbar {
    width: 10px;
}
.venue-admin-list::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.05);
    border-radius: 999px;
}
.venue-admin-list::-webkit-scrollbar-thumb {
    background: rgba(217, 119, 6, 0.5);
    border: 2px solid rgba(255, 255, 255, 0.9);
    border-radius: 999px;
}
.venue-admin-list::-webkit-scrollbar-thumb:hover {
    background: rgba(217, 119, 6, 0.48);
}

/* ──────────────────────────────────────────────────────
   Review parse-by-URL block
   ────────────────────────────────────────────────────── */
.vr-parse-block {
    padding: 10px 0 12px;
    border-bottom: 1px solid var(--border-subtle, rgba(0,0,0,.08));
    margin-bottom: 12px;
}
.vr-parse-row {
    display: flex;
    gap: 8px;
    align-items: center;
}
.vr-parse-row input {
    flex: 1;
    min-width: 0;
}
.vr-parse-hint {
    font-size: 12px;
    margin-top: 5px;
}
.vr-parse-status {
    font-size: 12px;
    margin-top: 6px;
    line-height: 1.4;
}
.vr-parse-status.vr-parse-ok {
    color: #16a34a;
}
.vr-parse-status.vr-parse-err {
    color: #dc2626;
}

/* Попапы для редактирования (выше #venueAdminPanel в fullscreen, z-index: 500) */
.venue-popup-overlay {
    position: fixed;
    inset: 0;
    /* Выше шапки/поиска (до ~10055), чтобы карточка не оказалась «под» слоёми UI */
    z-index: 100000;
    background: rgba(0, 0, 0, 0.62);
    backdrop-filter: blur(6px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 16px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 180ms ease, visibility 180ms ease;
}
.venue-popup-overlay.is-open {
    display: flex;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}
.venue-popup-overlay[hidden] {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}
.venue-popup {
    width: min(760px, 100%);
    max-height: calc(100vh - 32px);
    overflow: auto;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: linear-gradient(160deg, #ffffff, #fafafa);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.12);
    transform: translateY(12px) scale(0.98);
    transition: transform 200ms ease;
    position: relative;
}
.venue-popup-overlay.is-open .venue-popup {
    transform: translateY(0) scale(1);
}
.venue-popup-head {
    padding: 16px 16px 10px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    border-bottom: 1px solid var(--line);
}
.venue-popup-title {
    font-weight: 900;
    letter-spacing: 0.2px;
}
.venue-popup-sub {
    color: var(--muted);
    margin-top: 6px;
    font-size: 13px;
}
.venue-popup-close {
    width: 36px;
    height: 36px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: #f5f5f5;
    color: var(--text);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
}
.venue-popup-body {
    padding: 14px 16px 16px;
}
.venue-popup label {
    display: block;
    font-size: 13px;
    color: var(--muted);
    margin-bottom: 6px;
}
.venue-popup input,
.venue-popup select,
.venue-popup textarea {
    width: 100%;
    height: 42px;
    border-radius: 12px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--text);
    padding: 10px 12px;
    box-sizing: border-box;
}
.venue-popup textarea {
    height: auto;
    min-height: 90px;
    resize: vertical;
}
.venue-popup input[type="checkbox"] {
    height: 18px;
    width: 18px;
    margin: 0;
}

.venue-booking-card {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 12px;
    background: #fafafa;
    cursor: pointer;
    transition: transform 0.15s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    margin-bottom: 10px;
}
.venue-booking-card:hover {
    transform: translateY(-1px);
    border-color: rgba(217, 119, 6, 0.22);
}
.venue-booking-card.is-active {
    border-color: rgba(217, 119, 6, 0.35);
    box-shadow: 0 0 0 2px var(--accent-soft);
    background: rgba(217, 119, 6, 0.04);
}
.venue-booking-card-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}
.venue-booking-card-badges {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}
.venue-booking-time {
    font-weight: 800;
    letter-spacing: 0.2px;
}

.venue-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    border: 1px solid var(--line);
    background: #f0f0f2;
    color: var(--text);
}
.venue-status-new {
    color: #0d47a1;
    border-color: rgba(217, 119, 6, 0.35);
    background: var(--accent-soft);
}
.venue-status-confirmed {
    color: #1b5e20;
    border-color: rgba(76, 175, 80, 0.45);
    background: rgba(200, 230, 201, 0.55);
}
.venue-status-completed {
    color: #4a148c;
    border-color: rgba(111, 66, 193, 0.45);
    background: rgba(237, 231, 246, 0.9);
}
.venue-status-cancelled {
    color: var(--muted);
    border-color: var(--line);
    background: rgba(0, 0, 0, 0.04);
    text-decoration: line-through;
}

.venue-detail-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}
.venue-detail-title {
    font-weight: 900;
    letter-spacing: 0.2px;
}

.venue-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.venue-booking-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    margin-top: 12px;
}
.venue-table-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
    margin-top: 12px;
}
.venue-inline-error {
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(198, 40, 40, 0.35);
    background: var(--danger-soft);
    color: var(--danger);
    font-size: 13px;
}

.venue-table-photo-preview {
    margin-top: 12px;
    width: 100%;
    max-height: 220px;
    border-radius: 12px;
    object-fit: cover;
    border: 1px solid var(--line);
}

.venue-admin-board-wrap {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
}
.venue-admin-board-wrap .table-board {
    flex: 1 1 auto;
    width: 100%;
    min-height: min(560px, 70vh);
}

/* Схема столов: выделение в режиме фиксации */
.table-board .editable-item {
    cursor: pointer;
    user-select: none;
}
.table-board .editable-item.active {
    border-color: var(--link);
    box-shadow: 0 0 0 2px rgba(217, 119, 6, 0.22);
}
.table-board.editable .editable-item {
    cursor: grab;
}
.table-board.editable .editable-item.is-dragging {
    cursor: grabbing;
    opacity: 0.85;
    z-index: 10;
}
/* 4-corner resize handles (injected by JS into venue dashboard board) */
.table-board .vt2-rh {
    display: none;
    position: absolute;
    width: 10px;
    height: 10px;
    background: var(--link, #d97706);
    border: 2px solid #fff;
    border-radius: 50%;
    z-index: 5;
}
.table-board.editable .vt2-rh {
    display: block;
}
.table-board .vt2-rh-nw { top: -5px; left: -5px; cursor: nw-resize; }
.table-board .vt2-rh-ne { top: -5px; right: -5px; cursor: ne-resize; }
.table-board .vt2-rh-sw { bottom: -5px; left: -5px; cursor: sw-resize; }
.table-board .vt2-rh-se { bottom: -5px; right: -5px; cursor: se-resize; }

@media (max-width: 900px) {
    .venue-admin-shell {
        grid-template-columns: 1fr;
    }
    .venue-admin-left,
    .venue-admin-right {
        min-height: auto;
    }
    .venue-form-grid {
        grid-template-columns: 1fr;
    }
    .venue-tablepane-actions {
        grid-template-columns: 1fr;
    }
}
.metric p {
    margin: 0;
    font-size: 36px;
    font-weight: 800;
    color: var(--link);
}
.errorlist {
    margin: 6px 0 0;
    padding: 0;
    list-style: none;
    color: var(--danger);
    font-size: 13px;
}
.switcher {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-bottom: 14px;
}
.switcher a {
    text-align: center;
    color: var(--muted);
    text-decoration: none;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 10px 12px;
    background: #ffffff;
    transition: all 0.2s ease;
}
.switcher a.active {
    border-color: var(--ink);
    color: var(--btn-primary-text);
    background: var(--btn-primary-bg);
    box-shadow: none;
}

.auth-shell {
    max-width: 960px;
    margin: 28px auto 8px;
    border: 1px solid var(--line);
    border-radius: var(--radius-island);
    overflow: hidden;
    background: var(--surface);
    min-height: 600px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    box-shadow: var(--shadow-md);
}
.auth-side {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding: 44px 40px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    /* Тёмно-янтарный фон — вечерняя атмосфера ресторана */
    background: #0e0800;
}
/* Янтарные радиальные блики — как свет свечи */
.auth-side::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        radial-gradient(ellipse 80% 55% at 15% 15%, rgba(217, 119, 6, 0.25) 0%, transparent 55%),
        radial-gradient(ellipse 60% 50% at 85% 88%, rgba(180, 83, 9, 0.15) 0%, transparent 50%);
}
.auth-side::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
    background-size: 40px 40px;
}
.auth-side > * {
    position: relative;
    z-index: 2;
}
.auth-side-logo {
    width: 64px;
    height: 64px;
    margin-bottom: auto;
}
.auth-side h2 {
    margin: 0 0 14px;
    font-size: clamp(28px, 3vw, 38px);
    line-height: 1.1;
    max-width: 320px;
    color: #fff;
    letter-spacing: -0.03em;
    font-family: var(--font-display);
    font-weight: 700;
}
.auth-side p {
    margin: 0 0 28px;
    color: rgba(255, 255, 255, 0.6);
    max-width: 340px;
    font-size: 14px;
    line-height: 1.6;
}
.auth-steps {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.auth-step {
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 13px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.5);
    background: rgba(255, 255, 255, 0.04);
    text-align: left;
}
.auth-step.done {
    background: rgba(109, 40, 217, 0.25);
    color: rgba(255, 255, 255, 0.9);
    border-color: rgba(109, 40, 217, 0.4);
    font-weight: 600;
}
.auth-main {
    padding: 40px 36px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: var(--surface);
}
.auth-main h3 {
    margin: 8px 0 6px;
    font-size: 26px;
    letter-spacing: -0.02em;
    font-family: var(--font-display);
    font-weight: 700;
    color: var(--ink);
}
.auth-form { display: grid; gap: 14px; margin-top: 10px; }
.auth-grid { display: grid; gap: 12px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.auth-form label {
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
}
.auth-form input, .auth-form textarea, .auth-form select {
    margin-top: 5px;
    width: 100%;
    height: 42px;
    border-radius: 8px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--text);
    padding: 10px 12px;
    font-size: 14px;
    font-family: var(--font-sans);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.auth-form input:focus, .auth-form textarea:focus, .auth-form select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(217, 119, 6, 0.15);
}
.auth-form textarea { min-height: 84px; height: auto; resize: vertical; }
.auth-submit {
    width: 100%;
    margin-top: 4px;
    height: 46px;
    border-radius: var(--radius-pill);
    font-size: 15px;
    font-weight: 600;
}
.auth-footnote { text-align: center; margin-top: 16px; font-size: 14px; color: var(--muted); }
.auth-footnote a { color: var(--link); font-weight: 500; }
.field-help {
    display: block;
    margin-top: 5px;
    font-size: 12px;
    color: var(--muted);
}

.map-frame-wrap {
    margin-top: 10px;
    border: 1px solid var(--line);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}
.map-frame {
    width: 100%;
    height: 220px;
    border: 0;
    display: block;
}

.auth-page .container { max-width: 1120px; margin-top: 20px; }

.search-inline {
    margin-top: 14px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
}
.search-inline input {
    width: 100%;
    border: 1px solid var(--input-border);
    border-radius: 10px;
    padding: 10px 12px;
    color: var(--text);
    background: var(--bg-soft);
}
.cards-grid {
    margin-top: 8px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.mini-card {
    background: #ffffff;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 12px;
    display: grid;
    gap: 8px;
    box-shadow: var(--shadow-sm);
}
.mini-card-cover {
    width: 100%;
    height: 116px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid var(--line);
}
.row-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--line);
    grid-area: avatar;
}
.profile-head {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-bottom: 6px;
}
.avatar-photo {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(217, 119, 6, 0.35);
}
.establishment-hero {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 16px;
    align-items: center;
}
.cover-photo {
    width: 100%;
    border-radius: 14px;
    border: 1px solid var(--line);
    max-height: 280px;
    object-fit: cover;
}
.cover-photo.small {
    margin-top: 8px;
    max-height: 180px;
}
.table-board {
    position: relative;
    min-height: 560px;
    border: 1px dashed rgba(0, 0, 0, 0.12);
    border-radius: 12px;
    background:
        linear-gradient(to right, rgba(0, 0, 0, 0.09) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(0, 0, 0, 0.09) 1px, transparent 1px),
        linear-gradient(180deg, #e6e9f0 0%, #dfe3ec 100%);
    background-size: 40px 40px, 40px 40px, auto;
    overflow: hidden;
}
/* Схема в панели venue: защита от «иглы» после битых долей в БД / гонки ресайза */
.table-board .board-table {
    box-sizing: border-box;
    min-width: 52px;
    min-height: 48px;
    max-width: 100%;
    max-height: 100%;
}
.board-table {
    position: absolute;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: #7c4a0a;
    text-decoration: none;
    display: inline-flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    gap: 0;
    padding: 2px 2px 5px;
    box-shadow: none;
    transition: filter 0.15s, transform 0.12s;
    overflow: hidden;
}
.board-table:hover,
.board-table:focus,
.board-table:focus-visible,
.board-table:active {
    /* Наезжающие столы выходят вперёд при наведении/тапе */
    z-index: 5;
}
.board-table:hover {
    filter: brightness(1.08) drop-shadow(0 3px 8px rgba(100,50,0,0.25));
    transform: translateY(-1px);
}
.resize-handle {
    position: absolute;
    right: 5px;
    bottom: 5px;
    width: 12px;
    height: 12px;
    border-right: 2px solid rgba(217, 119, 6, 0.55);
    border-bottom: 2px solid rgba(217, 119, 6, 0.55);
    opacity: 0.85;
}
.table-picker {
    margin: 8px 0 12px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.table-card-pick {
    text-align: left;
    border: 1px solid var(--line);
    background: #ffffff;
    color: var(--text);
    border-radius: 10px;
    padding: 10px;
    display: grid;
    gap: 4px;
    cursor: pointer;
}
.table-card-pick small { color: var(--muted); }
.table-card-pick.active {
    border-color: rgba(217, 119, 6, 0.5);
    box-shadow: 0 0 0 2px var(--accent-soft);
}
.table-photo-preview {
    display: none;
    margin: 6px 0 12px;
}
.table-photo-preview.show {
    display: block;
}
.table-photo-preview img {
    width: 100%;
    max-height: 220px;
    border-radius: 10px;
    object-fit: cover;
    border: 1px solid var(--line);
}
/* ── Форм столов — shape-picker ── */
.shape-picker {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 7px;
    margin-top: 6px;
}
.shape-pick-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 8px 4px 6px;
    border: 1.5px solid var(--line);
    border-radius: 10px;
    background: var(--surface);
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
    font-size: 10px;
    color: var(--muted);
    font-weight: 600;
    line-height: 1.2;
    text-align: center;
}
.shape-pick-btn svg {
    width: 36px;
    height: auto;
    color: var(--muted);
    transition: color 0.15s;
}
.shape-pick-btn:hover {
    border-color: rgba(217,119,6,0.4);
    background: #fffbf5;
}
.shape-pick-btn.is-active {
    border-color: var(--link);
    background: rgba(217,119,6,0.06);
    box-shadow: 0 0 0 2px rgba(217,119,6,0.15);
    color: var(--ink);
}
.shape-pick-btn.is-active svg { color: var(--link); }

/* ── Формы столов на board ── */
.board-table.shape-round {
    border-radius: 50%;
}
.board-table.shape-oval {
    border-radius: 50% / 35%;
}
.board-table.shape-square {
    border-radius: 6px;
}
.board-table.shape-wide {
    border-radius: 8px;
    background: linear-gradient(165deg, #fff9f0 0%, #fef3e2 100%);
    border-color: rgba(217, 119, 6, 0.45);
}
.board-table.shape-bar {
    border-radius: 999px;
    background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
    border-color: #475569;
    color: #e2e8f0;
}
.board-table.shape-bar small { color: #94a3b8; }
.board-table-svg {
    position: absolute;
    inset: 0 0 16px;
    width: 100%;
    height: calc(100% - 16px);
    pointer-events: none;
    overflow: visible;
}
.board-table .board-table-title,
.board-table > span:not(.resize-handle) {
    position: relative;
    z-index: 1;
    font-size: 9px;
    font-weight: 800;
    color: #451a03;
    background: rgba(255,237,213,0.92);
    border: 1px solid rgba(180,83,9,0.2);
    padding: 1px 5px;
    border-radius: 3px;
    max-width: 96%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.5;
    flex-shrink: 0;
    letter-spacing: 0;
}
.board-table small {
    display: none; /* seats count скрыт — и так видно из имени */
}
.board-table .board-table-title,
.board-table > span:not(.resize-handle) {
    font-weight: 800;
    letter-spacing: 0.01em;
}
.editable .editable-item {
    cursor: grab;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.editable .editable-item.active {
    border-color: var(--link);
    box-shadow: 0 0 0 2px rgba(217, 119, 6, 0.22);
}
.table-thumb {
    margin-top: 8px;
    width: 108px;
    height: 76px;
    border-radius: 8px;
    object-fit: cover;
    border: 1px solid var(--line);
}
.table-thumb.large {
    width: 220px;
    height: 140px;
}

@keyframes glowMove {
    0% { transform: translate3d(0, 0, 0) scale(1); }
    100% { transform: translate3d(-12px, 8px, 0) scale(1.03); }
}
@keyframes floatY {
    0%, 100% { transform: rotate(25deg) translateY(0); }
    50% { transform: rotate(25deg) translateY(-14px); }
}
@keyframes pulseLogo {
    0%, 100% { filter: drop-shadow(0 0 8px var(--accent-soft)); }
    50% { filter: drop-shadow(0 0 16px var(--accent-glow)); }
}
@keyframes guestSearchIn {
    from { opacity: 0; transform: translateY(-10px) scale(0.98); filter: blur(10px); }
    to { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}
@keyframes topbarScan {
    0%, 100% { background-position: 130% 0; }
    50% { background-position: -30% 0; }
}

.hours-pill {
    margin: 10px 0 0;
    padding: 10px 14px;
    border-radius: 12px;
    border: 1px solid rgba(217, 119, 6, 0.22);
    background: rgba(217, 119, 6, 0.08);
    font-size: 14px;
    line-height: 1.45;
}
.hours-pill strong { color: var(--ink); }
.establishment-hours { margin-top: 12px; }
.small-hint { font-size: 12px; margin-top: 6px; }
.hours-edit-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

/* Флаги заведений */
.place-flags-inline {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 6px;
}
.flag-badge {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    color: var(--ink);
    border: 1px solid rgba(217, 119, 6, 0.55);
    background: rgba(217, 119, 6, 0.22);
    box-shadow: none;
}
.row-title .place-flags-inline {
    grid-column: 2;
    grid-row: auto;
    margin-top: 8px;
}
.active-filter-row {
    margin: 10px 0 6px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

/* Мини-профиль гостя */
.guest-profile-head {
    display: flex;
    gap: 14px;
    align-items: center;
}
.guest-avatar {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    font-size: 18px;
    letter-spacing: 0.3px;
    color: var(--btn-primary-text);
    background: var(--btn-primary-bg);
    border: 1px solid var(--btn-primary-bg);
    box-shadow: var(--shadow-sm);
}
.guest-profile-stats {
    margin-top: 14px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.stat-box {
    flex: 1;
    min-width: 160px;
    padding: 12px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}
.stat-num {
    font-size: 30px;
    font-weight: 900;
    color: var(--link);
    line-height: 1;
}
.guest-next {
    margin-top: 12px;
    padding: 12px;
    border-radius: 16px;
    border: 1px solid rgba(217, 119, 6, 0.15);
    background: var(--accent-soft);
}
.row-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

/* Минималистичная форма брони */
.booking-form {
    margin-top: 10px;
    display: grid;
    gap: 12px;
}
.booking-row {
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr 1fr;
}
.booking-row-2 {
    grid-template-columns: 1fr 1fr;
}
.booking-field-full {
    grid-column: 1 / -1;
}
.booking-field-hidden {
    display: none;
}
.field-label {
    font-size: 12px;
    color: var(--muted);
    font-weight: 700;
    margin-bottom: 6px;
}
.booking-field input,
.booking-field textarea,
.booking-field select {
    width: 100%;
    height: 42px;
    border-radius: 10px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--text);
    padding: 10px 12px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.booking-field textarea {
    height: auto;
    min-height: 84px;
}
.booking-field input:focus,
.booking-field textarea:focus,
.booking-field select:focus {
    outline: none;
    border-color: rgba(217, 119, 6, 0.45);
    box-shadow: 0 0 0 3px var(--accent-soft);
}
.booking-submit {
    width: 100%;
    justify-self: center;
}
.booking-submit.btn {
    height: 46px;
}

/* Масштаб схемы столов (гостевой просмотр) */
.table-zoom-controls {
    margin-bottom: 10px;
    display: flex;
    gap: 10px;
    align-items: center;
}
.flags-edit {
    margin: 6px 0 2px;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.flag-check {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: #ffffff;
}
.flag-check input {
    width: 16px;
    height: 16px;
    margin: 0;
}
.table-zoom-controls input[type="range"] {
    flex: 1;
}
.table-zoom-value {
    min-width: 64px;
    text-align: right;
    font-weight: 800;
    color: var(--link);
}
.table-board-viewport {
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #f7f7f8;
    padding: 12px;
}
.table-board-zoom {
    transform-origin: top left;
    transform: scale(var(--table-zoom, 1));
    width: max-content;
}

@media (max-width: 900px) {
    .grid.two, .grid.four { grid-template-columns: 1fr; }
    .hero { padding: 28px 22px; }
    .hero h1 { font-size: 30px; }
    .auth-shell { grid-template-columns: 1fr; min-height: auto; margin-top: 12px; }
    .auth-side {
        border-right: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
        min-height: 220px;
        padding: 28px 24px;
        justify-content: center;
    }
    .auth-side h2 { font-size: 26px; max-width: 420px; }
    .auth-grid { grid-template-columns: 1fr; }
    .cards-grid { grid-template-columns: 1fr; }
    .establishment-hero { grid-template-columns: 1fr; }
    .table-board { min-height: 420px; }
    .topbar {
        max-width: 100%;
        box-sizing: border-box;
    }
    .container {
        width: 100%;
        max-width: 100%;
        margin: 28px auto;
        padding: 0 12px 40px;
        box-sizing: border-box;
    }
    .panel {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .row.place-card-glass {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    /* Мобиль: лого + поиск (бургера нет, навигация — снизу) */
    .topbar-inner {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        column-gap: 0;
        row-gap: 0;
        align-items: center;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
        padding: 11px max(16px, env(safe-area-inset-right, 0px)) 11px max(16px, env(safe-area-inset-left, 0px));
    }
    /* Бургер и весь топбар-nav скрыты — заменены bottom-nav */
    .topbar-nav { display: none; }
    .topbar-spacer { display: none; }
    .brand {
        grid-column: 1;
        grid-row: 1;
        justify-self: center; /* Центрируем лого на мобиле */
    }
    .topbar-guest-lk {
        display: none;
    }
    /* Кабинет гостя: лого + поиск во второй строке */
    .topbar-inner.topbar-inner-guest {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
        row-gap: 8px;
        padding-bottom: 10px;
    }
    .topbar-inner.topbar-inner-guest .brand {
        justify-self: start;
    }

    /* Bottom nav — показываем на мобиле (не на лендинге) */
    body:not(.landing-page) .bottom-nav { display: block; }
    /* Отступ снизу, чтобы контент не прятался за нижнюю навигацию */
    body:not(.landing-page) { padding-bottom: calc(68px + env(safe-area-inset-bottom, 0px)); }
    .guest-search-slot {
        grid-column: 1 / -1;
        grid-row: 2;
        width: 100%;
        max-width: 100%;
        margin: 0;
        padding: 0;
        justify-self: stretch;
        min-width: 0;
        z-index: 10045;
    }
    .guest-search-full {
        width: 100%;
    }
    .guest-search-full.is-search-open {
        z-index: 10055 !important;
    }
    .guest-search-panel {
        left: 0;
        right: 0;
        width: auto;
        transform: translateY(-14px) scale(0.98);
    }
    .guest-search-panel.is-open {
        transform: translateY(0) scale(1);
    }
}

@media (max-width: 600px) {
    .topbar { padding: 10px 10px; }
    .topbar-inner { padding: 8px 10px; }
    .brand { font-size: 20px; }
    .guest-search-trigger-label { display: none; }
    .guest-search-trigger { padding: 10px 12px; }
    .topbar-nav a { margin-left: 10px; }
    .nav-cta { padding: 7px 10px; }
    .container {
        margin-top: 20px;
    }
    .auth-main { padding: 24px 20px; }
    .shape { display: none; }
    .cards-grid { grid-template-columns: 1fr; }
    .search-inline { grid-template-columns: 1fr; }
    .table-picker { grid-template-columns: 1fr; }
    .hours-edit-grid { grid-template-columns: 1fr; }
    .booking-row { grid-template-columns: 1fr; }
    .booking-row-2 { grid-template-columns: 1fr; }
    /* Компактный монолит: влезает инпут + «Найти» в один ряд */
    .guest-search-full { padding: 6px 8px !important; }
    .guest-search-slot {
        min-height: 42px;
    }

    .guest-search-full {
        border-radius: 14px !important;
    }

    .guest-search-full.is-search-open {
        border-radius: 12px !important;
    }

    .guest-search-top {
        width: 100%;
        min-width: 0;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        gap: 0;
    }

    .guest-search-full .guest-search-main {
        flex: 1 1 auto;
        min-width: 0;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        gap: 5px !important;
        justify-content: stretch !important;
    }

    .guest-search-input {
        font-size: 16px !important; /* iOS: не зумить при фокусе */
        min-height: 40px;
        padding: 7px 10px !important;
        border-radius: 999px !important;
    }

    .guest-search-full .guest-search-submit {
        flex-shrink: 0;
        padding: 7px 9px !important;
        font-size: 11px !important;
        font-weight: 800 !important;
        border-radius: 999px !important;
        letter-spacing: -0.02em;
        white-space: nowrap;
    }

    .guest-search-main {
        gap: 5px;
    }

    .guest-search-dropdown.is-open {
        max-height: min(72vh, 520px) !important;
    }

    .guest-search-full .guest-search-dropdown-results {
        max-height: min(44vh, 280px) !important;
        gap: 5px !important;
    }

    /* Совпадения: ниже по вертикали — больше карточек в видимой зоне */
    .guest-search-dropdown-results .guest-search-est-card.row.place-card-glass {
        align-items: flex-start !important;
        gap: 6px !important;
        padding: 7px 8px !important;
        margin-bottom: 5px !important;
        border-radius: 11px !important;
    }

    .guest-search-dropdown-results .guest-search-est-card .row-title {
        display: grid;
        grid-template-columns: 34px 1fr;
        grid-template-areas:
            "av tit"
            "av met"
            "av flg"
            "av inf";
        column-gap: 8px;
        row-gap: 0;
        align-items: start;
        min-width: 0;
        flex: 1 1 auto;
    }

    .guest-search-dropdown-results .guest-search-est-card .row-title > .row-avatar {
        grid-area: av;
        align-self: start;
        width: 34px !important;
        height: 34px !important;
        border-radius: 9px !important;
    }

    .guest-search-dropdown-results .guest-search-est-card .row-title strong {
        grid-area: tit;
        font-size: 14px !important;
        line-height: 1.2;
        margin: 0;
    }

    .guest-search-dropdown-results .guest-search-est-card .place-city-meta {
        grid-area: met;
        font-size: 11px !important;
        line-height: 1.25;
        margin-top: 1px;
    }

    .guest-search-dropdown-results .guest-search-est-card .place-flags-inline {
        grid-area: flg;
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: wrap !important;
        align-items: center;
        gap: 4px !important;
        margin-top: 3px;
    }

    .guest-search-dropdown-results .guest-search-est-card .place-card-info {
        grid-area: inf;
        margin-top: 2px !important;
        font-size: 10px !important;
        line-height: 1.2;
    }

    .guest-search-dropdown-results .guest-search-est-card .flag-badge {
        padding: 2px 6px !important;
        font-size: 10px !important;
        font-weight: 650 !important;
    }

    .guest-search-dropdown-results .guest-search-est-card > .place-popular-badge {
        width: 22px !important;
        height: 22px !important;
        top: 4px !important;
        right: 5px !important;
    }

    .guest-search-dropdown-results .guest-search-est-card .row-actions {
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: flex-end;
        gap: 4px;
        margin-top: 0 !important;
        flex-shrink: 0;
        align-self: center;
    }

    .guest-search-dropdown-results .guest-search-est-card .btn {
        flex: 0 1 auto;
        min-width: 0;
        text-align: center;
        justify-content: center;
        padding: 5px 7px !important;
        font-size: 10px !important;
        border-radius: 8px !important;
        white-space: nowrap;
    }

    .guest-search-dropdown-mount {
        padding-left: 0;
        padding-right: 0;
    }

    .guest-search-dropdown.is-open .guest-search-dropdown-mount {
        padding: 7px 0 8px;
        margin-top: 4px;
    }

    /* Бургер скрыт — навигация теперь снизу */
    .topbar-burger { display: none !important; }
    .topbar-nav-links {
        display: flex;
        flex-direction: column;
        gap: 4px;
        position: absolute;
        top: calc(100% + 8px);
        right: 0;
        padding: 8px;
        border-radius: 12px;
        border: 1px solid rgba(255, 255, 255, 0.1);
        background: #1c1c1f;
        box-shadow: 0 20px 48px rgba(0, 0, 0, 0.4);
        min-width: 200px;
        z-index: 95;
        align-items: stretch;
        opacity: 0;
        transform: translateY(-6px) scale(0.98);
        pointer-events: none;
        visibility: hidden;
        transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0.18s;
    }
    .topbar-nav.is-open .topbar-nav-links {
        opacity: 1;
        transform: translateY(0) scale(1);
        pointer-events: auto;
        visibility: visible;
        transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s;
    }
    .topbar-nav.is-open .topbar-nav-links a {
        margin-left: 0 !important;
        text-align: left;
        padding: 10px 12px;
        border: 1px solid transparent;
        border-radius: 8px;
        background: transparent;
        color: rgba(255, 255, 255, 0.75);
        font-size: 14px;
        font-weight: 500;
        transition: background 0.15s ease, color 0.15s ease;
    }
    .topbar-nav.is-open .topbar-nav-links a:hover {
        background: rgba(255, 255, 255, 0.08);
        color: #ffffff;
    }
    .topbar-nav.is-open .topbar-nav-links a.nav-cta {
        background: var(--accent) !important;
        border-color: transparent !important;
        color: #18130a !important;
        font-weight: 600;
    }
    .topbar-nav.is-open .topbar-nav-links a.nav-cta:hover {
        filter: brightness(1.06);
    }
    .topbar-nav.is-open .topbar-nav-links .topbar-guest-lk-mobile {
        display: grid;
        gap: 5px;
        padding: 10px 12px 12px;
        margin-bottom: 4px;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
        text-align: left;
    }
    .topbar-nav.is-open .topbar-nav-links .topbar-guest-lk-mobile .topbar-guest-name {
        font-size: 14px;
        color: #fff;
    }
    .topbar-nav.is-open .topbar-nav-links .topbar-guest-lk-mobile .topbar-guest-phone {
        font-size: 12px;
        color: rgba(255, 255, 255, 0.5);
    }
    .topbar-nav.is-open .topbar-nav-links .topbar-guest-lk-mobile .topbar-guest-chip {
        font-size: 11px;
        padding: 3px 8px;
        background: rgba(255, 255, 255, 0.1);
        border-color: rgba(255, 255, 255, 0.1);
        color: rgba(255, 255, 255, 0.7);
    }

    /* Mobile: тот же монолит (absolute в .guest-search-slot) */
    .guest-search-pill-filters { display: none !important; }
    .guest-search-dropdown-tags {
        display: flex;
        gap: 5px;
        flex-wrap: wrap;
        margin-bottom: 6px;
    }
    .guest-search-tag {
        border-radius: 999px;
        padding: 5px 9px;
        border: 1px solid rgba(255, 255, 255, 0.12);
        background: #f0f0f2;
        color: var(--muted);
        cursor: pointer;
        font-weight: 800;
        font-size: 11px;
        user-select: none;
        transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, filter 0.2s ease;
    }
    .guest-search-tag.is-active {
        color: var(--ink);
        border-color: rgba(217, 119, 6, 0.65);
        box-shadow: 0 0 18px var(--accent-soft);
        filter: brightness(1.05);
    }
    .guest-search-dropdown-results {
        display: grid;
        gap: 5px;
        max-height: min(44vh, 280px);
        overflow: auto;
    }
    .guest-search-suggestion {
        display: grid;
        grid-template-columns: auto 1fr;
        gap: 10px;
        align-items: center;
        text-decoration: none;
        border-radius: 12px;
        padding: 10px 10px;
        border: 1px solid rgba(255, 255, 255, 0.08);
        background: #ffffff;
        transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
    }
    .guest-search-suggestion:hover {
        border-color: rgba(217, 119, 6, 0.35);
        box-shadow: 0 0 18px var(--accent-soft);
        transform: translateY(-1px);
    }
    .guest-search-suggestion-logo {
        width: 44px;
        height: 44px;
        border-radius: 10px;
        object-fit: cover;
        border: 1px solid rgba(255, 255, 255, 0.08);
        background: rgba(0, 0, 0, 0.2);
    }
    .guest-search-suggestion-main {
        display: grid;
        gap: 3px;
    }
    .guest-search-suggestion-title {
        font-weight: 900;
    }
    .guest-search-suggestion-meta {
        color: var(--muted);
        font-size: 12px;
    }
    .guest-search-empty {
        color: var(--muted);
        font-size: 13px;
        padding: 10px 4px;
    }
}

/* Совпадения — продолжение той же формы (одна рамка/фон), не отдельная карточка */
.guest-search-dropdown {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
    width: 100% !important;
    min-width: 0 !important;
    z-index: 1;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    display: block !important;
    max-height: 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    overflow: hidden;
    /* Закрытие: opacity быстрее max-height — весь блок (теги+карточки) гаснет вместе, без «сначала низ, потом теги» */
    transition:
        max-height 0.28s cubic-bezier(0.4, 0, 0.2, 1),
        opacity 0.18s cubic-bezier(0.4, 0, 0.6, 1),
        visibility 0s linear 0.28s;
}

.guest-search-dropdown.is-open {
    max-height: min(88vh, 900px);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

/* Открытие: углы оболочки, затем высота */
.guest-search-full.is-search-open .guest-search-dropdown.is-open {
    transition:
        max-height 0.46s cubic-bezier(0.22, 1, 0.34, 1) 0.12s,
        opacity 0.26s cubic-bezier(0.22, 1, 0.36, 1) 0.08s,
        visibility 0s linear 0s;
}

.guest-search-dropdown-mount {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0 2px 8px;
}

.guest-search-dropdown.is-open .guest-search-dropdown-mount {
    border-top: 1px solid var(--line);
    margin-top: 8px;
    padding: 12px 2px 12px;
}

.guest-search-dropdown-tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.guest-search-tag {
    border-radius: 999px;
    padding: 8px 12px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: #f0f0f2;
    color: var(--muted);
    cursor: pointer;
    font-weight: 800;
    font-size: 12px;
    user-select: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, filter 0.2s ease;
}
.guest-search-tag.is-active {
    color: var(--ink);
    border-color: rgba(217, 119, 6, 0.65);
    box-shadow: 0 0 18px var(--accent-soft);
    filter: brightness(1.05);
}
.guest-search-dropdown-results {
    display: grid;
    gap: 8px;
    max-height: 320px;
    overflow: auto;
}
.guest-search-suggestion {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: center;
    text-decoration: none;
    border-radius: 12px;
    padding: 10px 10px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: #ffffff;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.guest-search-suggestion:hover {
    border-color: rgba(217, 119, 6, 0.35);
    box-shadow: 0 0 18px var(--accent-soft);
    transform: translateY(-1px);
}
.guest-search-suggestion-logo {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    object-fit: cover;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(0, 0, 0, 0.2);
}
.guest-search-suggestion-main {
    display: grid;
    gap: 3px;
}
.guest-search-suggestion-title {
    font-weight: 900;
}
.guest-search-suggestion-meta {
    color: var(--muted);
    font-size: 12px;
}
.guest-search-empty {
    color: var(--muted);
    font-size: 13px;
    padding: 10px 4px;
}

/* Minimal header search on all devices: hide pills */
.guest-search-pill-filters { display: none !important; }

@media (max-width: 900px) {
    .guest-search-pill-filters { display: none !important; }

    .guest-search-dropdown-tags {
        display: flex;
        gap: 8px;
        flex-wrap: wrap;
        margin-bottom: 10px;
    }

    .guest-search-tag {
        border-radius: 999px;
        padding: 8px 12px;
        border: 1px solid rgba(255, 255, 255, 0.12);
        background: #f0f0f2;
        color: var(--muted);
        cursor: pointer;
        font-weight: 800;
        font-size: 12px;
        user-select: none;
        transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, filter 0.2s ease;
    }

    .guest-search-tag.is-active {
        color: var(--ink);
        border-color: rgba(217, 119, 6, 0.65);
        box-shadow: 0 0 18px var(--accent-soft);
        filter: brightness(1.05);
    }

    .guest-search-dropdown-results {
        display: grid;
        gap: 8px;
        max-height: 320px;
        overflow: auto;
    }

    .guest-search-suggestion {
        display: grid;
        grid-template-columns: auto 1fr;
        gap: 10px;
        align-items: center;
        text-decoration: none;
        border-radius: 12px;
        padding: 10px 10px;
        border: 1px solid rgba(255, 255, 255, 0.08);
        background: #ffffff;
        transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
    }

    .guest-search-suggestion:hover {
        border-color: rgba(217, 119, 6, 0.35);
        box-shadow: 0 0 18px var(--accent-soft);
        transform: translateY(-1px);
    }

    .guest-search-suggestion-logo {
        width: 44px;
        height: 44px;
        border-radius: 10px;
        object-fit: cover;
        border: 1px solid rgba(255, 255, 255, 0.08);
        background: rgba(0, 0, 0, 0.2);
    }

    .guest-search-suggestion-main {
        display: grid;
        gap: 3px;
    }

    .guest-search-suggestion-title {
        font-weight: 900;
    }

    .guest-search-suggestion-meta {
        color: var(--muted);
        font-size: 12px;
    }

    .guest-search-empty {
        color: var(--muted);
        font-size: 13px;
        padding: 10px 4px;
    }
}

/* Один монолит: абсолют внутри слота — растёт вниз, шапка по сетке не раздувается */
.guest-search-full {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    background:
        linear-gradient(168deg, #ffffff, #f5f5f7) !important;
    backdrop-filter: blur(18px) saturate(1.14) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.14) !important;
    border: 1px solid var(--line) !important;
    box-shadow: var(--shadow-md) !important;
    z-index: 10040;
    overflow: hidden !important;
    /* Без «таблетки» на всю оболочку — меньше лагов при интерполяции с раскрытием */
    border-radius: 18px !important;
    padding: 8px 14px !important;
    transition:
        border-radius 0.28s cubic-bezier(0.4, 0, 0.2, 1),
        box-shadow 0.28s ease;
}

.guest-search-full.is-search-open {
    /* Чуть менее скруглено — сначала быстро «собирается» рамка, потом тянется блок (см. delay у dropdown) */
    border-radius: 13px !important;
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.1) !important;
}

.guest-search-top {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    width: 100%;
    min-width: 0;
    flex: 0 0 auto;
}
.guest-search-full::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        radial-gradient(100% 90% at 18% -10%, rgba(217, 119, 6, 0.2), transparent 52%),
        linear-gradient(115deg, rgba(255, 255, 255, 0.5), rgba(0, 0, 0, 0));
    pointer-events: none;
}
.guest-search-full > *:not(.guest-search-dropdown) {
    position: relative;
    z-index: 1;
}

.guest-search-input {
    border: 1px solid var(--input-border) !important;
    background: #ffffff !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.04) !important;
    transition: border-color 0.22s ease, box-shadow 0.22s ease, background 0.22s ease !important;
    border-radius: 999px !important;
}
.guest-search-input:focus {
    border-color: rgba(217, 119, 6, 0.85) !important;
    background: #ffffff !important;
    box-shadow:
        0 0 0 2px var(--accent-soft),
        inset 0 1px 2px rgba(0, 0, 0, 0.04) !important;
}
.guest-search-full .guest-search-submit {
    border-radius: 999px !important;
}

.guest-search-dropdown .guest-search-tag {
    border-color: var(--line) !important;
    background: #f0f0f2 !important;
    color: var(--text) !important;
    font-weight: 650;
}
.guest-search-dropdown .guest-search-tag.is-active {
    border-color: rgba(217, 119, 6, 0.75) !important;
    background: rgba(217, 119, 6, 0.28) !important;
    color: var(--ink) !important;
}

.guest-search-suggestion {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    align-items: center;
    gap: 12px !important;
    border: 1px solid var(--line) !important;
    background: #ffffff !important;
    backdrop-filter: blur(12px) saturate(1.1);
    -webkit-backdrop-filter: blur(12px) saturate(1.1);
    padding: 12px 14px !important;
    color: var(--text) !important;
    box-shadow: var(--shadow-sm) !important;
    transform: none !important;
    position: relative;
    overflow: hidden;
}
.guest-search-suggestion-bg {
    position: absolute;
    inset: 0;
    background-image: var(--suggest-cover);
    background-size: cover;
    background-position: center;
    opacity: 0.30;
    filter: saturate(1.1) blur(0.6px);
    pointer-events: none;
}
.guest-search-suggestion::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(112deg, rgba(217, 119, 6, 0.08) 10%, transparent 100%);
    pointer-events: none;
}
.guest-search-suggestion > * {
    position: relative;
    z-index: 1;
}
.guest-search-suggestion:hover {
    border-color: rgba(217, 119, 6, 0.55) !important;
    background: #f8faff !important;
    box-shadow: var(--shadow-md) !important;
    transform: none !important;
}
.guest-search-suggestion:visited {
    color: var(--text) !important;
}
.guest-search-suggestion-main {
    gap: 4px !important;
    min-width: 0;
}
.guest-search-suggestion-title {
    color: var(--text) !important;
    font-weight: 800;
    letter-spacing: 0.01em;
}
.guest-search-suggestion-meta {
    color: var(--muted) !important;
    font-size: 12px;
}
.guest-search-suggestion-flags {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 6px;
}
.guest-search-flag {
    display: inline-flex;
    padding: 3px 8px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    color: rgba(240, 220, 220, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.04);
}
.guest-search-suggestion-cta {
    flex-shrink: 0;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: rgba(230, 200, 200, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    padding: 8px 10px;
    background: rgba(255, 255, 255, 0.05);
}

.mini-card.place-card-glass {
    border: none !important;
    background: transparent !important;
    backdrop-filter: none;
    box-shadow: var(--shadow-sm);
    position: relative;
    overflow: hidden;
}
.mini-card.place-card-glass::before {
    content: "";
    position: absolute;
    inset: -14px;
    border-radius: inherit;
    background-image: var(--place-cover);
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    opacity: 1;
    filter: saturate(1.08);
    pointer-events: none;
}
.mini-card.place-card-glass::after {
    content: "";
    position: absolute;
    inset: 0;
    /* Фото почти без «тумана»: лёгкое затемнение + чуть снизу для подписей */
    background:
        linear-gradient(180deg, transparent 0%, transparent 50%, rgba(0, 0, 0, 0.22) 100%),
        rgba(0, 0, 0, 0.1);
    pointer-events: none;
}
.mini-card.place-card-glass > *:not(.place-popular-badge) {
    position: relative;
    z-index: 1;
}
.mini-card.place-card-glass .flag-badge {
    border: none !important;
    background: rgba(255, 255, 255, 0.22) !important;
    color: rgba(248, 250, 252, 0.95) !important;
    font-weight: 600;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
}

.row.place-card-glass {
    border: none !important;
    border-radius: 12px;
    padding: 12px 14px !important;
    margin-bottom: 10px;
    background: transparent !important;
    backdrop-filter: none;
    box-shadow: var(--shadow-sm);
    position: relative;
    overflow: hidden;
    align-items: flex-start;
}
.row.place-card-glass::before {
    content: "";
    position: absolute;
    inset: -14px;
    border-radius: inherit;
    background-image: var(--place-cover);
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    opacity: 1;
    filter: saturate(1.08);
    pointer-events: none;
}
.row.place-card-glass::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, transparent 0%, transparent 50%, rgba(0, 0, 0, 0.22) 100%),
        rgba(0, 0, 0, 0.1);
    pointer-events: none;
}
.row.place-card-glass > *:not(.place-popular-badge) {
    position: relative;
    z-index: 1;
}
.row.place-card-glass .flag-badge {
    border: none !important;
    background: rgba(255, 255, 255, 0.22) !important;
    color: rgba(248, 250, 252, 0.95) !important;
    font-weight: 600;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
}
/* Флаги в поиске — отдельный нейтральный стиль */
.flag-badge,
.guest-search-flag {
    border: none !important;
    background: rgba(217, 119, 6, 0.1) !important;
    color: #374151 !important;
    font-weight: 700;
}

/* Primary CTA: чёрные кнопки (не трогаем btn-ghost и est-btn-book) */
.guest-search-submit,
.btn:not(.btn-ghost):not(.btn-danger-ghost):not(.est-btn-book),
.row.place-card-glass .btn:not(.btn-ghost):not(.btn-danger-ghost):not(.est-btn-book),
.mini-card.place-card-glass .btn:not(.btn-ghost):not(.btn-danger-ghost):not(.est-btn-book) {
    color: var(--btn-primary-text) !important;
    border: 1px solid var(--btn-primary-bg) !important;
    background: var(--btn-primary-bg) !important;
    box-shadow: var(--shadow-sm) !important;
    transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease !important;
}
.guest-search-submit:hover,
.btn:not(.btn-ghost):not(.btn-danger-ghost):not(.est-btn-book):hover,
.row.place-card-glass .btn:not(.btn-ghost):not(.btn-danger-ghost):not(.est-btn-book):hover,
.mini-card.place-card-glass .btn:not(.btn-ghost):not(.btn-danger-ghost):not(.est-btn-book):hover {
    background: var(--btn-primary-hover) !important;
    border-color: var(--btn-primary-hover) !important;
    transform: translateY(-1px);
    box-shadow: var(--shadow-md) !important;
}

/* Fix overlap in establishment rows (city/meta + tags + bookings info) */
.row.place-card-glass .row-title {
    flex: 1 1 auto;
    min-width: 0;
    grid-template-columns: auto 1fr;
    grid-template-areas:
        "avatar title"
        "avatar meta"
        "avatar flags"
        "avatar info";
    row-gap: 4px;
    align-items: start;
}
.row.place-card-glass .row-title strong { grid-area: title; }
.row.place-card-glass .row-title .place-city-meta { grid-area: meta; }
.row.place-card-glass .row-title .place-flags-inline {
    grid-area: flags;
    margin-top: 2px;
}
.row.place-card-glass .row-title .place-card-info {
    grid-area: info;
    margin-top: 2px;
}

.row.place-card-glass .row-actions {
    margin-top: auto;
    align-self: flex-end;
    flex-shrink: 0;
}

/* Карточки заведений: обложка + лёгкая вуаль для текста */
.mini-card.place-card-glass,
.row.place-card-glass {
    border: none !important;
    border-radius: 16px !important;
    background: transparent !important;
    backdrop-filter: none;
    box-shadow: var(--shadow-sm) !important;
}
.mini-card.place-card-glass:hover,
.row.place-card-glass:hover {
    border: none !important;
    box-shadow: var(--shadow-md) !important;
    transform: translateY(-1px);
}
.mini-card.place-card-glass:hover::after,
.row.place-card-glass:hover::after {
    background:
        linear-gradient(180deg, transparent 0%, transparent 48%, rgba(0, 0, 0, 0.28) 100%),
        rgba(0, 0, 0, 0.12);
}

.flag-badge,
.guest-search-flag,
.guest-search-dropdown .guest-search-tag {
    border-radius: 999px !important;
    border: none !important;
    background: rgba(217, 119, 6, 0.12) !important;
    color: #5a6b82 !important;
    box-shadow: none;
}

.guest-search-full .guest-search-dropdown-tags {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}
.guest-search-full .guest-search-dropdown-results {
    width: 100% !important;
    max-height: min(52vh, 420px) !important;
}

/* ===== Карточки заведений: типографика поверх вуали ===== */
.mini-card.place-card-glass::before,
.row.place-card-glass::before {
    inset: -14px !important;
    border-radius: inherit !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    opacity: 1 !important;
    filter: saturate(1.08) !important;
}
.mini-card.place-card-glass strong,
.row.place-card-glass .row-title strong {
    font-size: 27px;
    letter-spacing: 0.01em;
    color: #f8fafc;
    font-weight: 700;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.55), 0 0 18px rgba(0, 0, 0, 0.25);
}
.mini-card.place-card-glass .muted,
.row.place-card-glass .muted,
.row.place-card-glass .place-city-meta,
.row.place-card-glass .place-card-info {
    color: rgba(248, 250, 252, 0.9) !important;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}
.row.place-card-glass .place-card-info {
    font-weight: 500;
}
.row.place-card-glass .row-avatar {
    width: 54px;
    height: 54px;
    border: none;
    box-shadow: none;
}
.mini-card.place-card-glass .btn,
.row.place-card-glass .btn {
    border-radius: 10px !important;
    padding: 9px 14px !important;
    font-weight: 700 !important;
}
.place-card-info {
    margin-top: 8px;
    font-size: 12px;
    color: var(--muted);
}

.place-popular-badge {
    position: absolute;
    top: 6px;
    right: 8px;
    z-index: 4;
    width: 28px;
    height: 28px;
    object-fit: contain;
    display: block;
    pointer-events: none;
    filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.55));
}

.row.place-card-glass > .place-popular-badge {
    z-index: 4;
}
.place-rating {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 6px;
    padding: 3px 8px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.35);
    border: 1px solid rgba(255, 255, 255, 0.22);
}
.place-rating__star {
    color: #f59e0b;
}
.place-rating__val {
    font-size: 13px;
    font-weight: 700;
    color: #ffffff;
}
.place-rating__cnt {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.92);
}

/* Подсказки поиска: те же карточки, что на дашборде; компактнее типографика */
.guest-search-dropdown-results .guest-search-est-card {
    margin-bottom: 10px;
    border-bottom: none !important;
    padding: 12px 14px !important;
}

.guest-search-dropdown-results .guest-search-est-card:last-child {
    margin-bottom: 0;
}

.guest-search-dropdown-results .guest-search-est-card .row-title strong {
    font-size: 17px;
    letter-spacing: 0.01em;
}

.guest-search-dropdown-results .guest-search-est-card .row-avatar {
    width: 46px;
    height: 46px;
}
.guest-search-dropdown-results .guest-search-est-card .row-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
}
.guest-search-dropdown-results .guest-search-est-card .place-flags-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 6px;
    max-width: 180px;
}
.guest-search-dropdown-results .guest-search-est-card .place-flags-actions .flag-badge {
    padding: 5px 9px;
    font-size: 11px;
}
.guest-search-dropdown-results .guest-search-est-card .place-action-buttons {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

@media (max-width: 600px) {
    .guest-search-suggestion {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }
    .guest-search-suggestion-cta {
        justify-self: start;
    }
}

/* ——— Подвал (тёмный блок как у Autonomy) ——— */
/* =====================================================
   FOOTER — редизайн (маркетинговый, с двумя CTA)
   ===================================================== */
.site-footer {
    position: relative;
    z-index: 2;
    margin-top: auto;
    background: #0e0800;
    color: rgba(255, 255, 255, 0.55);
    border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.site-footer-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 40px max(24px, env(safe-area-inset-left, 0px)) 36px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: start;
}

@media (min-width: 700px) {
    .site-footer-inner {
        grid-template-columns: minmax(200px, 280px) 1fr;
        gap: 32px 56px;
    }
}

/* Бренд + слоган + CTA */
.site-footer-brand-block {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.site-footer-brand {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
    font-size: 20px;
    color: #ffffff !important;
    text-decoration: none;
    letter-spacing: -0.03em;
    font-family: var(--font-display);
    margin-bottom: 10px;
}

.site-footer-brand:hover { color: rgba(255,255,255,0.85) !important; }

.site-footer-brand::before {
    content: "";
    display: inline-block;
    width: 9px;
    height: 9px;
    border-radius: 3px;
    background: var(--accent);
    flex-shrink: 0;
    box-shadow: 0 0 10px rgba(217, 119, 6, 0.5);
}

.site-footer-tagline {
    margin: 0 0 20px;
    font-size: 17px;
    line-height: 1.45;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.78);
    letter-spacing: -0.01em;
}

/* CTA-пара в футере */
.site-footer-cta-pair {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.site-footer-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 42px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    transition: filter 0.15s ease, opacity 0.15s ease;
    cursor: pointer;
}

.site-footer-cta--amber {
    background: linear-gradient(145deg, #f59e0b, #d97706);
    color: #18130a !important;
    box-shadow: 0 3px 14px rgba(217, 119, 6, 0.45);
}

.site-footer-cta--amber:hover { filter: brightness(1.08); }

.site-footer-cta--ghost {
    background: rgba(255, 255, 255, 0.07);
    color: rgba(255, 255, 255, 0.72) !important;
    border: 1px solid rgba(255, 255, 255, 0.14);
}

.site-footer-cta--ghost:hover {
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.9) !important;
}

/* Колонки навигации */
.site-footer-columns {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px 24px;
    padding-top: 4px;
}

@media (max-width: 500px) {
    .site-footer-columns {
        grid-template-columns: repeat(2, 1fr);
    }
}

.site-footer-heading {
    margin: 0 0 12px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.32);
}

.site-footer-links {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
}

.site-footer-links a {
    color: rgba(255, 255, 255, 0.5) !important;
    font-size: 14px;
    font-weight: 400;
    text-decoration: none;
    transition: color 0.15s ease;
    line-height: 1.4;
}

.site-footer-links a:hover {
    color: rgba(255, 255, 255, 0.9) !important;
}

/* Нижняя строка */
.site-footer-bottom {
    max-width: 1280px;
    margin: 0 auto;
    padding: 16px max(24px, env(safe-area-inset-left, 0px)) calc(20px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.site-footer-copy {
    margin: 0;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.22);
    line-height: 1.5;
}

.site-footer-legal {
    margin: 0;
    font-size: 11px;
    color: rgba(255, 255, 255, 0.15);
    line-height: 1.5;
    text-align: right;
}

@media (max-width: 600px) {
    .site-footer-legal { display: none; }
}

body.venue-admin-fullscreen .site-footer { display: none; }

/* На мобиле с bottom-nav футер дублирует навигацию — скрываем */
@media (max-width: 900px) {
    body:not(.landing-page):not(.auth-page) .site-footer {
        display: none;
    }
}

/* =====================================================
   НИЖНЯЯ НАВИГАЦИЯ (mobile only, вместо бургера)
   ===================================================== */
.bottom-nav {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 200;
    background: rgba(17, 12, 3, 0.96);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 6px max(8px, env(safe-area-inset-left, 0px))
             calc(6px + env(safe-area-inset-bottom, 0px))
             max(8px, env(safe-area-inset-left, 0px));
}
.bottom-nav__inner {
    display: flex;
    align-items: stretch;
    justify-content: space-around;
    max-width: 480px;
    margin: 0 auto;
    gap: 2px;
}
.bottom-nav__item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    padding: 7px 4px 8px;
    min-width: 0;
    border-radius: 10px;
    color: rgba(255, 255, 255, 0.38);
    text-decoration: none;
    font-size: 10.5px;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.01em;
    transition: color 0.18s ease, background 0.18s ease;
    cursor: pointer;
    min-height: 52px;
    text-align: center;
    white-space: nowrap;
    position: relative;
}
.bottom-nav__item svg {
    flex-shrink: 0;
    stroke-width: 1.6;
    transition: transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.bottom-nav__item:hover {
    color: rgba(255, 255, 255, 0.68);
    background: rgba(255, 255, 255, 0.04);
}
.bottom-nav__item:active svg { transform: scale(0.88); }
/* Активная вкладка: янтарный цвет + верхний индикатор */
.bottom-nav__item.is-active {
    color: var(--accent);
}
.bottom-nav__item.is-active::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 22px;
    height: 2.5px;
    background: var(--accent);
    border-radius: 0 0 3px 3px;
}
.bottom-nav__item.is-active svg { transform: scale(1.08); }
/* Янтарная CTA-кнопка */
.bottom-nav__item--amber {
    color: #18130a !important;
    background: linear-gradient(145deg, #f59e0b, #d97706);
    border-radius: 12px;
    margin: 4px 2px;
    min-height: 44px;
    box-shadow: 0 2px 10px rgba(217, 119, 6, 0.45);
    padding: 6px 8px;
    font-weight: 600;
}
.bottom-nav__item--amber:hover {
    background: linear-gradient(145deg, #d97706, #b45309);
    box-shadow: 0 4px 14px rgba(217, 119, 6, 0.55);
    color: #18130a !important;
}
.bottom-nav__item--amber::before { display: none; }
.bottom-nav__item--amber svg { stroke-width: 2; }
/* Скрываем нижнюю навигацию там где не нужна */
body.venue-admin-fullscreen .bottom-nav { display: none !important; }
body.auth-page .bottom-nav { display: none !important; }
body.auth-page { padding-bottom: 0 !important; }
/* Длинная форма брони: нижняя навигация перекрывает чипы и submit */
body.page-create-booking .bottom-nav { display: none !important; }
body.page-create-booking { padding-bottom: 0 !important; }
/* Страница заведения имеет свой sticky CTA; bottom-nav не должен перехватывать клики */
body.page-establishment .bottom-nav { display: none !important; }
body.page-establishment { padding-bottom: 0 !important; }

/* ——— Кабинет гостя ——— */
/* Ширина через класс на <main> (надёжнее, чем только body + кэш) */
main.container.container--guest-wide {
    max-width: 1680px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: max(16px, env(safe-area-inset-left, 0px)) !important;
    padding-right: max(16px, env(safe-area-inset-right, 0px)) !important;
    box-sizing: border-box !important;
    min-width: 0;
}
.guest-dashboard {
    display: grid;
    gap: 20px;
}
.page-guest-dashboard .guest-dashboard--orbit {
    gap: 18px;
}
.page-guest-dashboard .guest-body {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    align-items: start;
}
@media (min-width: 900px) {
    .page-guest-dashboard .guest-body {
        grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
        gap: 24px 32px;
    }
}
.page-guest-dashboard .guest-search-dock {
    /* Sticky только на десктопе — на мобиле просто блок вверху */
    align-self: start;
}
@media (min-width: 900px) {
    .page-guest-dashboard .guest-search-dock {
        position: sticky;
        top: max(68px, calc(env(safe-area-inset-top, 0px) + 52px));
        z-index: 4;
    }
}
/* =====================================================
   GUEST FILTER FORM (gf-*) — новый блок поиска/фильтров
   ===================================================== */
.gf-form {
    background: #ffffff;
    border-radius: var(--radius-island);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.gf-search {
    padding: 16px 18px 14px;
}

.gf-label {
    display: block;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--faint);
    margin: 0 0 8px;
}

.gf-search-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
    align-items: center;
}

.gf-input-wrap {
    position: relative;
}

.gf-input-icon {
    position: absolute;
    left: 11px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--faint);
    pointer-events: none;
    flex-shrink: 0;
}

.gf-input {
    width: 100%;
    height: 42px;
    border: 1.5px solid var(--line-strong);
    border-radius: 10px;
    background: var(--bg);
    color: var(--text);
    font-size: 14px;
    font-family: var(--font-sans);
    padding: 0 12px 0 33px;
    box-sizing: border-box;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    -webkit-appearance: none;
}

.gf-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(217, 119, 6, 0.12);
    background: #fff;
}

.gf-submit {
    height: 42px;
    padding: 0 16px;
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    border: none;
    border-radius: 10px;
    font-size: 13.5px;
    font-weight: 600;
    font-family: var(--font-sans);
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s ease;
    flex-shrink: 0;
}

.gf-submit:hover { background: var(--btn-primary-hover); }

.gf-divider {
    height: 1px;
    background: var(--line);
    margin: 0;
}

.gf-section {
    padding: 14px 18px;
}

/* ——— Город (select) ——— */
.gf-city-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.gf-city-icon {
    position: absolute;
    left: 11px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--faint);
    pointer-events: none;
}

.gf-select {
    width: 100%;
    height: 40px;
    border: 1.5px solid var(--line-strong);
    border-radius: 10px;
    background: var(--bg);
    color: var(--text);
    font-size: 14px;
    font-family: var(--font-sans);
    padding: 0 32px 0 30px;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
    box-sizing: border-box;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.gf-select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(217, 119, 6, 0.12);
}

.gf-select-arrow {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--faint);
    pointer-events: none;
}

/* ——— Пилюли типов ——— */
.gf-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.gf-pill {
    display: inline-flex;
    cursor: pointer;
    user-select: none;
}

.gf-pill input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    pointer-events: none;
}

.gf-pill span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 7px 13px;
    border: 1.5px solid var(--line-strong);
    border-radius: 999px;
    background: #fff;
    font-size: 13px;
    font-weight: 500;
    font-family: var(--font-sans);
    color: var(--text);
    transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
    white-space: nowrap;
}

.gf-pill span svg { color: var(--faint); transition: color 0.15s ease; }

.gf-pill:hover span {
    border-color: var(--accent-border);
    background: var(--accent-soft);
}

.gf-pill:has(input:checked) span {
    border-color: var(--accent);
    background: var(--accent-soft);
    color: #18130a;
    font-weight: 600;
    box-shadow: 0 0 0 1px var(--accent-border);
}

.gf-pill:has(input:checked) span svg { color: var(--accent); }

/* ——— Сброс ——— */
.gf-reset-wrap {
    padding: 0 18px 14px;
}

.gf-reset {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12.5px;
    font-weight: 500;
    color: var(--muted);
    text-decoration: none;
    transition: color 0.15s ease;
}

.gf-reset:hover { color: var(--danger); }

/* ——— Мобильный layout (горизонтальный скролл для пилюль) ——— */
@media (max-width: 899px) {
    .gf-form {
        border-radius: 12px;
    }

    .gf-search { padding: 14px 14px 12px; }
    .gf-section { padding: 12px 14px; }
    .gf-reset-wrap { padding: 0 14px 12px; }

    .gf-input { height: 46px; font-size: 16px; } /* iOS: no zoom */
    .gf-submit { height: 46px; padding: 0 14px; font-size: 13px; }

    /* Горизонтальный скролл пилюль */
    .gf-pills {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 2px;
        gap: 6px;
    }
    .gf-pills::-webkit-scrollbar { display: none; }
    .gf-pill span { flex-shrink: 0; }

    .gf-select { font-size: 16px; } /* iOS: no zoom */
}

@media (max-width: 899px) {
    /* Мобильная производительность: упрощаем тяжёлые эффекты карточек */
    .row.place-card-glass,
    .mini-card.place-card-glass {
        box-shadow: 0 3px 10px rgba(0, 0, 0, 0.18);
    }
    .row.place-card-glass::before,
    .mini-card.place-card-glass::before {
        filter: none;
    }
    .row.place-card-glass::after,
    .mini-card.place-card-glass::after {
        background:
            linear-gradient(180deg, transparent 0%, transparent 55%, rgba(0, 0, 0, 0.2) 100%),
            rgba(0, 0, 0, 0.08);
    }
    .place-type-badge {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }
}
.page-guest-dashboard .guest-results.places-panel {
    border-radius: var(--radius-island);
}
.page-guest-dashboard .guest-panel-head {
    justify-content: space-between;
    text-align: left;
}

/* =====================================================
   FULL-BLEED каталог на телефоне/планшете — «как приложение»
   Убираем коробку-панель и боковые рамки, карточки на всю ширину.
   ===================================================== */
@media (max-width: 899px) {
    .page-guest-dashboard main.container.container--guest-wide {
        padding-left: max(14px, env(safe-area-inset-left, 0px)) !important;
        padding-right: max(14px, env(safe-area-inset-right, 0px)) !important;
    }
    /* Список заведений — без рамки/фона/тени, без внутренних отступов */
    .page-guest-dashboard .guest-results.places-panel {
        background: transparent;
        border: none;
        box-shadow: none;
        padding: 0;
        margin-bottom: 0;
        border-radius: 0;
    }
    .page-guest-dashboard .guest-results.places-panel:hover {
        border: none;
        box-shadow: none;
    }
    .page-guest-dashboard .guest-panel-head {
        padding: 0 2px 2px;
    }
    /* Поиск/фильтры — лёгкая карточка во всю ширину */
    .page-guest-dashboard .gf-form {
        border-radius: 16px;
    }
    /* Ближайшая бронь — во всю ширину, мягче */
    .page-guest-dashboard .gd-booking-card {
        border-radius: 18px;
    }
}

/* =====================================================
   БЛИЖАЙШАЯ БРОНЬ (gd-booking-card)
   ===================================================== */
.gd-booking-card {
    background: linear-gradient(135deg, #fef9ec 0%, #fdf5e4 100%);
    border: 1.5px solid var(--accent-border);
    border-radius: var(--radius-island);
    padding: 14px 18px;
    margin-bottom: 20px;
    box-shadow: 0 2px 10px rgba(217, 119, 6, 0.08);
}

.gd-booking-card__eyebrow {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 10px;
}

.gd-booking-card__body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.gd-booking-card__info { min-width: 0; }

.gd-booking-card__place {
    margin: 0;
    font-size: 15px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -0.02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.gd-booking-card__time {
    margin: 3px 0 0;
    font-size: 13px;
    color: var(--muted);
    font-weight: 500;
}

.gd-booking-card__table {
    margin: 2px 0 0;
    font-size: 12px;
    color: var(--faint);
}

.gd-booking-card__btn {
    flex-shrink: 0;
    padding: 9px 18px;
    background: var(--accent);
    color: #18130a;
    border-radius: 10px;
    font-size: 13.5px;
    font-weight: 600;
    text-decoration: none;
    transition: filter 0.15s ease, box-shadow 0.15s ease;
    white-space: nowrap;
    box-shadow: 0 2px 8px rgba(217, 119, 6, 0.30);
}
.gd-booking-card__btn:hover {
    filter: brightness(1.07);
    box-shadow: 0 4px 14px rgba(217, 119, 6, 0.42);
    color: #18130a;
}

.place-social-proof {
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    font-weight: 700;
    color: #92400e;
    background: rgba(245, 158, 11, 0.12);
    border: 1px solid rgba(245, 158, 11, 0.28);
    border-radius: 999px;
    padding: 3px 9px;
    margin-bottom: 0;
    max-width: 100%;
    white-space: nowrap;
}

.place-cta-hint {
    font-size: 11px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.96);
    background: rgba(0, 0, 0, 0.38);
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 999px;
    padding: 3px 9px;
    margin-bottom: 0;
    max-width: 100%;
    white-space: nowrap;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

.place-next-slot-hint {
    font-size: 11px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.94);
    background: rgba(0, 0, 0, 0.32);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    padding: 3px 9px;
    margin-bottom: 2px;
    max-width: 100%;
    white-space: nowrap;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

/* =====================================================
   ТИП ЗАВЕДЕНИЯ — SVG-иконки на карточке
   ===================================================== */
.place-type-badges {
    display: flex;
    gap: 5px;
    margin-top: 6px;
    grid-area: flags;
    flex-wrap: nowrap;
}

.place-type-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.35);
    border: 1px solid rgba(255, 255, 255, 0.32);
    color: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    flex-shrink: 0;
    cursor: default;
    transition: background 0.15s ease;
}

.place-type-badge:hover {
    background: rgba(255, 255, 255, 0.25);
}

/* Без обложки — тёмные иконки на янтарном фоне */
.row.place-card-glass:not([style]) .place-type-badge {
    background: var(--accent-soft);
    border-color: var(--accent-border);
    color: var(--accent);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.row.place-card-glass:not([style]) .place-type-badge:hover {
    background: rgba(217, 119, 6, 0.18);
}

/* =====================================================
   СВОРАЧИВАЕМЫЕ ФИЛЬТРЫ — мобильный toggle
   ===================================================== */
.gf-filter-toggle {
    display: none; /* скрыт на десктопе */
}

@media (max-width: 899px) {
    .gf-filter-toggle {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        height: 42px;
        padding: 0 14px;
        background: var(--bg-soft);
        border: 1.5px solid var(--line-strong);
        border-radius: 10px;
        font-size: 13.5px;
        font-weight: 600;
        font-family: var(--font-sans);
        color: var(--text);
        cursor: pointer;
        white-space: nowrap;
        transition: border-color 0.15s ease, background 0.15s ease;
        flex-shrink: 0;
    }
    .gf-filter-toggle.has-active {
        border-color: var(--accent);
        background: var(--accent-soft);
        color: #18130a;
    }
    .gf-filter-toggle.has-active svg { color: var(--accent); }
    .gf-filter-toggle svg { color: var(--faint); }

    /* Счётчик активных фильтров */
    .gf-filter-badge {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 18px;
        height: 18px;
        padding: 0 5px;
        border-radius: 999px;
        background: var(--accent);
        color: #18130a;
        font-size: 11px;
        font-weight: 700;
    }

    /* Тело фильтров: скрыто по умолчанию на мобиле */
    .gf-filters-body {
        display: none;
    }
    .gf-filters-body.is-open {
        display: block;
    }
}

@media (min-width: 900px) {
    /* На десктопе тело всегда видно */
    .gf-filters-body { display: block !important; }
    .gf-filter-badge { display: none; }
}

/* =====================================================
   EMPTY STATE — пустой список заведений
   ===================================================== */
.gd-empty {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    text-align: center;
    gap: 10px;
}

.gd-empty__icon {
    color: var(--faint);
    margin-bottom: 4px;
}

.gd-empty__title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--text);
    letter-spacing: -0.02em;
}

.gd-empty__hint {
    margin: 0;
    font-size: 14px;
    color: var(--muted);
    line-height: 1.5;
    max-width: 260px;
}

/* =====================================================
   GUEST PANEL HEAD — уточнённый стиль
   ===================================================== */
.guest-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 24px;
    padding: 0 9px;
    border-radius: 999px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    font-size: 12px;
    font-weight: 600;
    color: var(--muted);
}

/* row-title grid area для place-type-badges */
.row.place-card-glass .row-title {
    grid-template-areas:
        "avatar title"
        "avatar meta"
        "avatar flags"
        "avatar info";
}
.guest-intro {
    border-radius: var(--radius-island);
    border: 1px solid var(--line);
    background: linear-gradient(135deg, rgba(217, 119, 6, 0.06), rgba(255, 255, 255, 0.98));
    padding: 18px 20px;
    font-size: 15px;
    line-height: 1.55;
    color: var(--text);
}
.guest-intro strong {
    font-weight: 700;
}
.guest-intro-actions {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}
.guest-intro-actions a {
    font-weight: 600;
    font-size: 14px;
}
.guest-intro-hint {
    font-size: 13px;
    color: var(--muted);
}
.guest-empty-extra {
    margin-top: 12px;
}
.access-blocked-panel {
    max-width: 560px;
    margin: 32px auto;
}
.access-blocked-panel h1 {
    margin-top: 0;
    font-size: 22px;
    letter-spacing: -0.02em;
}
.access-blocked-panel .access-blocked-actions {
    margin-top: 20px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.access-blocked-meta {
    font-size: 14px;
    margin: 0.35em 0 0;
}
.venue-empty-panel {
    max-width: 520px;
    margin: 0 auto;
}
.venue-empty-panel h2 {
    margin-top: 0;
}
.guest-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}
.guest-panel-head.centered {
    justify-content: center;
    text-align: center;
}
.guest-panel-head h3 {
    margin: 0;
    font-size: 22px;
    letter-spacing: -0.02em;
}
.guest-pill {
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    color: var(--muted);
    border: 1px solid var(--line);
    background: rgba(0, 0, 0, 0.03);
}
.guest-dashboard .bookings-list {
    display: grid;
    gap: 10px;
}
.guest-dashboard .booking-item {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 14px;
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}
.guest-dashboard .booking-main {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 4px;
}
.guest-dashboard .booking-main strong {
    font-size: 16px;
}
.guest-dashboard .booking-status {
    flex-shrink: 0;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 11px;
    font-weight: 600;
    border: 1px solid var(--line);
    color: var(--text);
    background: var(--bg);
    white-space: nowrap;
}
.guest-dashboard .booking-meta {
    color: var(--muted);
    font-weight: 600;
    margin-bottom: 4px;
}
.guest-dashboard .empty-state {
    border: 1px dashed var(--line-strong);
    border-radius: 16px;
    padding: 20px;
    color: var(--muted);
    background: var(--accent-soft);
    text-align: center;
}
.places-panel .row.place-card-glass {
    margin-bottom: 8px;
}
.places-search {
    margin-bottom: 16px;
}
.places-search .places-search-main {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
}
.places-search .places-search-input {
    width: 100%;
    border: 1px solid var(--input-border);
    border-radius: 14px;
    padding: 12px 14px;
    color: var(--text);
    background: var(--input-bg);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.places-search .places-search-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(217, 119, 6, 0.13);
}
.places-search .places-search-filters {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 10px;
    justify-content: flex-start;
    align-items: center;
}
.places-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}
/* ЛК гостя: явная сетка на широком main — несколько карточек в ряд */
.container--guest-wide .places-grid {
    grid-template-columns: 1fr;
    gap: 18px;
}
@media (min-width: 560px) {
    .container--guest-wide .places-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (min-width: 900px) {
    .container--guest-wide .places-grid {
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    }
}
@media (min-width: 1200px) {
    .container--guest-wide .places-grid {
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    }
}
.places-grid .row.place-card-glass {
    height: 100%;
    margin-bottom: 0;
    align-items: stretch;
}
.places-grid .row.place-card-glass.is-entering {
    animation: placeCardIn 0.28s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.places-grid .row.place-card-glass .row-title {
    align-content: start;
}
.places-grid .row.place-card-glass .row-actions {
    align-self: end;
    margin-top: 10px;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
}
.place-action-buttons {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.places-grid .empty-state {
    grid-column: 1 / -1;
}
@keyframes placeCardIn {
    from {
        opacity: 0;
        transform: translateY(8px) scale(0.985);
        filter: blur(4px);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
        filter: blur(0);
    }
}
@media (max-width: 900px) {
    .guest-dashboard .guest-metrics {
        grid-template-columns: 1fr;
    }
    .guest-dashboard .guest-top {
        flex-direction: column;
        align-items: flex-start;
    }
    .guest-dashboard .booking-main {
        flex-direction: column;
        align-items: flex-start;
    }
    .places-search .places-search-main {
        grid-template-columns: 1fr;
    }
}

/* ——— Создание брони v2 — новый шаблон ——— */
.bk-page {
    max-width: 600px;
    margin: 0 auto;
    padding: 0 0 120px;
}
.bk-head {
    padding: 20px 0 4px;
}
.bk-back {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: .85rem;
    font-weight: 600;
    color: var(--amber);
    text-decoration: none;
    margin-bottom: 10px;
}
.bk-back:hover { color: var(--amber-dark); }
.bk-title {
    font-size: 1.55rem;
    font-weight: 800;
    letter-spacing: -.03em;
    color: var(--text);
    margin: 0 0 4px;
}
.bk-lead {
    font-size: .88rem;
    color: var(--text-muted);
    margin: 0 0 4px;
}

/* Часы работы + ошибки формы */
.bk-hours-banner {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-muted);
    background: var(--bg-soft);
    border: 1px solid var(--border);
    border-radius: 99px;
    padding: 5px 12px;
    margin-top: 6px;
}
.bk-form-errors {
    background: rgba(220, 38, 38, .06);
    border: 1.5px solid rgba(220, 38, 38, .25);
    border-radius: var(--radius);
    padding: 10px 14px;
    margin-bottom: 10px;
}
.bk-form-errors p {
    margin: 0;
    font-size: .88rem;
    color: #dc2626;
    font-weight: 600;
}

/* Секции */
.bk-section {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 18px 18px 14px;
    margin-top: 10px;
}
.bk-section-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .95rem;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 12px;
}
.bk-section-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--amber);
    color: #fff;
    font-size: .72rem;
    font-weight: 800;
    flex-shrink: 0;
}
.bk-section-hint {
    font-size: .78rem;
    font-weight: 400;
    color: var(--text-muted);
    margin-left: auto;
}

/* Выбранный стол */
.bk-selected-table {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--bg-soft);
    border-radius: var(--radius);
}
.bk-selected-table__icon {
    color: var(--amber);
    flex-shrink: 0;
}
.bk-selected-table__info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: .88rem;
}
.bk-selected-table__info strong { color: var(--text); }
.bk-selected-table__info span { color: var(--text-muted); font-size: .8rem; }
.bk-selected-table__change {
    font-size: .8rem;
    font-weight: 600;
    color: var(--amber);
    text-decoration: none;
    flex-shrink: 0;
}

/* Пикер столов */
.bk-table-picker {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.bk-table-btn {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 10px 14px;
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    text-align: left;
    cursor: pointer;
    transition: border-color .15s, background .15s;
}
.bk-table-btn:hover { border-color: rgba(217,119,6,.35); }
.bk-table-btn.is-active {
    border-color: var(--amber);
    background: rgba(217,119,6,.06);
}
.bk-table-btn__name { font-size: .92rem; font-weight: 600; color: var(--text); }
.bk-table-btn__meta { font-size: .8rem; color: var(--text-muted); }

/* Быстрый выбор даты */
.bk-date-quick {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.bk-date-chip {
    padding: 6px 14px;
    border-radius: 99px;
    border: 1.5px solid var(--border);
    background: var(--surface);
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    transition: border-color .15s, color .15s, background .15s;
    white-space: nowrap;
}
.bk-date-chip:hover { border-color: rgba(217,119,6,.4); color: var(--amber-dark); }
.bk-date-chip.is-active {
    border-color: var(--amber);
    background: rgba(217,119,6,.08);
    color: var(--amber-dark);
}
.bk-date-chip--weekend { color: #7c3aed; border-color: rgba(124,58,237,.2); }
.bk-date-chip--weekend:hover { border-color: rgba(124,58,237,.5); color: #5b21b6; }
.bk-date-chip--weekend.is-active {
    border-color: #7c3aed;
    background: rgba(124,58,237,.07);
    color: #5b21b6;
}

/* Дата input */
.bk-date-row { display: flex; gap: 8px; }
.bk-date-input-wrap {
    position: relative;
    flex: 1;
}
.bk-date-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-muted);
    pointer-events: none;
}
.bk-date-input {
    width: 100%;
    height: 42px;
    border: 1.5px solid var(--input-border);
    border-radius: var(--radius);
    background: var(--input-bg);
    color: var(--text);
    padding: 0 12px 0 36px;
    font-size: .93rem;
    font-family: inherit;
    box-sizing: border-box;
    transition: border-color .15s, box-shadow .15s;
}
.bk-date-input:focus {
    outline: none;
    border-color: rgba(217,119,6,.5);
    box-shadow: 0 0 0 3px rgba(217,119,6,.1);
}

/* Слоты времени */
.bk-slots-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: flex-start;
}
.bk-slots-empty {
    font-size: .87rem;
    color: var(--text-muted);
    margin: 0;
    font-style: italic;
}
.bk-slot-group {
    width: 100%;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--text-muted);
    padding: 4px 0 2px;
    margin-top: 4px;
}
.bk-slot-group:first-child { margin-top: 0; }
.bk-slot {
    min-width: 60px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    font-size: .88rem;
    font-weight: 600;
    color: var(--text);
    cursor: pointer;
    transition: border-color .15s, background .15s, color .15s;
}
.bk-slot:hover:not(:disabled) { border-color: rgba(217,119,6,.4); }
.bk-slot.is-active {
    border-color: var(--amber);
    background: var(--amber);
    color: #fff;
}
.bk-slot.is-busy {
    opacity: .4;
    cursor: not-allowed;
    text-decoration: line-through;
}

/* Поля данных */
.bk-fields-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 10px;
}
.bk-field { margin-bottom: 10px; }
.bk-field--guests { margin-bottom: 10px; }
.bk-label {
    display: block;
    font-size: .8rem;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 6px;
}
.bk-optional { font-weight: 400; text-transform: none; letter-spacing: 0; }
.bk-field input,
.bk-field textarea,
.bk-field select {
    width: 100%;
    box-sizing: border-box;
    height: 42px;
    border: 1.5px solid var(--input-border);
    border-radius: var(--radius);
    background: var(--input-bg);
    color: var(--text);
    padding: 0 12px;
    font-size: .93rem;
    font-family: inherit;
    transition: border-color .15s, box-shadow .15s;
}
.bk-field textarea {
    height: auto;
    min-height: 64px;
    padding: 10px 12px;
    resize: vertical;
}
.bk-field input:focus,
.bk-field textarea:focus,
.bk-field select:focus {
    outline: none;
    border-color: rgba(217,119,6,.5);
    box-shadow: 0 0 0 3px rgba(217,119,6,.1);
}
.bk-field-error {
    font-size: .78rem;
    color: #dc2626;
    margin: 4px 0 0;
}

/* Гости чипы */
.bk-guests-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.bk-date-chip,
.bk-slot,
.bk-table-btn,
.bk-guests-chip {
    position: relative;
    z-index: 1;
    touch-action: manipulation;
}
.bk-guests-chip {
    min-width: 42px;
    height: 38px;
    padding: 0 10px;
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    font-size: .92rem;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    transition: border-color .15s, background .15s, color .15s;
}
.bk-guests-chip:hover { border-color: rgba(217,119,6,.4); }
.bk-guests-chip.is-active {
    border-color: var(--amber);
    background: rgba(217,119,6,.08);
    color: var(--amber-dark);
}

/* Итог */
.bk-summary {
    background: rgba(217,119,6,.07);
    border: 1.5px solid rgba(217,119,6,.25);
    border-radius: var(--radius);
    padding: 10px 14px;
    margin-top: 10px;
}
.bk-summary__inner {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .9rem;
    font-weight: 600;
    color: var(--amber-dark);
}

/* Кнопка подтверждения */
.bk-submit-wrap {
    margin-top: 14px;
    text-align: center;
}
.bk-submit {
    width: 100%;
    height: 52px;
    border-radius: 99px;
    border: none;
    background: var(--amber, var(--accent));
    color: #1a0f05;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    letter-spacing: -.01em;
    transition: background .15s, box-shadow .15s;
    box-shadow: 0 4px 18px rgba(217,119,6,.35);
}
.bk-submit:hover { background: var(--amber-dark, #b45309); color: #fff; box-shadow: 0 6px 22px rgba(217,119,6,.45); }
.bk-confirm-note {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    font-size: .78rem;
    color: #16a34a;
    font-weight: 600;
    margin: 8px 0 0;
}

/* Sticky submit (мобайл) */
.bk-sticky-submit {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 220;
    pointer-events: auto;
    padding: 12px 16px calc(12px + env(safe-area-inset-bottom, 0px));
    background: rgba(250,249,246,.92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid var(--border);
}
.bk-sticky-submit[hidden] { display: none; }
.bk-submit--sticky {
    width: 100%;
    height: 48px;
    border-radius: 99px;
    border: none;
    background: var(--amber, var(--accent));
    color: #1a0f05;
    font-size: .95rem;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 4px 18px rgba(217,119,6,.35);
    transition: background .15s, color .15s, box-shadow .15s;
}
.bk-submit--sticky:hover {
    background: var(--amber-dark, #b45309);
    color: #fff;
}

@media (min-width: 640px) {
    .bk-sticky-submit { display: none !important; }
    .bk-page { padding-bottom: 40px; }
}
@media (max-width: 500px) {
    .bk-fields-2 { grid-template-columns: 1fr; }
    .bk-page { padding: 0 0 calc(88px + env(safe-area-inset-bottom, 0px)); }
}
body.page-create-booking .bk-page {
    padding-bottom: calc(100px + env(safe-area-inset-bottom, 0px));
}
.bk-submit.is-loading,
.bk-submit--sticky.is-loading {
    opacity: 0.72;
    pointer-events: none;
    cursor: wait;
}
.bk-slot.is-past {
    opacity: 0.35;
    text-decoration: line-through;
}
/* Stepper */
.bk-stepper {
    display: flex;
    gap: 6px;
    margin: 12px 0 4px;
    padding: 0;
    list-style: none;
}
.bk-stepper__item {
    flex: 1;
    text-align: center;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-muted);
    padding: 6px 4px;
    border-radius: 8px;
    background: var(--surface);
    border: 1px solid var(--border);
    transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.bk-stepper__item.is-active {
    color: var(--amber-dark);
    border-color: rgba(217, 119, 6, 0.45);
    background: rgba(217, 119, 6, 0.08);
}
.bk-stepper__item.is-done {
    color: #16a34a;
    border-color: rgba(22, 163, 74, 0.35);
}
.venue-booking-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.venue-booking-card__primary {
    flex: 1;
    min-width: 0;
}
.venue-booking-card__secondary {
    flex: 0 0 auto;
}
/* Settings tabs */
.venue-settings-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 16px;
}
.venue-settings-tabs__btn {
    padding: 8px 14px;
    border-radius: 99px;
    border: 1.5px solid var(--border);
    background: var(--surface);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.venue-settings-tabs__btn.is-active {
    border-color: var(--amber);
    color: var(--amber-dark);
    background: rgba(217, 119, 6, 0.08);
}
.venue-settings-tab-panel[hidden] {
    display: none !important;
}

/* ——— Создание брони (отдельная страница) — СТАРЫЕ стили (оставлены для обратной совместимости) ——— */
.booking-back-wrap {
    margin: 0 0 8px;
}
.booking-back-link {
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    color: var(--link);
}
.booking-back-link:hover {
    color: var(--link-hover);
}
.booking-lead-hint {
    margin: 10px 0 0;
    font-size: 14px;
    line-height: 1.5;
}
.venue-empty-panel .access-blocked-actions {
    margin-top: 16px;
}
.page-create-booking .booking-shell {
    max-width: 760px;
    margin: 0 auto;
    border: 1px solid var(--line);
    border-radius: var(--radius-island);
    padding: 20px;
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}
.page-create-booking .booking-layout {
    display: grid;
    gap: 12px;
}
.page-create-booking .booking-header {
    display: grid;
    gap: 6px;
}
.page-create-booking .booking-title {
    margin: 0;
    font-size: 24px;
    letter-spacing: -0.02em;
}
.page-create-booking .booking-header .muted {
    font-size: 14px;
}
.page-create-booking .booking-busy {
    margin: 2px 0 8px;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px;
    background: var(--bg);
}
.page-create-booking .booking-busy-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 6px;
}
.page-create-booking .booking-busy-title {
    margin: 0;
    font-size: 13px;
    font-weight: 700;
}
.page-create-booking .booking-busy-hint {
    font-size: 11px;
    color: var(--muted);
}
.page-create-booking .booking-busy-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.page-create-booking .booking-busy-item {
    border: 1px solid var(--line);
    background: #ffffff;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 12px;
    color: var(--text);
}
.page-create-booking .booking-busy-empty {
    color: var(--muted);
    font-size: 13px;
}
.page-create-booking .booking-datetime-native {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 1px;
    height: 1px;
}
.page-create-booking .booking-datetime-custom {
    display: grid;
    grid-template-columns: 1fr 128px;
    gap: 8px;
}
.page-create-booking .booking-slots {
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    max-height: 86px;
    overflow: auto;
    padding-right: 2px;
}
.page-create-booking .booking-slot {
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 11px;
    color: var(--text);
    background: #ffffff;
    cursor: pointer;
    line-height: 1.25;
    transition: border-color 0.15s ease, background 0.15s ease;
}
.page-create-booking .booking-slot.is-active {
    border-color: rgba(217, 119, 6, 0.45);
    background: var(--accent-soft);
    color: var(--ink);
    font-weight: 600;
}
.page-create-booking .booking-slot.is-disabled {
    opacity: 0.38;
    cursor: not-allowed;
}
.page-create-booking .booking-selected-table {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px 14px;
    background: var(--bg);
}
.page-create-booking .booking-selected-table strong {
    display: block;
    margin-bottom: 4px;
}
.page-create-booking #bookingTablePhotoWrap img {
    max-height: 170px;
    object-fit: cover;
    border-radius: 12px;
}
.page-create-booking .booking-datetime-custom input,
.page-create-booking .booking-datetime-custom select {
    width: 100%;
    height: 40px;
    border-radius: 12px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--text);
    padding: 6px 12px;
}
.page-create-booking .booking-datetime-custom input:focus,
.page-create-booking .booking-datetime-custom select:focus {
    outline: none;
    border-color: rgba(217, 119, 6, 0.45);
    box-shadow: 0 0 0 3px var(--accent-soft);
}
.page-create-booking .booking-form {
    margin-top: 0;
}
.page-create-booking .booking-form .booking-row {
    gap: 8px;
}
.page-create-booking .booking-form .field-label {
    margin-bottom: 4px;
    font-size: 12px;
}
.page-create-booking .booking-form .booking-field input,
.page-create-booking .booking-form .booking-field select,
.page-create-booking .booking-form .booking-field textarea {
    height: auto;
    min-height: 40px;
    padding: 8px 12px;
}
.page-create-booking .booking-form .booking-field textarea {
    min-height: 56px;
}
.page-create-booking .booking-submit.btn {
    height: 44px;
    font-size: 15px;
    border-radius: var(--radius-pill);
}
@media (max-width: 700px) {
    .page-create-booking .booking-shell {
        padding: 14px;
    }
    .page-create-booking .booking-datetime-custom {
        grid-template-columns: 1fr;
    }
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .app-bg::before, .shape, .brand-logo, .topbar-scan { animation: none; }
    .hero, .panel, .auth-shell, .btn { transition: none; }
    .guest-search-panel {
        transition: none;
    }
    .guest-search-dropdown,
    .guest-search-full {
        transition: none !important;
    }
}

/* ===== Serenity: гостевой кабинет, панель заведения, профиль точки ===== */
.guest-welcome {
    padding: 26px 28px 24px;
    border-radius: var(--radius-island);
    border: 1px solid var(--line);
    background: linear-gradient(155deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 245, 241, 0.92) 100%);
    box-shadow: var(--shadow-sm);
}
.guest-welcome__eyebrow {
    margin: 0 0 8px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
}
.guest-welcome__title {
    margin: 0 0 10px;
    font-size: clamp(22px, 2.4vw, 30px);
    font-weight: 800;
    letter-spacing: -0.035em;
    line-height: 1.18;
    color: var(--text);
}
.guest-welcome__lead {
    margin: 0;
    font-size: 15px;
    line-height: 1.62;
    color: var(--muted);
    max-width: 42em;
}
.guest-welcome__links {
    margin-top: 14px;
}
.guest-welcome__links a {
    font-weight: 600;
    font-size: 14px;
}
.guest-welcome--compact {
    padding: 20px 22px;
}
.guest-welcome__grid {
    display: grid;
    gap: 16px;
    align-items: start;
}
@media (min-width: 700px) {
    .guest-welcome__grid {
        grid-template-columns: 1fr minmax(200px, 260px);
        gap: 20px 28px;
    }
}
.guest-welcome__aside {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.65);
}
.guest-welcome__cardlink {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 14px;
    border-radius: 12px;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    color: var(--accent) !important;
    background: var(--accent-soft);
    border: 1px solid rgba(217, 119, 6, 0.2);
    transition: background 0.15s ease, transform 0.15s ease;
}
.guest-welcome__cardlink:hover {
    background: rgba(217, 119, 6, 0.18);
    transform: translateY(-1px);
}
.guest-welcome__hint {
    margin: 0;
    font-size: 12px;
    line-height: 1.45;
}

.venue-edit-head {
    margin-bottom: 22px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--line);
}
.venue-edit-eyebrow {
    margin: 0 0 8px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
}
.venue-edit-head h2 {
    margin: 0 0 8px;
    font-size: clamp(22px, 2vw, 26px);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.2;
}
.venue-edit-lead {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    max-width: 36em;
}
.page-venue-edit .venue-edit-form label {
    font-weight: 600;
    font-size: 13px;
    color: var(--muted);
}

/* Hub-страницы заведения: настройки, медиатека */
.venue-hub-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 14px 0 4px;
    padding: 4px;
    border-radius: 12px;
    background: rgba(0, 0, 0, 0.03);
    border: 1px solid var(--line);
}
.venue-hub-nav__link {
    padding: 8px 14px;
    border-radius: 9px;
    font-size: 13px;
    font-weight: 600;
    color: var(--muted);
    text-decoration: none;
    transition: background 0.12s ease, color 0.12s ease;
}
.venue-hub-nav__link:hover {
    color: var(--text);
    background: rgba(255, 255, 255, 0.7);
}
.venue-hub-nav__link.is-active {
    color: var(--text);
    background: #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.venue-hub-page {
    max-width: 920px;
    margin: 0 auto;
    padding-bottom: 32px;
}
.venue-hub-page__head {
    margin-bottom: 20px;
}
.venue-hub-page__head-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.venue-hub-page__eyebrow {
    margin: 0 0 4px;
    font-size: 12px;
}
.venue-hub-page__title {
    margin: 0 0 6px;
    font-size: clamp(24px, 3vw, 30px);
    font-weight: 800;
    letter-spacing: -0.03em;
}
.venue-hub-page__sub {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
    max-width: 40em;
}
.venue-hub-page__switch {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
}
.venue-hub-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 14px;
    margin: 12px 0 22px;
}
.venue-hub-tile {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 88px;
    padding: 18px 20px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: var(--surface);
    text-decoration: none !important;
    color: var(--text) !important;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}
.venue-hub-tile:hover {
    border-color: var(--accent-border);
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
    color: var(--text) !important;
}
.venue-hub-tile__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 12px;
    background: var(--accent-soft, rgba(217, 119, 6, 0.1));
    color: var(--link, #b45309);
}
.venue-hub-tile--primary {
    border-color: var(--accent-border);
    background: linear-gradient(145deg, rgba(217, 119, 6, 0.1), rgba(255, 255, 255, 0.98));
}
.venue-hub-tile__title {
    font-weight: 800;
    font-size: 15px;
    letter-spacing: -0.02em;
    line-height: 1.3;
}
.venue-hub-tile__desc {
    font-size: 13px;
    line-height: 1.45;
    color: var(--muted);
}

/* ── Заголовки групп в hub ── */
.venue-hub-group-title {
    margin: 22px 0 0;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
}

/* ── Главный блок hub: операционная панель ── */
.venue-hub-hero {
    display: flex;
    align-items: center;
    gap: 14px;
    margin: 16px 0 4px;
    padding: 18px 20px;
    border-radius: 18px;
    border: 1px solid var(--accent-border, rgba(217, 119, 6, 0.35));
    background: linear-gradient(135deg, rgba(217, 119, 6, 0.14), rgba(255, 255, 255, 0.96));
    text-decoration: none !important;
    color: var(--text) !important;
    box-shadow: 0 8px 24px rgba(217, 119, 6, 0.1);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.venue-hub-hero:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 30px rgba(217, 119, 6, 0.16);
}
.venue-hub-hero:active { transform: scale(0.995); }
.venue-hub-hero__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    flex: 0 0 auto;
    border-radius: 14px;
    background: var(--link, #b45309);
    color: #fff;
}
.venue-hub-hero__body { flex: 1 1 auto; min-width: 0; }
.venue-hub-hero__title {
    display: block;
    font-size: 17px;
    font-weight: 800;
    letter-spacing: -0.02em;
}
.venue-hub-hero__desc {
    display: block;
    margin-top: 2px;
    font-size: 13px;
    color: var(--muted);
}
.venue-hub-hero__arrow {
    flex: 0 0 auto;
    color: var(--link, #b45309);
}

@media (max-width: 640px) {
    .venue-hub-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    /* Компактная строка: иконка слева, заголовок+описание справа */
    .venue-hub-tile {
        display: grid;
        grid-template-columns: 42px 1fr;
        grid-template-areas:
            "icon title"
            "icon desc";
        column-gap: 14px;
        row-gap: 2px;
        align-items: center;
        min-height: 0;
        padding: 14px 16px;
    }
    .venue-hub-tile__icon { grid-area: icon; align-self: center; }
    .venue-hub-tile__title { grid-area: title; align-self: end; }
    .venue-hub-tile__desc { grid-area: desc; align-self: start; }
    .venue-hub-hero { padding: 16px; }
}
.venue-sub-compact--block {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
    max-width: none;
    width: 100%;
    border-radius: 14px;
    margin-bottom: 8px;
    padding: 14px 18px;
}
.page-venue-owner-hub .venue-hub-page__head h1,
.page-venue-hub .venue-hub-page__head h1 {
    margin: 0 0 6px;
    font-size: clamp(24px, 3vw, 30px);
    font-weight: 800;
    letter-spacing: -0.03em;
}
.venue-owner-staff {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid var(--line);
}
.venue-owner-staff h2 {
    margin: 0 0 16px;
    font-size: 18px;
    font-weight: 800;
}
.venue-owner-staff__hint {
    margin: 0 0 14px;
    font-size: 14px;
    max-width: 42em;
}
.venue-owner-staff-list {
    list-style: none;
    margin: 16px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.venue-owner-staff-list li {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 6px 10px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.7);
}
.venue-staff-invite-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 14px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--bg-soft);
}
.venue-staff-invite-form__full {
    grid-column: 1 / -1;
}
.venue-staff-invite-form label {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
    color: var(--muted);
}
.venue-staff-invite-form input,
.venue-staff-invite-form select {
    font: inherit;
    padding: 10px 12px;
    border: 1px solid var(--input-border);
    border-radius: 10px;
    background: var(--input-bg);
    color: var(--text);
}
.venue-staff-invite-form__actions {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}
.venue-staff-invite-result {
    grid-column: 1 / -1;
    padding: 12px 14px;
    border-radius: 10px;
    font-size: 13px;
    background: var(--success-soft);
    border: 1px solid rgba(22, 163, 74, 0.25);
}
.venue-staff-invite-result.is-error {
    background: var(--danger-soft);
    border-color: rgba(220, 38, 38, 0.25);
}
@media (max-width: 640px) {
    .venue-staff-invite-form {
        grid-template-columns: 1fr;
    }
}

/* =====================================================
   Диалог «Новая бронь» (хостес) — премиум-модалка / bottom-sheet
   ===================================================== */
.venue-hostess-dialog {
    width: min(520px, calc(100vw - 32px));
    max-width: 520px;
    max-height: min(90vh, 760px);
    padding: 0;
    border: 1px solid var(--line);
    border-radius: 22px;
    background: var(--bg, #fbf8f3);
    box-shadow: 0 30px 80px rgba(20, 12, 4, 0.32);
    overflow: hidden;
    color: var(--text);
}
.venue-hostess-dialog::backdrop {
    background: rgba(10, 7, 2, 0.5);
    backdrop-filter: blur(2px);
}
.venue-hostess-dialog[open] {
    display: flex;
    flex-direction: column;
    animation: vhdPop 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes vhdPop {
    from { opacity: 0; transform: translateY(8px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
.vhd-head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 18px 20px 14px;
    border-bottom: 1px solid var(--line);
    background: #fff;
}
.vhd-title { margin: 0; font-size: 19px; font-weight: 800; letter-spacing: -0.02em; }
.vhd-sub { margin: 2px 0 0; font-size: 12.5px; }
.vhd-close {
    margin-left: auto;
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: #fff;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    transition: background 0.12s ease;
}
.vhd-close:hover { background: var(--bg-soft, #f5f0e8); }
.venue-hostess-dialog .vhd-form {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    min-height: 0;
    flex: 1 1 auto;
}
.vhd-body {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 14px;
    padding: 16px 20px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    min-height: 0;
}
.vhd-body .venue-staff-invite-form__full { grid-column: 1 / -1; }
.vhd-actions {
    margin: 0;
    padding: 12px 20px;
    border-top: 1px solid var(--line);
    background: #fff;
    display: flex;
    align-items: center;
    gap: 10px;
}
.vhd-actions .vhd-msg { flex: 1 1 auto; font-size: 12.5px; }
.vhd-actions .vhd-submit { margin-left: auto; }

@media (max-width: 640px) {
    .venue-hostess-dialog {
        width: 100vw;
        max-width: 100vw;
        height: 100dvh;
        max-height: 100dvh;
        margin: 0;
        border: 0;
        border-radius: 0;
    }
    .venue-hostess-dialog[open] {
        animation: vhdSheetUp 0.26s cubic-bezier(0.22, 1, 0.36, 1);
    }
    @keyframes vhdSheetUp {
        from { transform: translateY(100%); }
        to   { transform: translateY(0); }
    }
    .vhd-head {
        padding-top: calc(16px + env(safe-area-inset-top, 0px));
    }
    .vhd-body { grid-template-columns: 1fr; }
    .vhd-body input,
    .vhd-body select {
        height: 46px;
        font-size: 16px; /* без зума iOS */
    }
    .vhd-actions {
        padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
        box-shadow: 0 -10px 24px rgba(28, 16, 7, 0.1);
    }
    .vhd-actions .vhd-submit { flex: 0 0 auto; height: 48px; padding: 0 18px; font-weight: 800; }
}

.venue-media-page-upload {
    margin-bottom: 18px;
}
.venue-media-page-hint {
    margin: 0;
    font-size: 12px;
}
.venue-media-grid--page {
    min-height: 120px;
}
.venue-media-tile--pick .venue-media-tile-pick {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 6px 8px;
    font-size: 11px;
    font-weight: 700;
    text-align: center;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.72));
    color: #fff;
}
.venue-settings-form {
    display: grid;
    gap: 22px;
}
.venue-settings-section {
    padding: 18px 20px;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.72);
}
.venue-settings-section__head {
    margin-bottom: 14px;
}
.venue-settings-section__title {
    margin: 0 0 6px;
    font-size: 16px;
    font-weight: 800;
}
.venue-settings-section__hint {
    margin: 0;
    font-size: 13px;
}
.venue-settings-section__hint a {
    font-weight: 600;
}
.venue-settings-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 14px;
}
.venue-settings-field {
    display: grid;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: var(--muted);
}
.venue-settings-field--wide {
    grid-column: 1 / -1;
}
.venue-settings-field input,
.venue-settings-field textarea,
.venue-settings-field select {
    font-weight: 400;
    width: 100%;
}
.venue-settings-flags {
    margin: 12px 0;
}
.venue-settings-media-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.venue-settings-media-block {
    display: grid;
    gap: 10px;
}
.venue-settings-preview {
    aspect-ratio: 1;
    max-width: 160px;
    border-radius: 12px;
    border: 1px dashed rgba(0, 0, 0, 0.14);
    background: rgba(0, 0, 0, 0.03);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.venue-settings-preview--wide {
    aspect-ratio: 16 / 10;
    max-width: 100%;
}
.venue-settings-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.venue-settings-preview__empty {
    font-size: 12px;
    padding: 8px;
    text-align: center;
}
.venue-settings-check {
    display: flex;
    align-items: center;
    gap: 8px;
}
.venue-settings-help {
    font-size: 12px;
    margin: -4px 0 10px;
}
.venue-settings-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding-top: 4px;
}
.pos-integration-card {
    margin-top: 16px;
    padding: 16px;
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: rgba(255, 255, 255, 0.5);
    display: grid;
    gap: 12px;
}
.pos-integration-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.pos-integration-card__hint {
    margin: 0;
    font-size: 13px;
    line-height: 1.45;
}
.pos-integration-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
}
.pos-integration-options {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 18px;
    font-size: 13px;
}
.pos-integration-options label {
    display: flex;
    align-items: center;
    gap: 6px;
}
.pos-integration-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.pos-integration-status {
    margin: 0;
    font-size: 12px;
    line-height: 1.4;
    min-height: 1.2em;
}
.pos-integration-status.is-error {
    color: #b42318;
}
.pos-menu-primary {
    margin-bottom: 16px;
}
.pos-menu-primary__resolved {
    display: block;
    font-size: 12px;
    margin-top: 4px;
}
.pos-integration-docs {
    margin-bottom: 18px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    padding: 10px 14px;
    background: rgba(0, 0, 0, 0.02);
}
.pos-integration-docs summary {
    cursor: pointer;
    font-weight: 600;
}
.pos-integration-docs__body {
    margin-top: 10px;
    font-size: 13px;
    line-height: 1.5;
}
.pos-integration-docs__body p {
    margin: 0 0 8px;
}
.venue-pos-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.3;
    vertical-align: middle;
    white-space: nowrap;
}
.venue-pos-badge--ok {
    background: rgba(18, 128, 68, 0.12);
    color: #128044;
}
.venue-pos-badge--err {
    background: rgba(180, 35, 24, 0.12);
    color: #b42318;
}
.venue-pos-badge--muted {
    background: rgba(0, 0, 0, 0.06);
    color: var(--muted);
}
.venue-pos-badge__prov {
    opacity: 0.75;
    font-weight: 600;
    font-size: 10px;
}
.venue-pos-badge__rev {
    font-weight: 600;
    opacity: 0.9;
}
.venue-pos-detail {
    margin: 8px 0 4px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}
.venue-pos-detail__err {
    margin: 0;
    font-size: 12px;
    flex: 1 1 100%;
}
.venue-booking-card-top .venue-pos-badge {
    margin-left: auto;
}
@media (max-width: 720px) {
    .venue-settings-grid,
    .venue-settings-media-row {
        grid-template-columns: 1fr;
    }
    .venue-hub-nav__link {
        padding: 7px 12px;
        font-size: 12px;
    }
    /* Subnav в одну строку со свайпом — как таб-бар в приложении */
    .venue-hub-nav {
        flex-wrap: nowrap;
        overflow-x: auto;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
    }
    .venue-hub-nav::-webkit-scrollbar { display: none; }
    .venue-hub-nav__link { white-space: nowrap; flex: 0 0 auto; }
}

/* Настройки / медиатека — поля и layout (page-venue-settings, page-venue-media) */
.page-venue-settings main.container,
.page-venue-media main.container {
    padding-top: 12px;
    padding-bottom: max(24px, env(safe-area-inset-bottom, 0px));
}
.page-venue-settings .venue-hub-page,
.page-venue-media .venue-hub-page {
    width: 100%;
}
.page-venue-settings .venue-settings-form label,
.page-venue-settings .hours-edit-grid label {
    display: grid;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: var(--muted);
}
.page-venue-settings .venue-settings-input,
.page-venue-settings .venue-settings-form input:not([type="checkbox"]):not([type="radio"]),
.page-venue-settings .venue-settings-form textarea,
.page-venue-settings .venue-settings-form select,
.page-venue-settings .hours-edit-grid input,
.page-venue-settings .hours-edit-grid select,
.page-venue-media .venue-admin-input,
.page-venue-media .venue-media-upload input[type="text"],
.page-venue-media .venue-media-upload input[type="file"] {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid var(--input-border);
    border-radius: 10px;
    padding: 9px 12px;
    color: var(--text);
    background: var(--input-bg);
    font: inherit;
    font-weight: 400;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.page-venue-settings .venue-settings-form textarea {
    min-height: 96px;
    resize: vertical;
}
.page-venue-settings .venue-settings-input:focus,
.page-venue-settings .venue-settings-form input:not([type="checkbox"]):focus,
.page-venue-settings .venue-settings-form textarea:focus,
.page-venue-settings .venue-settings-form select:focus,
.page-venue-media .venue-admin-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
}
.page-venue-settings .venue-settings-form .errorlist,
.page-venue-settings .venue-settings-form ul.errorlist {
    margin: 4px 0 0;
    padding: 0;
    list-style: none;
    font-size: 12px;
    font-weight: 500;
    color: var(--danger);
}
.page-venue-settings .flags-edit {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 18px;
    margin: 4px 0 14px;
}
.page-venue-settings .flag-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--text);
    cursor: pointer;
}
.page-venue-settings .flag-check input {
    width: 18px;
    height: 18px;
    accent-color: var(--accent);
}
.page-venue-settings .field-help {
    font-weight: 400;
    font-size: 11px;
    color: var(--muted);
}
.page-venue-settings #venueHubEstablishmentSwitch,
.page-venue-media #venueHubEstablishmentSwitch {
    min-width: 200px;
}

.page-venue-dashboard .venue-sub-banner {
    border-radius: 20px;
    border-color: rgba(217, 119, 6, 0.16);
    background: linear-gradient(135deg, rgba(217, 119, 6, 0.05), rgba(255, 255, 255, 0.97));
}
.page-venue-dashboard .venue-left-tab.is-active {
    border-color: rgba(217, 119, 6, 0.38);
    background: linear-gradient(180deg, #fafbff 0%, #ffffff 100%);
    box-shadow: 0 4px 18px rgba(217, 119, 6, 0.08);
}

/* ══════════════════════════════════════════
   VENUE TABLES PAGE v2
══════════════════════════════════════════ */

/* Main layout — full-height two-column */
main.container.vt-main {
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.vt2-wrap {
    display: flex;
    flex: 1;
    min-height: 0;
    height: calc(100vh - 58px);
}
.vt2-board-col {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    border-right: 1px solid var(--line);
}
.vt2-board-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    border-bottom: 1px solid var(--line);
    background: var(--surface);
    flex-shrink: 0;
}
.vt2-back {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
    color: var(--link);
    text-decoration: none;
    padding: 5px 8px;
    border-radius: 7px;
    border: 1px solid var(--line);
    transition: background 0.15s;
    white-space: nowrap;
}
.vt2-back:hover { background: var(--bg); }
.vt2-board-title {
    font-size: 15px;
    margin: 0;
    font-weight: 700;
}
.vt2-board-hint {
    margin-left: auto;
    font-size: 12px;
    color: var(--muted);
}

/* Board canvas */
.vt2-board {
    flex: 1;
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(to right, rgba(0,0,0,0.07) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(0,0,0,0.07) 1px, transparent 1px),
        linear-gradient(180deg, #eceef4 0%, #e2e6ee 100%);
    background-size: 40px 40px, 40px 40px, auto;
    cursor: default;
}
.vt2-board-empty {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--muted);
    font-size: 14px;
    opacity: 0.5;
    pointer-events: none;
}

/* Table elements on board */
.vt2-table {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding: 0 2px 5px;
    cursor: grab;
    border-radius: 8px;
    border: 2px solid transparent;
    transition: border-color 0.15s, filter 0.15s;
    overflow: visible;
    user-select: none;
}
.vt2-table:active { cursor: grabbing; }
.vt2-table:hover { filter: brightness(1.06) drop-shadow(0 2px 6px rgba(100,50,0,0.2)); }
.vt2-table.is-selected {
    border-color: #d97706 !important;
    filter: drop-shadow(0 0 8px rgba(217,119,6,0.45));
    border-radius: 8px;
}
.board-table-svg {
    position: absolute;
    inset: 0 0 16px;
    width: 100%;
    height: calc(100% - 16px);
    pointer-events: none;
    overflow: visible;
}
.vt2-table-label {
    position: relative;
    z-index: 1;
    font-size: 9px;
    font-weight: 800;
    color: #451a03;
    background: rgba(255,237,213,0.92);
    border: 1px solid rgba(180,83,9,0.2);
    padding: 1px 5px;
    border-radius: 3px;
    max-width: 96%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.5;
    pointer-events: none;
}

/* Resize handles — 4 corners */
.vt2-rh {
    position: absolute;
    width: 14px;
    height: 14px;
    background: #d97706;
    border: 2px solid #fff;
    border-radius: 3px;
    z-index: 10;
    opacity: 0;
    transition: opacity 0.15s;
}
.vt2-table:hover .vt2-rh,
.vt2-table.is-selected .vt2-rh { opacity: 1; }
.vt2-rh-nw { top: -5px;  left: -5px;  cursor: nw-resize; }
.vt2-rh-ne { top: -5px;  right: -5px; cursor: ne-resize; }
.vt2-rh-sw { bottom: -5px; left: -5px;  cursor: sw-resize; }
.vt2-rh-se { bottom: -5px; right: -5px; cursor: se-resize; }

/* ── Right panel ── */
.vt2-panel {
    width: 320px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    background: var(--surface);
    overflow-y: auto;
}
.vt2-panel-section {
    padding: 16px;
    flex: 1;
}
.vt2-panel-head {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 700;
    color: var(--ink);
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--line);
}
.vt2-deselect {
    width: 28px;
    height: 28px;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--muted);
    flex-shrink: 0;
    transition: background 0.15s, color 0.15s;
}
.vt2-deselect:hover { background: var(--bg); color: var(--ink); }
.vt2-shape-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    margin-bottom: 6px;
}
.vt2-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin: 12px 0;
}
.vt2-field {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.vt2-field--half { grid-column: auto; }
.vt2-field--full { grid-column: 1 / -1; }
.vt2-field label {
    font-size: 11px;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.vt2-field input[type="text"],
.vt2-field input[type="number"],
.vt2-field input:not([type="checkbox"]) {
    padding: 8px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    font-size: 14px;
    background: var(--bg);
    color: var(--ink);
    width: 100%;
    box-sizing: border-box;
    transition: border-color 0.15s;
}
.vt2-field input:focus {
    outline: none;
    border-color: var(--link);
    box-shadow: 0 0 0 2px rgba(217,119,6,0.12);
}
.vt2-check-label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text);
}
.vt2-req { color: #d97706; }
.vt2-submit {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    margin-top: 4px;
}

/* Delete zone */
.vt2-delete-zone {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--line);
}
.vt2-delete-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background: transparent;
    border: 1px solid rgba(220,38,38,0.3);
    color: #dc2626;
    border-radius: 8px;
    padding: 7px 12px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
    width: 100%;
    justify-content: center;
}
.vt2-delete-btn:hover { background: rgba(220,38,38,0.06); border-color: rgba(220,38,38,0.5); }
.vt2-delete-confirm {
    background: rgba(220,38,38,0.05);
    border: 1px solid rgba(220,38,38,0.25);
    border-radius: 10px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.vt2-delete-confirm__q {
    font-size: 13px;
    color: #b91c1c;
    font-weight: 600;
    margin: 0;
}
.vt2-delete-confirm__btns {
    display: flex;
    gap: 8px;
}
.vt2-delete-yes {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 8px 14px;
    background: #dc2626;
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.15s;
}
.vt2-delete-yes:hover:not(:disabled) { background: #b91c1c; }
.vt2-delete-yes:disabled { opacity: 0.6; cursor: not-allowed; }
.vt2-delete-no {
    padding: 8px 14px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    color: var(--muted);
    transition: background 0.15s;
}
.vt2-delete-no:hover { background: var(--bg); color: var(--ink); }
@keyframes spin { to { transform: rotate(360deg); } }
.spin { animation: spin 0.8s linear infinite; transform-origin: center; }

/* Messages */
.vt2-msg { font-size: 12px; margin-top: 8px; }
.vt2-msg--ok  { color: #16a34a; }
.vt2-msg--err { color: #dc2626; }

/* Tip footer */
.vt2-tip {
    padding: 12px 16px;
    border-top: 1px solid var(--line);
    font-size: 12px;
    color: var(--muted);
    display: flex;
    align-items: flex-start;
    gap: 7px;
    flex-shrink: 0;
    background: var(--bg);
}
.vt2-tip svg { flex-shrink: 0; margin-top: 1px; }

@media (max-width: 768px) {
    .vt2-wrap { flex-direction: column; height: auto; }
    .vt2-board { min-height: 380px; height: 380px; }
    .vt2-panel { width: 100%; border-top: 1px solid var(--line); }
}

/* old vt- classes still used by venue_table_edit.html */
.vt-page {
    padding: 0 0 40px;
}
.vt-breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 12px 0 16px;
    font-size: 13px;
    color: var(--muted);
}
.vt-breadcrumb__link {
    display: flex;
    align-items: center;
    gap: 5px;
    color: var(--link);
    text-decoration: none;
    font-weight: 600;
}
.vt-breadcrumb__link:hover { text-decoration: underline; }
.vt-breadcrumb__sep { color: var(--muted); opacity: 0.4; }
.vt-breadcrumb__current { color: var(--text); font-weight: 600; }
.vt-layout {
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: 20px;
    align-items: start;
}
@media (max-width: 900px) {
    .vt-layout { grid-template-columns: 1fr; }
    .vt-right { order: -1; }
}

/* ── Форма добавления ── */
.vt-add-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
    margin-bottom: 16px;
}
.vt-add-card__header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 18px 12px;
    border-bottom: 1px solid var(--line);
    background: linear-gradient(135deg, rgba(217,119,6,0.04), transparent);
    color: var(--link);
}
.vt-add-card__header h3 {
    margin: 0;
    font-size: 15px;
    color: var(--ink);
}
.vt-form {
    padding: 16px 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.vt-form__shape-label {
    font-size: 12px;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 6px;
}
.vt-form__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.vt-form__grid--4 {
    grid-template-columns: repeat(4, 1fr);
}
.vt-form__full {
    grid-column: 1 / -1;
}
.vt-form__coords {
    border: 1px solid var(--line);
    border-radius: 10px;
    overflow: hidden;
}
.vt-form__coords summary {
    padding: 8px 12px;
    cursor: pointer;
    font-size: 13px;
    color: var(--muted);
    user-select: none;
    background: var(--bg);
}
.vt-form__coords[open] summary { border-bottom: 1px solid var(--line); }
.vt-form__coords > .vt-form__grid { padding: 12px; }
.vt-form__coords .muted { padding: 0 12px 10px; }
.vt-form__active-row label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    cursor: pointer;
}
.vt-form__submit {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
}

/* ── Список столов ── */
.vt-list__title {
    font-size: 15px;
    margin: 0 0 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.vt-list__count {
    font-size: 11px;
    font-weight: 700;
    background: rgba(217,119,6,0.1);
    color: var(--link);
    border-radius: 999px;
    padding: 2px 8px;
}
.vt-table-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 14px;
    margin-bottom: 8px;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.vt-table-card:hover {
    border-color: rgba(217,119,6,0.3);
    box-shadow: 0 2px 12px rgba(217,119,6,0.1);
}
.vt-table-card--inactive {
    opacity: 0.5;
}
.vt-table-card__icon {
    width: 52px;
    height: 38px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg);
    border-radius: 8px;
    border: 1px solid rgba(146,98,30,0.15);
}
.vt-table-card__icon svg { width: 100%; height: 100%; }
.vt-table-card__info {
    flex: 1;
    min-width: 0;
}
.vt-table-card__name {
    font-size: 14px;
    font-weight: 700;
    color: var(--ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.vt-table-card__meta {
    font-size: 12px;
    color: var(--muted);
    display: flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
    margin-top: 2px;
}
.vt-table-card__dot { opacity: 0.4; }
.vt-table-card__badge {
    background: rgba(239,68,68,0.1);
    color: #dc2626;
    font-size: 10px;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.vt-table-card__photo {
    width: 44px;
    height: 44px;
    border-radius: 8px;
    object-fit: cover;
    border: 1px solid var(--line);
    flex-shrink: 0;
}
.vt-table-card__actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

/* ── Борд схемы ── */
.vt-board-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
    position: sticky;
    top: 80px;
}
.vt-board-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 14px 18px 12px;
    border-bottom: 1px solid var(--line);
}
.vt-board-card__header h3 { margin: 0; font-size: 15px; }
.vt-board-card__hint { font-size: 12px; }
.vt-board-card .table-board {
    border-radius: 0 0 18px 18px;
    min-height: 480px;
    border: none;
    border-top: none;
}
.vt-board-empty {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--muted);
    font-size: 13px;
    text-align: center;
}

/* ── Edit panel ── */
.vt-edit-panel__header {
    background: linear-gradient(135deg, rgba(59,130,246,0.06), transparent);
    color: #1d4ed8;
}
.vt-edit-back {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: transparent;
    cursor: pointer;
    color: var(--muted);
    flex-shrink: 0;
    transition: background 0.15s, color 0.15s;
}
.vt-edit-back:hover { background: var(--bg); color: var(--ink); }
.vt-form__btns {
    display: flex;
    gap: 8px;
    align-items: center;
}
.vt-form__btns .vt-form__submit { flex: 1; }

/* ── Selected state ── */
.board-table.is-selected {
    border-color: #3b82f6 !important;
    background: rgba(59,130,246,0.08) !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,0.2) !important;
}
.vt-table-card.is-selected {
    border-color: rgba(59,130,246,0.4);
    background: rgba(59,130,246,0.04);
}

/* ── Guide block ── */
.vt-guide {
    background: linear-gradient(135deg, #fffbf0, #fff8e6);
    border: 1px solid rgba(217,119,6,0.2);
    border-radius: 14px;
    padding: 14px 16px;
    margin-bottom: 12px;
    overflow: hidden;
}
.vt-guide__header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}
.vt-guide__icon { color: #d97706; flex-shrink: 0; }
.vt-guide__title {
    font-size: 13px;
    font-weight: 700;
    color: #92400e;
    flex: 1;
}
.vt-guide__close {
    background: none;
    border: none;
    cursor: pointer;
    color: #b45309;
    opacity: 0.6;
    padding: 2px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.15s;
}
.vt-guide__close:hover { opacity: 1; }
.vt-guide__steps {
    display: flex;
    flex-direction: column;
    gap: 7px;
}
.vt-guide__step {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    font-size: 12.5px;
    color: #78350f;
    line-height: 1.5;
}
.vt-guide__num {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    background: rgba(217,119,6,0.15);
    color: #b45309;
    border-radius: 50%;
    font-size: 11px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 1px;
}
.page-venue-dashboard .table-board {
    background:
        linear-gradient(to right, rgba(0, 0, 0, 0.09) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(0, 0, 0, 0.09) 1px, transparent 1px),
        linear-gradient(180deg, #eceef4 0%, #e2e6ee 100%);
    background-size: 40px 40px, 40px 40px, auto;
    border-color: rgba(0, 0, 0, 0.08);
}

/* Orbit: касания на телефонах */
@media (max-width: 900px) {
    .guest-search-trigger,
    .guest-search-submit,
    .places-search-input,
    .places-search .guest-search-submit {
        min-height: var(--tap-min);
    }
    .venue-left-tab {
        min-height: var(--tap-min);
        padding: 12px 16px;
    }
    .venue-admin-select {
        min-height: 48px;
        font-size: 16px;
    }
    .topbar-burger {
        min-width: var(--tap-min);
        min-height: var(--tap-min);
    }
    .board-table {
        min-width: 56px;
        min-height: 52px;
    }
}

/* =====================================================
   AUTH PAGE V2 — Тёмный фон + белая карточка
   ===================================================== */
body.auth-page {
    background: #0d0803;
    background-image:
        radial-gradient(ellipse 70% 55% at 50% -5%, rgba(217, 119, 6, 0.20), transparent 55%),
        radial-gradient(ellipse 40% 35% at 5% 100%, rgba(180, 83, 9, 0.10), transparent 55%);
    min-height: 100svh;
    display: flex;
    flex-direction: column;
}

body.auth-page .topbar {
    background: rgba(13, 8, 3, 0.92) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
}

body.auth-page main.container {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 100%;
    width: 100%;
    margin: 0;
    padding: 24px 16px 48px;
    box-sizing: border-box;
}

body.auth-page .site-footer { display: none; }

/* ——— Карточка ——— */
.auth-card {
    width: 100%;
    max-width: 400px;
    background: #ffffff;
    border-radius: 20px;
    padding: 36px 32px 28px;
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.04),
        0 8px 24px rgba(0, 0, 0, 0.28),
        0 40px 80px rgba(0, 0, 0, 0.38);
}

.auth-card__logo {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-bottom: 24px;
    font-family: var(--font-display);
    font-size: 17px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -0.02em;
    text-decoration: none;
}

.auth-card__logo-mark {
    width: 9px;
    height: 9px;
    border-radius: 3px;
    background: var(--accent);
    display: block;
    flex-shrink: 0;
}

.auth-card__title {
    margin: 0 0 5px;
    font-family: var(--font-display);
    font-size: clamp(1.375rem, 4vw, 1.625rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    color: var(--ink);
}

.auth-card__lead {
    margin: 0 0 22px;
    font-size: 0.9375rem;
    color: var(--muted);
    line-height: 1.5;
}

/* ——— Переключатель гость/владелец ——— */
.auth-switcher {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 4px;
    background: var(--bg-soft);
    border-radius: 12px;
    margin-bottom: 22px;
    gap: 3px;
}

.auth-switcher__btn {
    display: block;
    text-align: center;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--muted);
    text-decoration: none;
    border-radius: 9px;
    padding: 10px 8px;
    transition: all 0.18s ease;
    line-height: 1.3;
}

.auth-switcher__btn.is-active {
    background: #ffffff;
    color: var(--ink);
    font-weight: 600;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.10);
}

/* ——— Поля формы ——— */
.auth-field { margin-bottom: 13px; }

.auth-label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
    margin-bottom: 5px;
    letter-spacing: -0.005em;
}

.auth-card .auth-field input,
.auth-card .auth-field textarea,
.auth-card .auth-field select {
    width: 100%;
    height: 48px;
    border-radius: 10px;
    border: 1.5px solid var(--line-strong);
    background: var(--bg);
    color: var(--text);
    padding: 0 14px;
    font-size: 16px; /* iOS: предотвращает zoom */
    font-family: var(--font-sans);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    box-sizing: border-box;
    display: block;
    -webkit-appearance: none;
}

.auth-card .auth-field input:focus,
.auth-card .auth-field textarea:focus,
.auth-card .auth-field select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(217, 119, 6, 0.13);
    background: #fff;
}

.auth-card .auth-field textarea {
    height: auto;
    min-height: 78px;
    padding: 12px 14px;
    resize: vertical;
}

.auth-field-error {
    margin: 5px 0 0;
    font-size: 12px;
    color: var(--danger);
    line-height: 1.4;
}

.auth-error-box {
    background: var(--danger-soft);
    border: 1px solid rgba(220, 38, 38, 0.18);
    border-radius: 10px;
    padding: 11px 14px;
    font-size: 13.5px;
    color: var(--danger);
    margin-bottom: 16px;
    line-height: 1.4;
}

.auth-fields-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.auth-submit {
    display: block;
    width: 100%;
    height: 52px;
    border-radius: 13px;
    font-size: 15.5px;
    font-weight: 600;
    color: #18130a;
    background: var(--accent);
    border: none;
    cursor: pointer;
    transition: filter 0.15s ease, box-shadow 0.15s ease, transform 0.1s ease;
    margin-top: 18px;
    font-family: var(--font-sans);
    letter-spacing: -0.01em;
    box-shadow: 0 4px 16px rgba(217, 119, 6, 0.35);
    -webkit-appearance: none;
}

.auth-submit:hover {
    filter: brightness(1.07);
    box-shadow: 0 6px 20px rgba(217, 119, 6, 0.45);
}

.auth-submit:active { transform: scale(0.99); filter: brightness(0.97); }

.auth-card__foot {
    margin: 18px 0 0;
    font-size: 14px;
    color: var(--muted);
    text-align: center;
    line-height: 1.55;
}

.auth-card__foot a {
    color: var(--link);
    font-weight: 500;
    text-decoration: none;
}
.auth-card__foot a:hover { color: var(--link-hover); text-decoration: underline; }

@media (max-width: 440px) {
    .auth-fields-grid { grid-template-columns: 1fr; gap: 0; }
}

/* ——— Мобильная авторизация: как нативный экран приложения ———
   Шапка убрана, карточка на весь экран, контент центрируется и
   не листается при простом входе. Клавиатура не перекрывает поля
   за счёт interactive-widget=resizes-content + 100dvh. */
@media (max-width: 640px) {
    body.auth-page .topbar { display: none !important; }
    body.auth-page {
        background:
            radial-gradient(ellipse 90% 50% at 50% 0%, rgba(217, 119, 6, 0.22), transparent 60%),
            radial-gradient(ellipse 60% 40% at 0% 100%, rgba(180, 83, 9, 0.12), transparent 55%),
            #0d0803;
    }
    body.auth-page main.container {
        min-height: 100dvh;
        align-items: stretch;
        justify-content: flex-start;
        padding:
            calc(env(safe-area-inset-top, 0px) + 14px)
            14px
            calc(env(safe-area-inset-bottom, 0px) + 14px);
    }
    .auth-card {
        max-width: 100%;
        margin: auto;
        padding: 30px 22px 24px;
        border-radius: 24px;
        box-shadow:
            0 0 0 1px rgba(255, 255, 255, 0.05),
            0 20px 60px rgba(0, 0, 0, 0.45);
    }
    .auth-card__logo { margin-bottom: 20px; }
    .auth-card__lead { margin-bottom: 20px; }
    /* Крупнее тач-цели */
    .auth-card .auth-field input,
    .auth-card .auth-field select {
        height: 52px;
        border-radius: 13px;
    }
    .auth-submit { height: 54px; margin-top: 20px; }
}

/* Совсем узкие экраны / низкая высота — компактнее, чтобы вход помещался */
@media (max-width: 640px) and (max-height: 720px) {
    .auth-card { padding: 22px 20px 20px; }
    .auth-card__logo { margin-bottom: 14px; }
    .auth-card__title { font-size: 1.4rem; }
    .auth-card__lead { margin-bottom: 16px; font-size: 0.9rem; }
    .auth-field { margin-bottom: 11px; }
    .auth-submit { margin-top: 14px; }
    .auth-card__foot { margin-top: 14px; }
}

/* =====================================================
   COOKIE CONSENT BANNER
   ===================================================== */
.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 9000;
    padding: 12px 20px calc(12px + env(safe-area-inset-bottom, 0px));
    background: rgba(14, 8, 0, 0.97);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid rgba(255, 255, 255, 0.09);
    transform: translateY(100%);
    transition: transform 0.34s cubic-bezier(0.34, 1.2, 0.64, 1);
}

.cookie-banner.is-visible {
    transform: translateY(0);
}

/* На мобиле — поднять над bottom-nav */
@media (max-width: 900px) {
    body:not(.landing-page):not(.auth-page) .cookie-banner {
        bottom: calc(60px + env(safe-area-inset-bottom, 0px));
        padding-bottom: 12px;
    }
}

.cookie-banner__inner {
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.cookie-banner__text {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.65);
    line-height: 1.5;
    flex: 1 1 300px;
}

.cookie-banner__text strong {
    color: rgba(255, 255, 255, 0.88);
    font-weight: 600;
}

.cookie-banner__link {
    color: var(--accent) !important;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.cookie-banner__actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

.cookie-banner__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 36px;
    padding: 0 16px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: filter 0.15s ease, opacity 0.15s ease;
    border: none;
}

.cookie-banner__btn--accept {
    background: linear-gradient(145deg, #f59e0b, #d97706);
    color: #18130a;
    box-shadow: 0 2px 10px rgba(217, 119, 6, 0.4);
}

.cookie-banner__btn--accept:hover { filter: brightness(1.08); }

.cookie-banner__btn--more {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.14);
}

.cookie-banner__btn--more:hover {
    background: rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.9);
}

/* =====================================================
   ССЫЛКА В НИЖНЕЙ СТРОКЕ ФУТЕРА
   ===================================================== */
.site-footer-legal__link {
    color: rgba(255, 255, 255, 0.35) !important;
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: color 0.15s ease;
}
.site-footer-legal__link:hover {
    color: rgba(255, 255, 255, 0.65) !important;
}

/* =====================================================
   СТРАНИЦА ПОЛИТИКИ КОНФИДЕНЦИАЛЬНОСТИ
   ===================================================== */
.legal-page {
    min-height: 60vh;
}

.legal-page__inner {
    max-width: 760px;
    margin: 0 auto;
    padding: 0 0 48px;
}

.legal-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--muted);
    margin-bottom: 24px;
}

.legal-breadcrumb a {
    color: var(--muted);
    text-decoration: none;
    transition: color 0.15s ease;
}

.legal-breadcrumb a:hover { color: var(--accent); }
.legal-breadcrumb span:not([aria-hidden]) { color: var(--ink); font-weight: 500; }

.legal-page__title {
    font-size: clamp(26px, 4vw, 36px);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--ink);
    margin: 0 0 6px;
}

.legal-page__updated {
    margin: 0 0 32px;
    font-size: 13px;
    color: var(--muted);
}

.legal-content {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.legal-content section h2 {
    font-size: 18px;
    font-weight: 700;
    color: var(--ink);
    margin: 0 0 10px;
    letter-spacing: -0.01em;
}

.legal-content section h3 {
    font-size: 15px;
    font-weight: 600;
    color: var(--text);
    margin: 12px 0 6px;
}

.legal-content p, .legal-content li {
    font-size: 15px;
    line-height: 1.7;
    color: var(--text);
}

.legal-content ul {
    margin: 0;
    padding-left: 20px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.legal-content a {
    color: var(--link);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.legal-content a:hover { color: var(--link-hover); }

/* ——— Share кнопка на профиле заведения ——— */
.est-share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .18s, border-color .18s;
}
.est-share-btn:hover {
    background: rgba(217, 119, 6, 0.35);
    border-color: rgba(217, 119, 6, 0.7);
}

/* ——— Страница спасибо после брони ——— */
.booking-success {
    max-width: 460px;
    margin: 64px auto;
    padding: 40px 32px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    text-align: center;
    box-shadow: var(--shadow-card);
}
.booking-success__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: rgba(22, 163, 74, .08);
    border: 1.5px solid rgba(22, 163, 74, .25);
    color: #16a34a;
    margin: 0 auto 20px;
}
.booking-success__title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 10px;
}
.booking-success__ref {
    font-size: 0.82rem;
    margin: -4px 0 12px;
    letter-spacing: 0.02em;
}
.booking-success__lead {
    font-size: .97rem;
    color: var(--text-muted);
    line-height: 1.55;
    margin: 0 0 6px;
}
.booking-success__table {
    font-size: .88rem;
    color: var(--amber);
    font-weight: 600;
    margin: 0 0 24px;
}
.booking-success__share {
    margin: 24px 0;
    padding: 16px;
    background: var(--bg-soft);
    border-radius: var(--radius);
}
.booking-success__share-text {
    font-size: .85rem;
    color: var(--text-muted);
    margin: 0 0 10px;
}
.booking-success__share-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border-radius: 99px;
    border: 1.5px solid var(--amber);
    background: transparent;
    color: var(--amber-dark);
    font-weight: 600;
    font-size: .88rem;
    cursor: pointer;
    transition: background .16s, color .16s;
}
.booking-success__share-btn:hover {
    background: var(--amber);
    color: #fff;
}
.booking-success__actions {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 8px;
}
@media (max-width: 500px) {
    .booking-success {
        margin: 24px 16px;
        padding: 28px 18px;
    }
    .booking-success__actions { flex-direction: column; }
}

/* ——— Отмена брони в карточке ближайшей брони ——— */
.gd-booking-card__actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.gd-booking-card__cancel-form {
    margin: 0;
    padding: 0;
    display: inline;
}
.gd-booking-card__cancel {
    padding: 6px 12px;
    border-radius: 99px;
    border: 1px solid rgba(220, 38, 38, .35);
    background: transparent;
    color: #dc2626;
    font-size: .8rem;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background .16s, color .16s;
}
.gd-booking-card__cancel:hover {
    background: rgba(220, 38, 38, .08);
}

/* ── Venue table edit page layout ── */
.vt-edit-layout {
    display: grid;
    grid-template-columns: 420px 1fr;
    gap: 20px;
    align-items: start;
}
@media (max-width: 900px) {
    .vt-edit-layout { grid-template-columns: 1fr; }
}
.vt-edit-header-icon {
    width: 44px;
    height: 34px;
    flex-shrink: 0;
}
.vt-edit-header-icon svg { width: 100%; height: 100%; }
.vt-edit-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.vt-edit-preview { position: sticky; top: 80px; }
.vt-preview-box {
    padding: 32px 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 200px;
    background:
        linear-gradient(to right, rgba(0,0,0,0.06) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(0,0,0,0.06) 1px, transparent 1px),
        linear-gradient(180deg, #eceef4 0%, #e2e6ee 100%);
    background-size: 40px 40px, 40px 40px, auto;
}
.vt-preview-table {
    width: 130px;
    height: 90px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding-bottom: 8px;
    border: 1.5px solid rgba(217,119,6,0.28);
    border-radius: 10px;
    background: rgba(255,255,255,0.06);
    color: #d97706;
    transition: all 0.2s;
}
.vt-preview-svg {
    position: absolute;
    inset: 6px 4px 22px;
    width: calc(100% - 8px);
    height: calc(100% - 28px);
}
.vt-preview-label {
    position: relative;
    z-index: 1;
    font-size: 11px;
    font-weight: 800;
    color: #3d2600;
    background: rgba(255,255,255,0.82);
    padding: 1px 6px;
    border-radius: 4px;
    max-width: 90%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.vt-preview-meta {
    padding: 14px 18px;
    border-top: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.vt-preview-meta__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 13px;
}
.vt-preview-meta__key { color: var(--muted); }
.vt-preview-meta__val { font-weight: 600; color: var(--ink); }

/* Venue staff roles — operational dashboards */
.venue-left-tabs--solo { border-bottom: 1px solid var(--line); padding-bottom: 8px; }
.venue-page-wrap { padding: 24px; max-width: 1200px; margin: 0 auto; }
.venue-page-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}
.venue-page-head h1 { margin: 0 0 4px; font-size: 1.6rem; }
.venue-audit-filters {
    background: #f7f3ec;
    border: 1px solid var(--line, #e6dfd2);
    border-radius: 14px;
    padding: 14px 16px;
    margin-bottom: 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.venue-audit-actions {
    flex-wrap: wrap;
    gap: 6px;
}
.venue-audit-action-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: white;
    border: 1px solid var(--line, #e6dfd2);
    border-radius: 999px;
    padding: 3px 10px;
    font-size: 0.78rem;
    cursor: pointer;
}
.venue-audit-action-chip input { margin: 0; }
.venue-audit-action-chip:has(input:checked) {
    background: #2d6cdf;
    color: white;
    border-color: #2d6cdf;
}
.venue-audit-table { overflow-x: auto; }
.venue-audit-table table {
    width: 100%;
    border-collapse: collapse;
    background: white;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.venue-audit-table th,
.venue-audit-table td {
    text-align: left;
    padding: 10px 14px;
    border-bottom: 1px solid var(--line, #efe9dc);
    vertical-align: top;
    font-size: 0.88rem;
}
.venue-audit-table th { background: #fbf6ed; font-weight: 600; }
.venue-audit-table tbody tr:last-child td { border-bottom: none; }
.venue-audit-table pre {
    margin: 6px 0 0;
    font-size: 0.78rem;
    background: #f7f3ec;
    padding: 6px 8px;
    border-radius: 8px;
    overflow-x: auto;
    max-width: 460px;
}
.venue-audit-chip {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    background: #efe9dc;
    color: #4b3a18;
    font-size: 0.75rem;
}
.venue-audit-chip--role_change { background: #e6e1ff; color: #2c1d8d; }
.venue-audit-chip--staff_deactivate,
.venue-audit-chip--invite_revoke { background: #f3dada; color: #832a2a; }
.venue-audit-chip--invite_create,
.venue-audit-chip--invite_accept,
.venue-audit-chip--staff_create { background: #d9efd9; color: #1f5a1f; }
.venue-audit-chip--clock_open { background: #def3e1; color: #1d6b3a; }
.venue-audit-chip--clock_close { background: #fde3c8; color: #7a3b13; }
.venue-audit-chip--table_assign,
.venue-audit-chip--table_release { background: #e1ecf8; color: #234a7d; }
.venue-audit-pagination {
    display: flex;
    gap: 12px;
    align-items: center;
    justify-content: center;
    padding: 14px 0;
}
.venue-staff-clock {
    display: inline-block;
    margin-left: 6px;
    padding: 1px 8px;
    border-radius: 999px;
    font-size: 0.72rem;
    line-height: 1.4;
}
.venue-staff-clock--on { background: #def3e1; color: #1d6b3a; }
.venue-staff-clock--off { background: #f0e1e1; color: #843838; }
.board-table-release {
    position: absolute;
    bottom: 4px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 0.65rem;
    color: #b04a0a;
    background: rgba(255, 255, 255, 0.85);
    padding: 1px 6px;
    border-radius: 6px;
    pointer-events: none;
}
.vt2-table.has-waiter::after {
    content: "";
    position: absolute;
    top: 4px;
    right: 4px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #2d8a4e;
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.95);
    pointer-events: none;
}
.venue-shift-banner {
  margin: 12px 0;
  padding: 12px 16px;
  border-radius: 12px;
  background: #fff8e6;
  border: 1px solid #f0d78a;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.venue-shift-banner--active {
  background: #ecfdf3;
  border-color: #a7e3c2;
}
.venue-shift-banner__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.venue-shift-banner__text strong { font-size: 14px; }
.venue-shift-banner__text span { font-size: 12.5px; color: var(--muted, #6b6256); }
.venue-shift-banner .btn { flex: 0 0 auto; }
@media (max-width: 560px) {
  .venue-shift-banner { flex-wrap: nowrap; }
  .venue-shift-banner .btn { white-space: nowrap; }
}
.venue-notify-strip {
  position: relative;
  margin: 8px 0;
  padding: 10px 14px;
  border-radius: 8px;
  background: #eef6ff;
  border: 1px solid #c5ddf5;
  font-size: 13px;
}
.venue-notify-sound {
  position: absolute;
  top: 6px;
  right: 8px;
  width: 30px;
  height: 30px;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.7);
  cursor: pointer;
  font-size: 15px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease, transform 0.1s ease;
}
.venue-notify-sound:hover { background: #fff; }
.venue-notify-sound:active { transform: scale(0.92); }
.venue-notify-strip > div { padding-right: 36px; }
.venue-shift-banner:empty,
.venue-notify-strip:empty {
  display: none !important;
}
.venue-shift-banner[hidden],
.venue-notify-strip[hidden] {
  display: none !important;
}
.venue-staff-app__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.venue-staff-app__head > div:first-child { display: flex; align-items: baseline; gap: 12px; }
.venue-staff-app__head-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.venue-staff-app__role {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}

/* ─── Состояния столов для официанта ─── */
.board-table.is-mine {
  outline: 2px solid #2d8a4e;
  outline-offset: -2px;
  box-shadow: 0 0 0 3px rgba(45, 138, 78, 0.12);
}
.board-table.is-free {
  outline: 2px dashed #c9a227;
  outline-offset: -2px;
  cursor: pointer;
}
.board-table.is-other {
  opacity: 0.45;
  pointer-events: none;
  filter: grayscale(60%);
}
.board-table.is-selected {
  outline: 3px solid var(--link, #d97706);
  outline-offset: -2px;
  box-shadow: 0 0 0 4px rgba(217, 119, 6, 0.18);
}
.board-table--readonly { cursor: pointer; }
.board-table-claim,
.board-table-release {
  display: block;
  font-size: 10px;
  font-weight: 700;
  position: absolute;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%);
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.92);
  pointer-events: none;
}
.board-table-claim { color: #9a7b1a; }
.board-table-release { color: #2d8a4e; }

/* ─── Layout: waiter dashboard ─── */
.venue-waiter-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 16px;
  align-items: stretch;
}
.venue-waiter-board-wrap { display: flex; flex-direction: column; gap: 12px; min-width: 0; }
.venue-waiter-board-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.venue-waiter-board-head h3 { margin: 0; }
.venue-waiter-legend { display: flex; gap: 12px; flex-wrap: wrap; font-size: 12px; margin: 0; }
.venue-waiter-legend__chip {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 3px;
  margin-right: 4px;
  vertical-align: -1px;
}
.venue-waiter-legend__chip--mine { background: #2d8a4e; }
.venue-waiter-legend__chip--free { background: #c9a227; }
.venue-waiter-legend__chip--other { background: #aaa; opacity: 0.6; }

.venue-waiter-board .table-board {
  width: 100%;
  min-height: min(60vh, 520px);
  aspect-ratio: 16 / 10;
}
.venue-waiter-side__head { display: flex; align-items: baseline; gap: 8px; margin-bottom: 10px; }
.venue-waiter-side__head h2 { margin: 0; font-size: 16px; }

@media (max-width: 1000px) {
  .venue-waiter-shell { grid-template-columns: 1fr; }
  .venue-waiter-board .table-board {
    min-height: 0;
    /* Единый холст 16/10 — как в редакторе и остальных схемах */
    aspect-ratio: 16 / 10;
  }
  .board-table-claim, .board-table-release {
    font-size: 9px;
    padding: 1px 4px;
    bottom: 2px;
  }
}
@media (max-width: 640px) {
  .venue-waiter-board .table-board { aspect-ratio: 16 / 10; min-height: 0; }
  .board-table-title { font-size: 11px; padding: 0 2px; }
  /* На узких экранах текст «Взять/Отпустить» прячем — статус показывает обводка */
  .board-table-claim, .board-table-release { display: none; }
  .board-table.is-free::after,
  .board-table.is-mine::after {
    content: "";
    position: absolute;
    top: 4px;
    right: 4px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
  }
  .board-table.is-free::after { background: #c9a227; }
  .board-table.is-mine::after { background: #2d8a4e; }
}

/* ─── Staff dashboards (hostess / waiter) — тот же shell, что у менеджера ─── */
.page-venue-hostess main.container.container--guest-wide,
.page-venue-waiter main.container.container--guest-wide {
    max-width: 1680px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.venue-staff-shell.venue-admin-shell {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.12fr);
}
.venue-staff-board-hint {
    font-size: 13px;
    margin: 0 0 8px;
}
.venue-booking-card__actions {
    margin-top: 10px;
}
.venue-booking-card__actions .btn {
    pointer-events: auto;
}
.board-table.board-table--readonly.is-selected,
.board-table.is-selected {
    border-color: rgba(217, 119, 6, 0.55) !important;
    box-shadow: 0 0 0 2px rgba(217, 119, 6, 0.25);
}
.venue-hostess-table-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  background: rgba(217, 119, 6, 0.12);
  color: #8a4b06;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 600;
}
.venue-hostess-table-pill .btn-link {
  background: none;
  border: 0;
  color: inherit;
  cursor: pointer;
  font-weight: 700;
  padding: 0 4px;
}
@media (max-width: 900px) {
  .page-venue-hostess .venue-hostess-app,
  .page-venue-waiter #venueWaiterApp,
  .page-venue-focused .venue-focused-page {
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  }
  /* Телефон/планшет: список броней и схема друг под другом, на всю ширину */
  .venue-staff-shell.venue-admin-shell {
    grid-template-columns: 1fr !important;
    gap: 14px;
  }
  .venue-staff-shell .venue-admin-list {
    max-height: min(46vh, 520px);
  }
  /* Официанту схему — первой: он быстро берёт/отпускает свои столы.
     Хостес оставляем список броней сверху — это её основная работа. */
  .page-venue-waiter .venue-staff-shell .panel.venue-admin-right {
    order: -1;
  }
}
@media (min-width: 901px) and (max-width: 1200px) {
  .venue-staff-shell .venue-admin-list {
    max-height: min(50vh, 560px);
  }
}

/* ─── Focused page (Меню / Отзывы / Персонал) ─── */
.venue-focused-page { padding: 0; }
.venue-focused-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.venue-focused-head__title { margin: 0; }
.venue-focused-head__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.venue-focused-body {
  padding: 16px;
}
.venue-focused-body .venue-left-pane { padding: 0; }
.venue-focused-body .venue-menu-panel-head,
.venue-focused-body .venue-reviews-head,
.venue-focused-body .venue-staff-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.venue-focused-body .venue-menu-toolbar { display: flex; gap: 8px; flex-wrap: wrap; }
@media (max-width: 640px) {
  .venue-focused-head { flex-direction: column; align-items: stretch; }
  .venue-focused-head__actions { justify-content: flex-start; }
}

/* =====================================================
   GUEST CATALOG — premium place cards (clean, no overlap)
   ===================================================== */
.places-grid--cards {
    align-items: stretch;
}
.place-card {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 230px;
    padding: 16px;
    border-radius: 18px;
    overflow: hidden;
    isolation: isolate;
    text-decoration: none;
    color: #f8fafc;
    background: #1c1409;
    box-shadow: var(--shadow-sm);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
    -webkit-tap-highlight-color: transparent;
}
.place-card:hover,
.place-card:focus-visible {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    outline: none;
}
.place-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -2;
    background-image: var(--place-cover);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: transform 0.4s ease;
}
.place-card:hover::before { transform: scale(1.05); }
.place-card__shade {
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        linear-gradient(180deg, rgba(10, 6, 2, 0.05) 0%, rgba(10, 6, 2, 0.12) 42%, rgba(10, 6, 2, 0.74) 100%);
}
.place-card__fire {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 26px;
    height: 26px;
    object-fit: contain;
    filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.6));
    pointer-events: none;
}
.place-card__top {
    position: absolute;
    top: 12px;
    left: 12px;
    display: flex;
    gap: 6px;
}
.place-card__rating {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 9px;
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 700;
    color: #fff;
    background: rgba(12, 8, 4, 0.5);
    backdrop-filter: blur(6px);
    border: 1px solid rgba(255, 255, 255, 0.16);
}
.place-card__rating svg { color: #fbbf24; }
.place-card__rating i {
    font-style: normal;
    font-weight: 500;
    font-size: 11px;
    opacity: 0.8;
}
.place-card__body {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.place-card__head {
    display: flex;
    align-items: center;
    gap: 11px;
    min-width: 0;
}
.place-card__logo {
    flex: none;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    object-fit: cover;
    background: rgba(255, 255, 255, 0.1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}
.place-card__titles {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.place-card__name {
    font-family: var(--font-display);
    font-size: 22px;
    line-height: 1.15;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: #fff;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.55);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.place-card__city {
    font-size: 13px;
    font-weight: 500;
    color: rgba(248, 250, 252, 0.88);
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.place-card__meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
}
.place-card__type {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 9px;
    color: rgba(255, 255, 255, 0.95);
    background: rgba(255, 255, 255, 0.14);
    backdrop-filter: blur(4px);
    border: 1px solid rgba(255, 255, 255, 0.16);
}
.place-card__chip {
    margin-left: auto;
    padding: 4px 11px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    color: #fff7ed;
    background: rgba(217, 119, 6, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.12);
    white-space: nowrap;
}
.place-card__cta {
    margin-top: 2px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 11px 14px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 700;
    color: var(--btn-primary-text);
    background: var(--accent);
    box-shadow: 0 6px 16px rgba(217, 119, 6, 0.35);
    transition: background 0.2s ease, transform 0.2s ease;
}
.place-card:hover .place-card__cta { background: #b45309; }

@media (max-width: 559px) {
    .place-card { min-height: 200px; padding: 14px; }
    .place-card__name { font-size: 20px; }
}

/* =====================================================
   FLOOR PLAN — единый холст для всех схем зала
   Один и тот же aspect-ratio в редакторе и во всех просмотрах
   (гость / хостес / официант / опер-панель), чтобы расстановка
   столов выглядела ОДИНАКОВО везде и ничего не «съезжало».
   ===================================================== */
.table-board,
.venue-waiter-board .table-board,
.page-venue-dashboard .table-board,
.venue-admin-board-wrap .table-board,
.vt-board-card .table-board,
body.venue-admin-fullscreen .table-board,
.est-table-panel,
.est-table-wrap .est-table-panel {
    aspect-ratio: 16 / 10 !important;
    min-height: 0 !important;
    min-width: 0 !important;
    height: auto !important;
}
/* Гостевая схема: вписываем по ширине (зум — щипком), без принудительного скролла */
.est-table-wrap {
    overflow: hidden !important;
}
/* Редактор столов: тот же холст 16/10, по центру, влезает в экран */
.vt2-board {
    flex: 0 0 auto !important;
    width: min(100%, calc((100vh - 160px) * 1.6)) !important;
    height: auto !important;
    aspect-ratio: 16 / 10 !important;
    min-height: 0 !important;
    margin: 0 auto !important;
}
@media (max-width: 900px) {
    .vt2-board {
        width: 100% !important;
    }
}

/* =====================================================
   Лист заказа/чека по брони (официант / хостес)
   ===================================================== */
.page-venue-waiter .venue-booking-card {
    cursor: pointer;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.05s ease;
}
.page-venue-waiter .venue-booking-card:hover {
    border-color: rgba(217, 119, 6, 0.45);
    box-shadow: 0 6px 18px rgba(28, 16, 7, 0.08);
}
.page-venue-waiter .venue-booking-card:active { transform: scale(0.995); }
.page-venue-waiter .venue-booking-card::after {
    content: "Открыть чек →";
    display: block;
    margin-top: 8px;
    font-size: 12px;
    font-weight: 700;
    color: var(--link);
    opacity: 0.85;
}

.so-sheet {
    position: fixed;
    inset: 0;
    z-index: 100400;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.so-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 7, 2, 0);
    transition: background 0.22s ease;
}
.so-sheet.is-open .so-backdrop { background: rgba(10, 7, 2, 0.5); }
.so-panel {
    position: relative;
    width: 100%;
    max-width: 560px;
    max-height: 94vh;
    display: flex;
    flex-direction: column;
    background: var(--bg, #fbf8f3);
    border-radius: 22px 22px 0 0;
    box-shadow: 0 -20px 60px rgba(20, 12, 4, 0.32);
    transform: translateY(100%);
    transition: transform 0.28s cubic-bezier(0.34, 1.2, 0.64, 1);
    overflow: hidden;
}
.so-sheet.is-open .so-panel { transform: translateY(0); }
.so-head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 18px 12px;
    border-bottom: 1px solid var(--line, rgba(0,0,0,0.08));
    background: #fff;
}
.so-title { font-size: 18px; font-weight: 800; line-height: 1.2; }
.so-sub { margin-top: 3px; font-size: 12.5px; }
.so-close {
    margin-left: auto;
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    border: 1px solid var(--line, rgba(0,0,0,0.1));
    background: #fff;
    font-size: 16px;
    cursor: pointer;
}
.so-body { flex: 1 1 auto; overflow-y: auto; padding: 14px 18px; -webkit-overflow-scrolling: touch; }
.so-status-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
}
.so-status-btns { display: flex; gap: 8px; flex-wrap: wrap; margin-left: auto; }
.so-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 8px;
}
.so-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
    border-bottom: 1px dashed var(--line, rgba(0,0,0,0.08));
}
.so-select {
    width: 100%;
    min-width: 0;
    padding: 9px 10px;
    border-radius: 10px;
    border: 1px solid var(--line, rgba(0,0,0,0.14));
    background: #fff;
    font-size: 14px;
}
.so-qty { display: inline-flex; align-items: center; gap: 4px; }
.so-qbtn {
    width: 32px;
    height: 32px;
    border-radius: 9px;
    border: 1px solid var(--line, rgba(0,0,0,0.14));
    background: #fff;
    font-size: 17px;
    font-weight: 700;
    cursor: pointer;
    line-height: 1;
}
.so-qval {
    width: 42px;
    text-align: center;
    padding: 7px 4px;
    border-radius: 9px;
    border: 1px solid var(--line, rgba(0,0,0,0.14));
    font-size: 14px;
    -moz-appearance: textfield;
}
.so-qval::-webkit-outer-spin-button,
.so-qval::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.so-add-btns { display: flex; gap: 6px; }
.so-custom {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr 120px;
    gap: 8px;
    margin-top: 2px;
}
.so-custom[hidden] { display: none; }
.so-ctitle,
.so-cprice {
    padding: 9px 10px;
    border-radius: 10px;
    border: 1px solid var(--line, rgba(0,0,0,0.14));
    background: #fff;
    font-size: 14px;
}
.so-cprice {
    -moz-appearance: textfield;
}
.so-cprice::-webkit-outer-spin-button,
.so-cprice::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.so-line {
    grid-column: 1 / -1;
    font-size: 12px;
    color: var(--muted, #6b6256);
}
.so-del {
    grid-row: 1;
    grid-column: 3;
    width: 32px;
    height: 32px;
    border: 0;
    background: transparent;
    color: var(--muted, #6b6256);
    font-size: 14px;
    cursor: pointer;
}
.so-foot {
    margin-top: 12px;
    text-align: right;
    font-size: 15px;
    font-weight: 700;
}
.so-total { color: var(--link); }
.so-err {
    margin-top: 12px;
    padding: 10px 12px;
    border-radius: 10px;
    background: rgba(220, 38, 38, 0.08);
    color: #b91c1c;
    font-size: 13px;
}
.so-actions {
    flex: 0 0 auto;
    padding: 12px 18px calc(12px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--line, rgba(0,0,0,0.08));
    background: #fff;
}
.so-save {
    width: 100%;
    padding: 14px;
    font-size: 16px;
    font-weight: 800;
    border-radius: 14px;
}
body.so-open { overflow: hidden; }

@media (min-width: 720px) {
    .so-sheet { align-items: center; }
    .so-panel { border-radius: 20px; max-height: 88vh; }
}
.so-menu-search {
    width: 100%;
    margin: 0 0 8px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid var(--line, rgba(0,0,0,0.14));
    font-size: 15px;
    background: #fff;
}

/* Менеджер: вкладки Брони / Схема на телефоне */
.venue-mob-tabs {
    display: none;
}
@media (max-width: 900px) {
    .venue-mob-tabs {
        display: flex;
        gap: 8px;
        margin: 0 0 12px;
        padding: 4px;
        border-radius: 14px;
        background: var(--bg-soft, #f5f0e8);
        border: 1px solid var(--line);
    }
    .venue-mob-tab {
        flex: 1 1 50%;
        min-height: 44px;
        border: 0;
        border-radius: 11px;
        background: transparent;
        font-size: 14px;
        font-weight: 700;
        color: var(--muted);
        cursor: pointer;
        transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
    }
    .venue-mob-tab.is-active {
        background: #fff;
        color: var(--ink);
        box-shadow: 0 2px 8px rgba(28, 16, 7, 0.08);
    }
    .page-venue-dashboard .venue-mob-tab-board .venue-admin-left {
        display: none !important;
    }
    .page-venue-dashboard .venue-mob-tab-bookings .venue-admin-right {
        display: none !important;
    }
    /* Официант / хостес: те же вкладки Брони / Схема */
    .page-venue-waiter .venue-mob-tab-board .venue-admin-left,
    .page-venue-hostess .venue-mob-tab-board .venue-admin-left {
        display: none !important;
    }
    .page-venue-waiter .venue-mob-tab-bookings .venue-admin-right,
    .page-venue-hostess .venue-mob-tab-bookings .venue-admin-right {
        display: none !important;
    }
    .page-venue-dashboard .venue-admin-board-wrap.venue-board-zoom-wrap {
        overflow: hidden;
        touch-action: pan-y;
        position: relative;
        aspect-ratio: 16 / 10;
        max-height: min(56vh, 480px);
        border-radius: 16px;
        background: linear-gradient(165deg, #f8f4ee 0%, #efe8dc 100%);
    }
    .page-venue-dashboard .venue-board-zoom-wrap .table-board {
        transform-origin: 0 0;
        will-change: transform;
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
    }
    .page-venue-waiter .venue-board-zoom-wrap,
    .page-venue-hostess .venue-board-zoom-wrap {
        overflow: hidden;
        touch-action: pan-y;
        position: relative;
        aspect-ratio: 16 / 10;
        max-height: min(56vh, 480px);
        border-radius: 16px;
    }
    .page-venue-waiter .venue-board-zoom-wrap .table-board,
    .page-venue-hostess .venue-board-zoom-wrap .table-board {
        transform-origin: 0 0;
        will-change: transform;
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
    }
    .page-venue-hub main.container,
    .page-venue-hub .venue-hub-page {
        padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px));
    }
}

/* Щипковый зум схемы у персонала (телефон/планшет) — самодостаточно,
   без привязки к узкому media-запросу, чтобы работало и на планшетах. */
.venue-board-zoom-wrap.is-zoomable {
    position: relative;
    overflow: hidden;
    touch-action: pan-y;
    border-radius: 16px;
    -webkit-overflow-scrolling: touch;
}
.venue-board-zoom-wrap.is-zoomable .table-board {
    transform-origin: 0 0;
    will-change: transform;
}
.venue-board-zoom-wrap.is-zoomable::after {
    content: "👌 Сведи/разведи пальцы для масштаба";
    position: absolute;
    left: 50%;
    bottom: 8px;
    transform: translateX(-50%);
    z-index: 4;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    color: #fff;
    background: rgba(28, 16, 7, 0.72);
    backdrop-filter: blur(4px);
    pointer-events: none;
    opacity: 0;
    animation: zoomHintPulse 5s ease forwards;
}
@keyframes zoomHintPulse {
    0% { opacity: 0; }
    12% { opacity: 1; }
    78% { opacity: 1; }
    100% { opacity: 0; }
}

/* Панели персонала на телефоне — компактнее и легче (full-bleed-стиль) */
@media (max-width: 899px) {
    .page-venue-hostess main.container.container--guest-wide,
    .page-venue-waiter main.container.container--guest-wide,
    .page-venue-dashboard main.container.container--guest-wide {
        padding-left: max(12px, env(safe-area-inset-left, 0px)) !important;
        padding-right: max(12px, env(safe-area-inset-right, 0px)) !important;
    }
    .page-venue-hostess .venue-admin-shell .panel,
    .page-venue-waiter .venue-admin-shell .panel,
    .page-venue-dashboard .venue-admin-shell .panel {
        padding: 14px;
        border-radius: 16px;
    }
    .page-venue-hostess .venue-admin-shell,
    .page-venue-waiter .venue-admin-shell,
    .page-venue-dashboard .venue-admin-shell {
        gap: 14px;
    }
}

/* FAB «Новая бронь» — плавающая кнопка на телефоне/планшете */
.venue-staff-fab .venue-staff-fab__plus { font-weight: 800; font-size: 1.05em; line-height: 1; }
.venue-staff-fab .venue-staff-fab__label { margin-left: 4px; }
@media (max-width: 900px) {
    .venue-staff-fab {
        position: fixed;
        right: 16px;
        bottom: calc(72px + env(safe-area-inset-bottom, 0px));
        z-index: 9000;
        height: 52px;
        padding: 0 22px 0 18px;
        border-radius: 999px;
        display: inline-flex;
        align-items: center;
        gap: 2px;
        font-size: 15px;
        font-weight: 700;
        color: var(--btn-primary-text, #18130a);
        background: var(--accent);
        box-shadow: 0 8px 24px rgba(217, 119, 6, 0.45), 0 2px 6px rgba(0,0,0,0.2);
        border: none;
        animation: fabPop 0.3s cubic-bezier(0.22, 1, 0.36, 1);
    }
    .venue-staff-fab .venue-staff-fab__plus { font-size: 1.35em; }
    .venue-staff-fab:active { transform: scale(0.96); }
    /* Освобождаем шапку — экшены больше не теснят заголовок */
    .page-venue-hostess .venue-staff-app__head-actions {
        position: static;
    }
}
@keyframes fabPop {
    from { opacity: 0; transform: translateY(12px) scale(0.9); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Хостес: тап по брони открывает лист заказа */
.page-venue-hostess .venue-booking-card {
    cursor: pointer;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.page-venue-hostess .venue-booking-card:hover {
    border-color: rgba(217, 119, 6, 0.45);
    box-shadow: 0 6px 18px rgba(28, 16, 7, 0.08);
}
.page-venue-hostess .venue-booking-card::after {
    content: "Открыть бронь →";
    display: block;
    margin-top: 8px;
    font-size: 12px;
    font-weight: 700;
    color: var(--link);
}
.page-venue-hostess .venue-booking-card__actions {
    position: relative;
    z-index: 2;
}

/* Легенда официанта — компактно на узком экране */
@media (max-width: 480px) {
    .venue-waiter-legend {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 6px 8px;
        font-size: 11px;
    }
    .venue-waiter-legend__chip {
        width: 10px;
        height: 10px;
    }
}

/* Каталог гостя — одна колонка, без налезания chip на CTA */
@media (max-width: 640px) {
    .places-grid--cards {
        grid-template-columns: 1fr !important;
        gap: 14px;
    }
    .place-card {
        min-height: 210px;
    }
    /* Иконки типа — в ряд; chip переносится на новую строку, если не влез */
    .place-card__meta {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        gap: 6px;
    }
    .place-card__chip {
        margin-left: auto;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .place-card__cta {
        margin-top: 4px;
    }
}

/* Подписи столов — не вылезают за границы */
.board-table .board-table-title,
.board-table > span.board-table-title {
    max-width: 92%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    pointer-events: none;
}
