:root {
    --site-width: 80%;
    --modal-width: 80vw;
    --bg: #f6f7fb;
    --card: #ffffff;
    --text: #1f2937;
    --muted: #6b7280;
    --primary: #0ea5e9;
    --primary-dark: #0284c7;
    --danger: #c74b4b;
    --danger-strong: #b33d3d;
    --danger-text: #8f2f2f;
    --danger-soft-bg: rgba(199, 75, 75, 0.14);
    --danger-border: rgba(199, 75, 75, 0.5);
    --danger-ring: rgba(199, 75, 75, 0.3);
    --btn-primary-bg: var(--primary);
    --btn-primary-bg-hover: var(--primary-dark);
    --border: rgba(31, 41, 55, 0.12);
    --shadow: 0 8px 22px rgba(2, 132, 199, 0.10);
    --radius: 12px;
    /* Поля ввода: в тёмной теме — тёмная «подложка» + светлый текст (--text), не белый фон. */
    --field-surface: rgba(255, 255, 255, 0.92);
    --field-surface-focus: #ffffff;
    --field-surface-disabled: rgba(248, 250, 252, 0.95);
    /* Fallback для компонентов с var(--input-bg) / var(--card-bg) — прайс/маркетинг тулбары. */
    --input-bg: var(--field-surface);
    --card-bg: var(--card);
    /* Боковое и верхнее подменю лидер-панели (не белые плашки в тёмной теме). */
    --leader-nav-sidebar-bg: rgba(255, 255, 255, 0.72);
    --leader-nav-primary-hover: rgba(255, 255, 255, 0.95);
    --leader-nav-secondary-hover: rgba(15, 23, 42, 0.05);
    --leader-nav-tertiary-bg: rgba(255, 255, 255, 0.65);
    --leader-nav-tertiary-hover: rgba(15, 23, 42, 0.06);
    --leader-nav-active-bg: rgba(14, 165, 233, 0.12);
    --leader-nav-active-border: rgba(14, 165, 233, 0.4);
    --leader-nav-active-bg-soft: rgba(14, 165, 233, 0.1);
    --leader-nav-active-border-soft: rgba(14, 165, 233, 0.25);
    --leader-nav-sidebar-border: var(--border);
    /* Сворачиваемые блоки (details): не светло-серые в тёмной теме */
    --leader-collapsible-bg: rgba(255, 255, 255, 0.58);
    /*
     * Отступ sticky-сайдбара «Управление автомойкой» от верха вьюпорта.
     * Шапка полупрозрачная — если top меньше реальной высоты .site-header, фон карточки меню виден «под стеклом».
     */
    --leader-sidebar-under-header: 87px;
    /* Сегмент «тип входа/регистрации»: фон дорожки (иначе в dark — светлая полоса + светлый --text). */
    --register-kind-track-bg: rgba(248, 250, 252, 0.95);
    --register-kind-segment-hover-bg: rgba(14, 165, 233, 0.08);
}

/* Простой интерфейс: темы (атрибут data-simple-ui-theme на html в simple-режиме — SPA и Django-шаблоны). */
html[data-simple-ui-theme="light"] {
    color-scheme: light;
    --bg: #f6f7fb;
    --card: #ffffff;
    --text: #1f2937;
    --muted: #6b7280;
    --primary: #0ea5e9;
    --primary-dark: #0284c7;
    --danger: #c74b4b;
    --danger-strong: #b33d3d;
    --danger-text: #8f2f2f;
    --danger-soft-bg: rgba(199, 75, 75, 0.14);
    --danger-border: rgba(199, 75, 75, 0.5);
    --danger-ring: rgba(199, 75, 75, 0.3);
    --border: rgba(31, 41, 55, 0.12);
    --shadow: 0 8px 22px rgba(2, 132, 199, 0.10);
    --simple-ui-header-bg: rgba(246, 247, 251, 0.85);
    --simple-ui-footer-bg: rgba(255, 255, 255, 0.6);
    --btn-ghost-bg: rgba(255, 255, 255, 0.65);
    --btn-ghost-bg-hover: rgba(255, 255, 255, 0.95);
    --nav-link-hover-bg: rgba(255, 255, 255, 0.6);
    --field-surface: rgba(255, 255, 255, 0.92);
    --field-surface-focus: #ffffff;
    --field-surface-disabled: rgba(248, 250, 252, 0.95);
    --leader-nav-sidebar-bg: rgba(255, 255, 255, 0.72);
    --leader-nav-primary-hover: rgba(255, 255, 255, 0.95);
    --leader-nav-secondary-hover: rgba(15, 23, 42, 0.05);
    --leader-nav-tertiary-bg: rgba(255, 255, 255, 0.65);
    --leader-nav-tertiary-hover: rgba(15, 23, 42, 0.06);
    --leader-nav-active-bg: rgba(14, 165, 233, 0.12);
    --leader-nav-active-border: rgba(14, 165, 233, 0.4);
    --leader-nav-active-bg-soft: rgba(14, 165, 233, 0.1);
    --leader-nav-active-border-soft: rgba(14, 165, 233, 0.25);
    --leader-nav-sidebar-border: var(--border);
    --leader-collapsible-bg: rgba(255, 255, 255, 0.58);
    --btn-primary-bg: var(--primary);
    --btn-primary-bg-hover: var(--primary-dark);
    --input-bg: var(--field-surface);
    --card-bg: var(--card);
    --register-kind-track-bg: rgba(248, 250, 252, 0.95);
    --register-kind-segment-hover-bg: rgba(14, 165, 233, 0.08);
}

html[data-simple-ui-theme="dark"] {
    color-scheme: dark;
    --bg: #0b1220;
    --card: #152036;
    --text: #e5e7eb;
    /* Приглушённый синевато-голубой вместо нейтрального серого */
    --muted: #8cb4d9;
    --primary: #38bdf8;
    --primary-dark: #7dd3fc;
    --danger: #c95a5a;
    --danger-strong: #b94a4a;
    --danger-text: #efb6b6;
    --danger-soft-bg: rgba(201, 90, 90, 0.26);
    --danger-border: rgba(201, 90, 90, 0.56);
    --danger-ring: rgba(201, 90, 90, 0.36);
    --border: rgba(56, 189, 248, 0.22);
    --shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
    --simple-ui-header-bg: rgba(10, 22, 42, 0.93);
    --simple-ui-footer-bg: rgba(18, 36, 62, 0.78);
    --btn-ghost-bg: rgba(22, 44, 78, 0.82);
    --btn-ghost-bg-hover: rgba(32, 62, 108, 0.92);
    --nav-link-hover-bg: rgba(56, 189, 248, 0.14);
    --field-surface: #1a3358;
    --field-surface-focus: #274a78;
    --field-surface-disabled: rgba(26, 51, 88, 0.65);
    /* Выпадающие панели комбобоксов (.leader-marketing-*) — не белый fallback. */
    --surface: #1a3358;
    /* Сайдбар почти сливается с фоном — только лёгкая обводка */
    --leader-nav-sidebar-bg: var(--bg);
    --leader-nav-sidebar-border: rgba(56, 189, 248, 0.12);
    --leader-nav-primary-hover: rgba(56, 189, 248, 0.1);
    --leader-nav-secondary-hover: rgba(56, 189, 248, 0.08);
    --leader-nav-tertiary-bg: rgba(56, 189, 248, 0.09);
    --leader-nav-tertiary-hover: rgba(56, 189, 248, 0.16);
    --leader-collapsible-bg: rgba(22, 44, 72, 0.55);
    --leader-nav-active-bg: rgba(56, 189, 248, 0.22);
    --leader-nav-active-border: rgba(125, 211, 252, 0.42);
    --leader-nav-active-bg-soft: rgba(56, 189, 248, 0.16);
    --leader-nav-active-border-soft: rgba(125, 211, 252, 0.32);
    /* Кнопки .btn-primary: спокойный сине-бирюзовый вместо яркого #38bdf8 */
    --btn-primary-bg: #0f6f9c;
    --btn-primary-bg-hover: #0c5d84;
    --input-bg: var(--field-surface);
    --card-bg: var(--card);
    --register-kind-track-bg: rgba(22, 34, 54, 0.92);
    --register-kind-segment-hover-bg: rgba(56, 189, 248, 0.16);
}

html[data-simple-ui-theme="system"] {
    color-scheme: light dark;
}

@media (prefers-color-scheme: dark) {
    html[data-simple-ui-theme="system"] {
        color-scheme: dark;
        --bg: #0b1220;
        --card: #152036;
        --text: #e5e7eb;
        --muted: #8cb4d9;
        --primary: #38bdf8;
        --primary-dark: #7dd3fc;
        --danger: #c95a5a;
        --danger-strong: #b94a4a;
        --danger-text: #efb6b6;
        --danger-soft-bg: rgba(201, 90, 90, 0.26);
        --danger-border: rgba(201, 90, 90, 0.56);
        --danger-ring: rgba(201, 90, 90, 0.36);
        --border: rgba(56, 189, 248, 0.22);
        --shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
        --simple-ui-header-bg: rgba(10, 22, 42, 0.93);
        --simple-ui-footer-bg: rgba(18, 36, 62, 0.78);
        --btn-ghost-bg: rgba(22, 44, 78, 0.82);
        --btn-ghost-bg-hover: rgba(32, 62, 108, 0.92);
        --nav-link-hover-bg: rgba(56, 189, 248, 0.14);
        --field-surface: #1a3358;
        --field-surface-focus: #274a78;
        --field-surface-disabled: rgba(26, 51, 88, 0.65);
        --surface: #1a3358;
        --leader-nav-sidebar-bg: var(--bg);
        --leader-nav-sidebar-border: rgba(56, 189, 248, 0.12);
        --leader-nav-primary-hover: rgba(56, 189, 248, 0.1);
        --leader-nav-secondary-hover: rgba(56, 189, 248, 0.08);
        --leader-nav-tertiary-bg: rgba(56, 189, 248, 0.09);
        --leader-nav-tertiary-hover: rgba(56, 189, 248, 0.16);
        --leader-collapsible-bg: rgba(22, 44, 72, 0.55);
        --leader-nav-active-bg: rgba(56, 189, 248, 0.22);
        --leader-nav-active-border: rgba(125, 211, 252, 0.42);
        --leader-nav-active-bg-soft: rgba(56, 189, 248, 0.16);
        --leader-nav-active-border-soft: rgba(125, 211, 252, 0.32);
        --btn-primary-bg: #0f6f9c;
        --btn-primary-bg-hover: #0c5d84;
        --input-bg: var(--field-surface);
        --card-bg: var(--card);
        --register-kind-track-bg: rgba(22, 34, 54, 0.92);
        --register-kind-segment-hover-bg: rgba(56, 189, 248, 0.16);
    }
}

body.site-layout--employee-nav {
    /* Меню сотрудника: больше ссылок в .nav-main, колонка с кнопкой переключения UI — шапка выше */
    --leader-sidebar-under-header: 114px;
}

* { box-sizing: border-box; }

html {
    height: 100%;
    zoom: 0.9;
}

body {
    margin: 0;
    min-height: 100%;
    font-size: 13px;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    color: var(--text);
    background: var(--bg);
}

body.site-layout {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

@supports (zoom: 1) {
    body.site-layout {
        min-height: calc(100vh / 0.9);
    }
    body.site-layout > #root {
        min-height: calc(100vh / 0.9);
    }
}

/* React SPA: шапка и подвал внутри #root — иначе flex на body не трогает main */
body.site-layout > #root {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}


.container {
    width: var(--site-width);
    max-width: 100%;
    margin: 0 auto;
}


.site-header {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    box-sizing: border-box;
    background: rgba(246, 247, 251, 0.85);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--border);
    z-index: 10;
}

.site-header.site-header--simple-ui {
    background: var(--simple-ui-header-bg, rgba(246, 247, 251, 0.85));
}

.header-mobile-top {
    display: contents;
}

.header-inner {
    padding: 12px 0;
    display: grid;
    grid-template-columns: minmax(0, auto) minmax(0, 1fr) auto;
    align-items: start;
    gap: 10px 14px;
}

/* Простой интерфейс: меню по центру между логотипом и аккаунтом (не «в середине» широкой средней колонки) */
.site-header.site-header--simple-ui .header-inner {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
}

.site-header.site-header--simple-ui .header-brand {
    justify-self: start;
}

.site-header.site-header--simple-ui .nav-main {
    justify-content: center;
    max-width: 100%;
    min-width: 0;
    position: relative;
    z-index: 1;
}

.site-header.site-header--simple-ui .header-auth-stack {
    justify-self: end;
}

/* Простой UI: ссылки меню без «гостевого» синего; активная — в тон теме (в т.ч. тёмная). */
.site-header.site-header--simple-ui .nav-main .nav-link,
.site-header.site-header--simple-ui .nav-main a.nav-link:visited {
    color: var(--text);
}

html[data-simple-ui-theme="dark"] .site-header.site-header--simple-ui .nav-main .nav-link.active {
    background: var(--leader-nav-active-bg-soft);
    border-color: var(--leader-nav-active-border-soft);
    color: var(--text);
}

@media (prefers-color-scheme: dark) {
    html[data-simple-ui-theme="system"] .site-header.site-header--simple-ui .nav-main .nav-link,
    html[data-simple-ui-theme="system"] .site-header.site-header--simple-ui .nav-main a.nav-link:visited {
        color: var(--text);
    }

    html[data-simple-ui-theme="system"] .site-header.site-header--simple-ui .nav-main .nav-link.active {
        background: var(--leader-nav-active-bg-soft);
        border-color: var(--leader-nav-active-border-soft);
        color: var(--text);
    }
}

.header-brand {
    align-self: center;
    min-width: 0;
    max-width: 100%;
}

/* Кнопка «гамбургер»: только узкий экран (см. @media ниже) */
.header-nav-toggle {
    display: none;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin: 0;
    padding: 0;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--btn-ghost-bg, rgba(255, 255, 255, 0.65));
    color: var(--text);
    cursor: pointer;
    flex-shrink: 0;
    transition: background 120ms ease, border-color 120ms ease;
}

.header-nav-toggle:hover {
    background: var(--btn-ghost-bg-hover, rgba(255, 255, 255, 0.95));
}

.header-nav-toggle:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
}

.header-nav-toggle__bars {
    display: block;
}

.header-mobile-backdrop {
    display: none;
}

.site-header.site-header--has-bg .header-nav-toggle {
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.35);
    background: rgba(255, 255, 255, 0.12);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}

.site-header.site-header--has-bg .header-nav-toggle:hover {
    background: rgba(255, 255, 255, 0.22);
}

.nav-main {
    justify-content: center;
}

.header-auth-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    align-self: center;
    position: relative;
    z-index: 5;
    pointer-events: auto;
}

.header-auth {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
}

.header-ui-mode-form {
    margin: 0;
}

.header-ui-mode-btn {
    font-size: 9px;
    padding: 4px 8px;
    white-space: nowrap;
}

.header-ui-segment-form {
    margin: 0;
}

.header-ui-segmentstrip {
    display: inline-flex;
    align-items: stretch;
    flex-wrap: nowrap;
    border: 1px solid var(--border);
    border-radius: 9px;
    overflow: hidden;
    background: var(--btn-ghost-bg, rgba(255, 255, 255, 0.65));
    max-width: 100%;
}

.header-ui-segment-btn {
    font: inherit;
    font-size: 9px;
    font-weight: 600;
    margin: 0;
    padding: 4px 8px;
    border: none;
    border-radius: 0;
    background: transparent;
    color: var(--text);
    cursor: pointer;
    white-space: nowrap;
    line-height: 1.2;
    transition: background 120ms ease, color 120ms ease;
}

.header-ui-segment-btn + .header-ui-segment-btn {
    border-left: 1px solid var(--border);
}

.header-ui-segment-btn:hover {
    background: var(--btn-ghost-bg-hover, rgba(255, 255, 255, 0.95));
}

.header-ui-segment-btn:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: -2px;
}

.header-ui-segment-btn:disabled {
    opacity: 0.55;
    cursor: progress;
}

.header-ui-segment-btn--selected {
    background: rgba(14, 165, 233, 0.16);
    color: var(--primary-dark);
}

.header-ui-segment-btn--icon {
    padding: 4px 7px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 26px;
}

.header-ui-segment-icon {
    display: block;
    flex-shrink: 0;
}

.brand-link {
    text-decoration: none;
    color: inherit;
}

.brand-title {
    font-weight: 800;
    font-size: 16px;
    line-height: 1.2;
    overflow-wrap: anywhere;
    word-break: normal;
}

.brand-subtitle {
    color: var(--muted);
    font-size: 10px;
    margin-top: 2px;
    line-height: 1.25;
    overflow-wrap: anywhere;
    word-break: normal;
}

.brand {
    display: flex;
    align-items: center;
    gap: 9px;
    min-width: 0;
}

.brand-text {
    min-width: 0;
}

.brand-logo-img {
    flex-shrink: 0;
    object-fit: contain;
    border-radius: 8px;
}

.brand-logo-placeholder {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    border: 1px dashed rgba(100, 116, 139, 0.75);
    background: rgba(241, 245, 249, 0.9);
    color: #475569;
    font-size: 8px;
    font-weight: 700;
    letter-spacing: 0.4px;
}

.site-header.site-header--has-bg {
    /* Слой 1–2: затемнение для читаемости; слой 3: фото с отдельной точкой фокуса */
    --header-bg-readability: rgba(15, 23, 42, 0.35);
    background-image: linear-gradient(
            var(--header-bg-readability),
            var(--header-bg-readability)
        ),
        linear-gradient(var(--header-bg-overlay, rgba(246, 247, 251, 0.5)), var(--header-bg-overlay, rgba(246, 247, 251, 0.5))),
        var(--header-bg-image);
    background-size: cover, cover, cover;
    background-position: center center, center center, var(--header-bg-pos-x, 50%) var(--header-bg-pos-y, 50%);
    background-repeat: no-repeat;
    border-bottom-color: rgba(31, 41, 55, 0.18);
}

.site-header.site-header--has-bg .brand-title,
.site-header.site-header--has-bg .brand-subtitle {
    color: #f8fafc;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.85), 0 0 9px rgba(0, 0, 0, 0.55);
}

.site-header.site-header--has-bg .nav-main .nav-link,
.site-header.site-header--has-bg .header-auth .nav-link,
.site-header.site-header--has-bg .header-ui-mode-btn {
    color: #f8fafc;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.85), 0 0 8px rgba(0, 0, 0, 0.45);
}

.site-header.site-header--has-bg .nav-main .nav-link:hover,
.site-header.site-header--has-bg .header-auth .nav-link:hover,
.site-header.site-header--has-bg .header-ui-mode-btn:hover {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.35);
    color: #fff;
}

.site-header.site-header--has-bg .nav-main .nav-link.active,
.site-header.site-header--has-bg .header-auth .nav-link.active {
    background: rgba(14, 165, 233, 0.45);
    border-color: rgba(125, 211, 252, 0.55);
    color: #fff;
}

/* Нет отдельного фона шапки: сквозь шапку виден тот же фон страницы (background-attachment: fixed на body) */
.site-header.site-header--site-bg-continues {
    background: rgba(246, 247, 251, 0.38);
    backdrop-filter: blur(9px);
    -webkit-backdrop-filter: blur(9px);
    border-bottom-color: rgba(31, 41, 55, 0.14);
}

/*
 * Единый фон: шапка как и везде — sticky (см. .site-header). Чуть плотнее подложка и сильнее blur,
 * чтобы при прокрутке контент под стеклом читался хуже и шапка ощущалась отдельной полосой.
 */
body.site-unified-bg .site-header.site-header--site-bg-continues {
    background: rgba(246, 247, 251, 0.88);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom-color: rgba(31, 41, 55, 0.12);
    box-shadow: 0 1px 0 rgba(31, 41, 55, 0.06);
}

body.site-body--has-bg {
    background-image: linear-gradient(var(--site-bg-overlay, rgba(246, 247, 251, 0.88)), var(--site-bg-overlay, rgba(246, 247, 251, 0.88))), var(--site-bg-image);
    background-size: cover;
    background-position: center top;
    background-attachment: fixed;
    background-repeat: no-repeat;
}

.nav {
    display: flex;
    gap: 9px;
    flex-wrap: wrap;
}

.nav-link {
    text-decoration: none;
    color: var(--text);
    padding: 8px 9px;
    border-radius: 9px;
    border: 1px solid transparent;
    transition: 160ms ease;
}

.nav-link:hover {
    border-color: var(--border);
    background: var(--nav-link-hover-bg, rgba(255, 255, 255, 0.6));
}

.nav-link.active {
    background: rgba(14, 165, 233, 0.10);
    border-color: rgba(14, 165, 233, 0.35);
    color: var(--primary-dark);
}

/* Согласие на cookie (SPA + Django base.html), ключ localStorage alfamoika_cookie_consent_v1 */
.cookie-consent {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 100;
    padding: 12px 0 calc(12px + env(safe-area-inset-bottom, 0px));
    background: rgba(15, 23, 42, 0.94);
    color: #e2e8f0;
    border-top: 1px solid rgba(148, 163, 184, 0.4);
    box-shadow: 0 -6px 28px rgba(0, 0, 0, 0.18);
}

.cookie-consent[hidden] {
    display: none !important;
}

.cookie-consent__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px 18px;
}

.cookie-consent__text {
    margin: 0;
    flex: 1 1 min(100%, 540px);
    font-size: 13px;
    line-height: 1.5;
    color: #cbd5e1;
}

.cookie-consent__btn {
    flex-shrink: 0;
}

body.cookie-consent-visible {
    padding-bottom: calc(96px + env(safe-area-inset-bottom, 0px));
}

@media (max-width: 520px) {
    .cookie-consent__inner {
        flex-direction: column;
        align-items: stretch;
    }

    .cookie-consent__btn {
        width: 100%;
    }
}

.site-main {
    flex: 1 0 auto;
    padding: 20px 0 30px;
}

.flash-stack {
    display: grid;
    gap: 6px;
    margin-bottom: 9px;
}

/* React-оболочка: длинный хвост уведомлений после графика/прайса не должен раздувать вёрстку */
.flash-stack--spa-shell {
    max-height: min(40vh, 240px);
    overflow-y: auto;
    margin-top: 9px;
    margin-bottom: 0;
}

.flash {
    padding: 8px 9px;
    border-radius: 8px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.8);
}

.flash-success {
    border-color: rgba(34, 197, 94, 0.45);
    background: rgba(34, 197, 94, 0.12);
}

.flash-error {
    border-color: var(--danger-border);
    background: var(--danger-soft-bg);
}

.flash-warning {
    border-color: rgba(245, 158, 11, 0.45);
    background: rgba(245, 158, 11, 0.12);
}

.flash-info {
    border-color: rgba(14, 165, 233, 0.38);
    background: rgba(14, 165, 233, 0.1);
}

/* Simple UI, тёмная тема: .flash не остаётся «светлым пятном» с бледным текстом */
html[data-simple-ui-theme="dark"] .flash {
    background: var(--card-bg, var(--card));
    color: var(--text);
    border-color: var(--border);
}

html[data-simple-ui-theme="dark"] .flash-success {
    border-color: rgba(52, 211, 153, 0.42);
    background: rgba(16, 185, 129, 0.16);
    color: var(--text);
}

html[data-simple-ui-theme="dark"] .flash-error {
    border-color: var(--danger-border);
    background: var(--danger-soft-bg);
    color: var(--danger-text);
}

html[data-simple-ui-theme="dark"] .flash-warning {
    border-color: rgba(251, 191, 36, 0.45);
    background: rgba(245, 158, 11, 0.14);
    color: var(--text);
}

html[data-simple-ui-theme="dark"] .flash-info {
    border-color: rgba(56, 189, 248, 0.32);
    background: rgba(56, 189, 248, 0.12);
    color: var(--text);
}

@media (prefers-color-scheme: dark) {
    html[data-simple-ui-theme="system"] .flash {
        background: var(--card-bg, var(--card));
        color: var(--text);
        border-color: var(--border);
    }

    html[data-simple-ui-theme="system"] .flash-success {
        border-color: rgba(52, 211, 153, 0.42);
        background: rgba(16, 185, 129, 0.16);
        color: var(--text);
    }

    html[data-simple-ui-theme="system"] .flash-error {
        border-color: var(--danger-border);
        background: var(--danger-soft-bg);
        color: var(--danger-text);
    }

    html[data-simple-ui-theme="system"] .flash-warning {
        border-color: rgba(251, 191, 36, 0.45);
        background: rgba(245, 158, 11, 0.14);
        color: var(--text);
    }

    html[data-simple-ui-theme="system"] .flash-info {
        border-color: rgba(56, 189, 248, 0.32);
        background: rgba(56, 189, 248, 0.12);
        color: var(--text);
    }
}

.hero {
    padding: 21px 15px;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.16), rgba(2, 132, 199, 0.06));
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.hero-title {
    margin: 0;
    font-size: clamp(18px, 3.5vw, 26px);
    line-height: 1.2;
}

.hero-text {
    margin: 10px 0 14px;
    color: var(--muted);
    font-size: 11px;
    max-width: 62ch;
}

.hero-actions {
    display: flex;
    gap: 9px;
    flex-wrap: wrap;
}

.page {
    padding: 6px 0 0;
}

.page-title {
    margin: 8px 0 0;
    font-size: 26px;
}

.page-text {
    margin: 8px 0 15px;
    color: var(--muted);
}

.section {
    margin-top: 20px;
}

.section-title {
    margin: 0 0 10px;
    font-size: 15px;
}

.grid {
    display: grid;
    gap: 10px;
}

/* Равные доли в строке: иначе min-content длинных полей ломает 1fr */
.grid > *,
.leader-staff-modal-row > * {
    min-width: 0;
}

.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

/* Реквизиты: фиксируем одинаковые 2 колонки для всех трёх строк.
   Поддерживаем и новую (.leader-org-fields-grid), и старую разметку (leader-org-*-row). */
.leader-org-kind-inn-row,
.leader-org-fields-grid,
.leader-org-names-row.grid.grid-2,
.leader-org-director-row.grid.grid-2,
.leader-org-contact-row.grid.grid-2 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    width: 100%;
}

.leader-org-kind-inn-row > *,
.leader-org-fields-grid > *,
.leader-org-names-row.grid.grid-2 > *,
.leader-org-director-row.grid.grid-2 > *,
.leader-org-contact-row.grid.grid-2 > * {
    min-width: 0;
}

.leader-org-kind-inn-row .leader-staff-field,
.leader-org-fields-grid .leader-staff-field,
.leader-org-names-row.grid.grid-2 .leader-staff-field,
.leader-org-director-row.grid.grid-2 .leader-staff-field,
.leader-org-contact-row.grid.grid-2 .leader-staff-field {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
}

@media (max-width: 860px) {
    .grid-3 { grid-template-columns: 1fr; }
    .grid-2 { grid-template-columns: 1fr; }
    .leader-org-kind-inn-row,
    .leader-org-fields-grid,
    .leader-org-names-row.grid.grid-2,
    .leader-org-director-row.grid.grid-2,
    .leader-org-contact-row.grid.grid-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 12px 12px;
}

.card-title {
    margin: 0 0 6px;
    font-size: 12px;
}

.card-success {
    border-color: rgba(14, 165, 233, 0.35);
}

.card-space {
    margin-bottom: 10px;
}

.card-compact {
    padding: 9px;
}

.card-flat {
    box-shadow: none;
}

.card-text {
    margin: 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.5;
}

.feature-title {
    font-weight: 700;
    margin-bottom: 4px;
}

.feature-text {
    color: var(--muted);
    font-size: 10px;
    line-height: 1.5;
}

.btn {
    text-decoration: none;
    display: inline-block;
    padding: 8px 10px;
    border-radius: 9px;
    border: 1px solid transparent;
    font-weight: 600;
    transition: 160ms ease;
}

.btn-primary {
    background: var(--btn-primary-bg, var(--primary));
    color: #fff;
}

.btn-primary:hover {
    background: var(--btn-primary-bg-hover, var(--primary-dark));
}

.btn-primary:disabled {
    opacity: 0.48;
    cursor: not-allowed;
}

.btn-ghost {
    background: var(--btn-ghost-bg, rgba(255, 255, 255, 0.65));
    border-color: var(--border);
    color: var(--text);
}

.btn-ghost:hover {
    background: var(--btn-ghost-bg-hover, rgba(255, 255, 255, 0.95));
}

.cta {
    margin-top: 14px;
    padding: 12px;
    border-radius: var(--radius);
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.7);
}

.cta-title {
    font-weight: 800;
    margin-bottom: 4px;
}

.cta-text {
    color: var(--muted);
}

html[data-simple-ui-theme="dark"] .cta {
    background: var(--card-bg, var(--card));
    border-color: var(--border);
}

@media (prefers-color-scheme: dark) {
    html[data-simple-ui-theme="system"] .cta {
        background: var(--card-bg, var(--card));
        border-color: var(--border);
    }
}

.site-footer {
    flex-shrink: 0;
    border-top: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.6);
}

html[data-simple-ui-theme] .site-footer {
    background: var(--simple-ui-footer-bg, rgba(255, 255, 255, 0.6));
}

@media (max-width: 900px) {
    :root {
        /* Шапка: строка бренд+гамбургер, строка аккаунта */
        --leader-sidebar-under-header: 118px;
    }

    body.site-layout--employee-nav {
        --leader-sidebar-under-header: 138px;
    }

    /*
     * Без blur на шапке: иначе backdrop-filter задаёт containing block для position:fixed
     * (Chrome/WebKit) — панель меню привязана к высоте шапки и остаётся в потоке + pointer-events:none.
     */
    .site-header,
    .site-header.site-header--site-bg-continues,
    body.site-unified-bg .site-header.site-header--site-bg-continues {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }

    .header-mobile-top {
        display: flex;
        flex-direction: row;
        align-items: flex-start;
        justify-content: space-between;
        gap: 10px;
        width: 100%;
        min-width: 0;
    }

    .header-inner {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }

    .header-nav-toggle {
        display: inline-flex;
        flex-shrink: 0;
    }

    .site-header .header-mobile-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 195;
        background: rgba(15, 23, 42, 0.45);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition:
            opacity 0.2s ease,
            visibility 0.2s ease;
    }

    .site-header.site-header--mobile-menu-open .header-mobile-backdrop {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    /* Специфичность выше, чем у .site-header.site-header--simple-ui .nav-main { position: relative } */
    .site-header .nav.nav-main {
        position: fixed;
        z-index: 200;
        left: 0;
        top: 0;
        bottom: 0;
        width: min(92vw, 320px);
        box-sizing: border-box;
        margin: 0;
        padding: calc(12px + env(safe-area-inset-top, 0px)) 14px calc(20px + env(safe-area-inset-bottom, 0px));
        flex-direction: column;
        flex-wrap: nowrap;
        align-items: stretch;
        gap: 6px;
        justify-content: flex-start;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        background: var(--card-bg, var(--card));
        border-right: 1px solid var(--border);
        box-shadow: 8px 0 28px rgba(15, 23, 42, 0.18);
        transform: translateX(-105%);
        transition: transform 0.22s ease;
        pointer-events: none;
    }

    .site-header.site-header--mobile-menu-open .nav.nav-main {
        transform: translateX(0);
        pointer-events: auto;
    }

    .site-header.site-header--has-bg .nav.nav-main {
        background: color-mix(in srgb, var(--card-bg, #152036) 92%, transparent);
    }

    .site-header.site-header--has-bg .nav.nav-main .nav-link {
        color: var(--text);
        text-shadow: none;
    }

    .header-auth-stack {
        width: 100%;
        max-width: 100%;
        align-self: stretch;
        align-items: flex-end;
    }

    .header-ui-segment-form {
        align-self: flex-end;
        width: auto;
        max-width: 100%;
    }

    .header-auth {
        flex-wrap: wrap;
        justify-content: flex-end;
        max-width: 100%;
    }

    .header-auth .nav-link {
        white-space: normal;
        text-align: right;
        max-width: 100%;
        overflow-wrap: anywhere;
        word-break: normal;
    }

    .header-ui-segmentstrip {
        display: inline-flex;
        flex-wrap: wrap;
        justify-content: flex-end;
        width: auto;
        max-width: 100%;
        align-self: flex-end;
    }

    .header-ui-segment-btn:not(.header-ui-segment-btn--icon) {
        flex: 0 1 auto;
        width: auto;
        min-width: 0;
    }

    .header-mobile-drawer-extras {
        margin-top: 10px;
        padding-top: 12px;
        border-top: 1px solid var(--border);
        width: 100%;
    }

    .header-mobile-drawer-site-mgmt .site-management-sidenav {
        display: flex;
        flex-direction: column;
        gap: 6px;
        width: 100%;
    }

    .header-mobile-drawer-site-mgmt .site-management__tab {
        display: block;
        width: 100%;
        text-align: left;
    }

    .site-header.site-header--simple-ui .nav.nav-main {
        justify-content: flex-start;
        max-width: none;
    }
}

.footer-inner {
    padding: 14px 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 9px;
    flex-wrap: wrap;
}

/* Телефон и e-mail в подвале — одна строка справа */
.footer-contact-cluster {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 8px 16px;
    margin-left: auto;
    text-align: left;
}

.info-title {
    font-weight: 800;
    margin-bottom: 4px;
}

.info-text {
    line-height: 1.45;
}

/* «О нас»: e-mail — отдельный блок как у телефона, адрес крупнее */
.contact-block-email {
    margin-top: 14px;
}

.contact-block-email__value,
.contact-block-email__value .link {
    font-size: 1.125rem;
    font-weight: 600;
}

.muted { color: var(--muted); }
.small { font-size: 10px; }
.link { color: var(--primary-dark); text-decoration: none; }
.link:hover { text-decoration: underline; }

.map-wrap {
    margin-top: 14px;
}

.map-title {
    font-weight: 800;
    margin-bottom: 6px;
}

.map {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--card);
}

.map iframe {
    width: 100%;
    height: 240px;
    border: 0;
}

.contact-locations {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.contact-location-btn {
    text-align: left;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--field-surface);
    color: var(--text);
    padding: 6px 8px;
    cursor: pointer;
}

.contact-location-btn.is-selected {
    border-color: rgba(14, 165, 233, 0.55);
    background: rgba(14, 165, 233, 0.08);
}

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

.price-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 10px;
}

.price-card-title {
    font-weight: 900;
    letter-spacing: 0.4px;
    text-align: center;
    margin-bottom: 8px;
}

.price-image {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 9px;
}

.price-note {
    margin-top: 8px;
}

@media (max-width: 860px) {
    .price-grid { grid-template-columns: 1fr; }
}

.services-body-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
    margin: 10px 0 6px;
}

.services-body-toolbar__label {
    font-weight: 700;
}

.services-body-toolbar__select {
    min-width: 150px;
    max-width: 100%;
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--field-surface);
    color: var(--text);
    font-size: 11px;
}

.price-table-wrap {
    margin: 14px 0 9px;
}

.price-table-title {
    margin: 0 0 8px;
    font-size: 14px;
}

.price-section {
    margin: 9px 0;
    padding: 9px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--card-bg);
    color: var(--text);
}

.price-section-title {
    font-weight: 900;
    margin-bottom: 6px;
    text-align: center;
}

.price-table-scroll {
    overflow-x: auto;
}

.price-table td.price-cell--all-bodies {
    text-align: center;
    white-space: normal;
}

.price-table__th-price {
    min-width: 10rem;
}

.price-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 570px;
}

.price-table--single-col {
    min-width: 0;
    table-layout: fixed;
}

.price-table--single-col th[data-price-col="name"],
.price-table--single-col td[data-price-col="name"] {
    width: 62%;
}

.price-table-scroll--filtered .price-table--by-body {
    min-width: 0;
}

.price-table th,
.price-table td {
    padding: 8px 8px;
    border-top: 1px solid var(--border);
    vertical-align: top;
    white-space: nowrap;
}

.price-table th {
    text-align: left;
    font-size: 10px;
    color: var(--muted);
    border-top: 0;
}

.price-table th[data-price-col]:not([data-price-col="name"]),
.price-table td[data-price-col]:not([data-price-col="name"]):not(.price-name):not(.price-cell--all-bodies) {
    text-align: right;
}

.price-table--single-col .price-cell-value {
    text-align: right;
}

.price-name {
    white-space: normal;
    min-width: 210px;
}

.price-table--single-col .price-name {
    min-width: 0;
}

.form-card {
    padding: 14px;
}

.form-row {
    margin-bottom: 10px;
}

.form-row label {
    display: block;
    font-weight: 700;
    margin-bottom: 4px;
}

.form-help {
    margin-bottom: 9px;
}

.form-submit-btn {
    margin-top: 8px;
}

.form-error-summary {
    margin-bottom: 8px;
    font-size: 10px;
    color: var(--danger-text);
}

/* Онлайн-запись: всплывающее сообщение об ошибках (справа внизу) */
.bk-booking-toast {
    position: fixed;
    bottom: 1.25rem;
    right: 1.25rem;
    z-index: 10050;
    max-width: min(315px, calc(100vw - 2rem));
    padding: 9px 12px;
    border-radius: 9px;
    background: #0f172a;
    color: #f8fafc;
    font-size: 10px;
    line-height: 1.45;
    box-shadow: 0 9px 30px rgba(15, 23, 42, 0.35);
    border: 1px solid rgba(248, 250, 252, 0.12);
    opacity: 0;
    transform: translateY(9px);
    transition: opacity 0.22s ease, transform 0.22s ease;
    pointer-events: none;
}

.bk-booking-toast.bk-booking-toast--visible {
    opacity: 1;
    transform: translateY(0);
}

.form-field-error {
    margin-top: 3px;
    font-size: 10px;
    color: var(--danger-text);
}

.section-title-compact {
    margin-top: 0;
}

.stack-list {
    display: grid;
    gap: 8px;
}

.form-inline-top {
    margin-top: 8px;
}

.spacer-12 {
    height: 9px;
}

.car-title {
    font-weight: 800;
}

.booking-row-header {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
}

.booking-service-line {
    margin-top: 4px;
}

/* Единый вид полей ввода (страница «Управление автомойкой» и др.) */
.form-card input:not([type]),
.form-card input[type="text"],
.form-card input[type="tel"],
.form-card input[type="email"],
.form-card input[type="password"],
.form-card input[type="number"],
.form-card input[type="date"],
.form-card input[type="time"],
.form-card input[type="datetime-local"],
.form-card input[type="search"],
.form-card select,
.form-card textarea {
    width: 100%;
    max-width: 100%;
    padding: 8px 9px;
    border: 1px solid var(--border);
    border-radius: 9px;
    background-color: var(--field-surface);
    font: inherit;
    color: var(--text);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.form-card select {
    cursor: pointer;
    appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%),
        linear-gradient(135deg, var(--muted) 50%, transparent 50%);
    background-position: calc(100% - 14px) calc(50% - 2px), calc(100% - 10px) calc(50% - 2px);
    background-size: 4px 4px, 4px 4px;
    background-repeat: no-repeat;
    padding-right: 24px;
}

.form-card input:focus-visible,
.form-card textarea:focus-visible {
    outline: none;
    border-color: rgba(14, 165, 233, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
    background-color: var(--field-surface-focus);
}

.form-card select:focus-visible {
    outline: none;
    border-color: rgba(14, 165, 233, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
    background-color: var(--field-surface-focus);
}

.form-row:has(.form-field-error) input,
.form-row:has(.form-field-error) select,
.form-row:has(.form-field-error) textarea {
    border-color: var(--danger-border);
}

.form-card input:disabled,
.form-card select:disabled,
.form-card textarea:disabled {
    opacity: 0.68;
    cursor: not-allowed;
    background-color: var(--field-surface-disabled);
}

.form-card textarea {
    resize: vertical;
    min-height: 66px;
}

.form-card input::placeholder,
.form-card textarea::placeholder,
.leader-settings-main input::placeholder,
.leader-settings-main textarea::placeholder {
    color: var(--muted);
}

/* Регистрация: «Тип клиента» + варианты — строго одна строка */
.register-kind-row {
    margin-bottom: 1rem;
}
.register-kind-line {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem 0.75rem;
    width: 100%;
    min-width: 0;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}

/* Вход: тумблер без подписи слева — по центру карточки */
.login-kind-line--centered {
    justify-content: center;
}

.login-kind-line--centered .register-kind-toggle-wrap {
    flex: 0 1 auto;
    width: min(100%, 58rem);
    max-width: min(100%, 58rem);
}

/* Вход: широкая полоса под длинные подписи (сегменты 50/50 — см. ниже после базового правила) */
.login-kind-line--centered .register-kind-toggle-wrap > div {
    min-width: min(100%, 48rem);
}
.login-kind-line--centered .register-kind-toggle-wrap label {
    white-space: normal;
    line-height: 1.25;
    padding: 0.55rem 0.75rem;
}

.register-kind-label {
    font-weight: 600;
    margin: 0;
    font-size: 0.95rem;
    color: var(--text);
    flex: 0 0 auto;
    white-space: nowrap;
}
.register-kind-row:has(.register-kind-errors) .register-kind-line {
    margin-bottom: 4px;
}
.register-kind-errors {
    display: block;
    width: 100%;
    margin-top: 0;
}
.register-kind-toggle-wrap {
    flex: 1 1 auto;
    min-width: 0;
    width: 100%;
    max-width: 44rem;
}
/* Django 4.2+: RadioSelect — контейнер <div id="…">, опции — вложенные <div>, не <ul><li> */
.register-kind-toggle-wrap > div {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    min-width: min(100%, 34rem);
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
    background: var(--register-kind-track-bg, rgba(248, 250, 252, 0.95));
    box-sizing: border-box;
}
.register-kind-toggle-wrap > div > div {
    margin: 0;
    padding: 0;
    display: flex;
    flex: 1 1 0%;
    min-width: 12.5rem;
    align-items: stretch;
}
/* Вход: оба сегмента строго одинаковой ширины (перекрывает min-width: 12.5rem у регистрации) */
.login-kind-line--centered .register-kind-toggle-wrap > div > div {
    flex: 1 1 0%;
    min-width: 0;
}
.register-kind-toggle-wrap > div > div + div {
    border-left: 1px solid var(--border);
}
/* Старый вывод <ul><li> (если вдруг другой виджет) */
.register-kind-toggle-wrap > ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    min-width: min(100%, 34rem);
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
    background: var(--register-kind-track-bg, rgba(248, 250, 252, 0.95));
    box-sizing: border-box;
}
.register-kind-toggle-wrap > ul > li {
    margin: 0;
    padding: 0;
    display: flex;
    flex: 1 1 0%;
    min-width: 12.5rem;
    align-items: stretch;
}
.register-kind-toggle-wrap > ul > li + li {
    border-left: 1px solid var(--border);
}
.register-kind-toggle-wrap label {
    position: relative;
    box-sizing: border-box;
    flex: 1 1 auto;
    align-self: stretch;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 2.2rem;
    min-width: 0;
    margin: 0;
    padding: 0.35rem 0.75rem;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.875rem;
    line-height: 1.2;
    white-space: nowrap;
    text-align: center;
    color: var(--text);
    background: transparent;
    user-select: none;
    transition: background 0.15s ease, color 0.15s ease;
}
/* Фон сегмента на обёртке — без щели снизу у подсветки */
.register-kind-toggle-wrap > div > div:hover:not(:has(input:checked)) {
    background: var(--register-kind-segment-hover-bg, rgba(14, 165, 233, 0.08));
}
.register-kind-toggle-wrap > div > div:has(input:checked) {
    background: var(--accent, #0ea5e9);
}
.register-kind-toggle-wrap > div > div:has(input:checked) label {
    color: #fff;
}
.register-kind-toggle-wrap > div > div:has(input:checked):hover {
    background: #0284c7;
}
.register-kind-toggle-wrap > ul > li:hover:not(:has(input:checked)) {
    background: var(--register-kind-segment-hover-bg, rgba(14, 165, 233, 0.08));
}
.register-kind-toggle-wrap > ul > li:has(input:checked) {
    background: var(--accent, #0ea5e9);
}
.register-kind-toggle-wrap > ul > li:has(input:checked) label {
    color: #fff;
}
.register-kind-toggle-wrap > ul > li:has(input:checked):hover {
    background: #0284c7;
}
.register-kind-toggle-wrap input[type="radio"] {
    position: absolute;
    opacity: 0.001;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    cursor: pointer;
}

/* Organizations page */
.organizations-table-wrap {
    overflow-x: auto;
}
.organizations-table {
    width: 100%;
    border-collapse: collapse;
}
.organizations-table th,
.organizations-table td {
    text-align: left;
    padding: 6px;
}
.organizations-table tbody td {
    border-top: 1px solid #e5e7eb;
}
.organizations-table__row {
    cursor: pointer;
}
.organizations-table__row:hover {
    background: rgba(14, 165, 233, 0.08);
}

/* Organizations modal */
.organizations-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    background: rgba(15, 23, 42, 0.45);
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
}
.organizations-modal {
    width: min(680px, 100%);
    max-height: 90vh;
    overflow: auto;
}
.organizations-modal__title {
    margin-top: 0;
}
.organizations-modal__row {
    display: grid;
    gap: 9px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.organizations-modal__row--triple {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.organizations-modal__input-readonly {
    background: rgba(15, 23, 42, 0.06);
    cursor: default;
    color: inherit;
}
@media (max-width: 760px) {
    .organizations-modal__row {
        grid-template-columns: 1fr;
    }
    .organizations-modal__row--triple {
        grid-template-columns: 1fr;
    }
}
.organizations-modal__actions {
    display: flex;
    gap: 8px;
    margin-top: 9px;
}
.register-kind-toggle-wrap label:focus-within {
    outline: 2px solid var(--accent, #0ea5e9);
    outline-offset: 2px;
    z-index: 1;
}

/* Регистрация: ФИО + email в одну строку, пароль с подсказками */
.reg-fio-email-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0 1rem;
    align-items: start;
    margin-bottom: 10px;
}
@media (max-width: 640px) {
    .reg-fio-email-grid {
        grid-template-columns: 1fr;
    }
}
.reg-fio-email-grid .form-row {
    margin-bottom: 0;
}
.reg-password-line {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: stretch;
    width: 100%;
}
.reg-password-line .js-reg-password,
.reg-password-line input[type="password"],
.reg-password-line input[type="text"] {
    flex: 1 1 auto;
    min-width: 0;
    padding-right: 33px;
}
.reg-toggle-pass {
    position: absolute;
    top: 50%;
    right: 6px;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 27px;
    height: 27px;
    padding: 0;
    color: var(--muted);
}
.reg-toggle-pass:hover {
    color: var(--text);
}
/* Только одна иконка: без класса — пароль скрыт (зачёркнутый глаз); с классом — показан (открытый глаз). */
.reg-toggle-pass .reg-eye-icons {
    position: relative;
    width: 15px;
    height: 15px;
    flex-shrink: 0;
}
.reg-toggle-pass .reg-eye-icons svg {
    position: absolute;
    inset: 0;
    display: block;
}
.reg-toggle-pass:not(.reg-toggle-pass--reveal) .reg-eye-open {
    display: none !important;
}
.reg-toggle-pass:not(.reg-toggle-pass--reveal) .reg-eye-off {
    display: block !important;
}
.reg-toggle-pass.reg-toggle-pass--reveal .reg-eye-open {
    display: block !important;
}
.reg-toggle-pass.reg-toggle-pass--reveal .reg-eye-off {
    display: none !important;
}
.reg-pass-hint {
    list-style: none;
    margin: 6px 0 0;
    padding: 0;
    font-size: 9px;
    line-height: 1.45;
    color: var(--muted);
}
.reg-pass-hint li {
    margin: 2px 0;
    padding-left: 1.1em;
    position: relative;
}
.reg-pass-hint li::before {
    content: "—";
    position: absolute;
    left: 0;
    color: var(--border);
}
.reg-pass-hint li.reg-pass-hint__ok {
    color: #15803d;
}
.reg-pass-hint li.reg-pass-hint__ok::before {
    content: "✓";
    color: #15803d;
}
.reg-password2-row--error label {
    color: var(--danger-text);
}
.form-card input.reg-input--error,
.form-card .reg-password-line input.reg-input--error {
    border-color: var(--danger-border) !important;
}
.form-card input.reg-input--ok,
.form-card .reg-password-line input.reg-input--ok {
    border-color: rgba(34, 197, 94, 0.7) !important;
    box-shadow: 0 0 0 1px rgba(34, 197, 94, 0.15);
}
p.reg-pass-mismatch.form-field-error {
    margin-top: 4px;
    margin-bottom: 0;
    color: var(--danger-text);
}
.reg-phone-taken,
.reg-inn-taken {
    margin-top: 6px;
    line-height: 1.45;
    font-size: 1rem;
    font-weight: 600;
}

.reg-phone-telegram-line {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 8px;
    width: 100%;
}

.reg-phone-telegram-line .reg-phone-input-wrap {
    flex: 1 1 auto;
    min-width: 0;
}

.reg-telegram-verify-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 0 9px;
    min-height: 2.3rem;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 700;
    border: 1px solid transparent;
    cursor: pointer;
    white-space: nowrap;
    box-sizing: border-box;
    text-decoration: none;
    font-family: inherit;
}

.reg-telegram-verify-btn__icon {
    flex-shrink: 0;
    display: block;
}

.reg-telegram-verify-btn--wait {
    color: var(--muted);
    background: rgba(148, 163, 184, 0.2);
    border-color: var(--border);
    cursor: not-allowed;
    opacity: 0.85;
}

.reg-telegram-verify-btn--need {
    color: #fff;
    background: var(--danger);
    border-color: var(--danger-strong);
}

.reg-telegram-verify-btn--need:hover {
    background: var(--danger-strong);
}

.reg-telegram-verify-btn--done {
    color: #fff;
    background: #15803d;
    border-color: #166534;
    cursor: default;
    pointer-events: none;
}

.reg-telegram-verify-btn--done:disabled {
    opacity: 1;
}

@media (max-width: 540px) {
    .reg-phone-telegram-line {
        flex-wrap: wrap;
    }

    .reg-telegram-verify-btn {
        width: 100%;
        min-height: 2.2rem;
    }
}

.reg-business-entity-row {
    margin-bottom: 10px;
}

/* React-экран "Управление автомойкой": единый мягкий стиль всех полей */
.leader-settings-main input[type="text"],
.leader-settings-main input:not([type]),
.leader-settings-main input[type="tel"],
.leader-settings-main input[type="email"],
.leader-settings-main input[type="password"],
.leader-settings-main input[type="number"],
.leader-settings-main input[type="date"],
.leader-settings-main input[type="time"],
.leader-settings-main input[type="datetime-local"],
.leader-settings-main input[type="search"],
.leader-settings-main select,
.leader-settings-main textarea,
.leader-modal--staff input[type="text"],
.leader-modal--staff input:not([type]),
.leader-modal--staff input[type="tel"],
.leader-modal--staff input[type="email"],
.leader-modal--staff input[type="number"],
.leader-modal--staff select,
.leader-modal--staff textarea {
    border-radius: 9px;
    border: 1px solid var(--border);
    background-color: var(--field-surface);
    padding: 7px 8px;
    line-height: 1.3;
    font: inherit;
    color: var(--text);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

/* Те же поля в таблицах сотрудников (часть инпутов рендерится без атрибута type) */
.leader-staff-table input:not([type]) {
    border-radius: 9px;
    border: 1px solid var(--border);
    background-color: var(--field-surface);
    padding: 6px 8px;
    font: inherit;
    color: var(--text);
}

.leader-settings-main input:focus-visible,
.leader-settings-main select:focus-visible,
.leader-settings-main textarea:focus-visible,
.leader-modal--staff input:focus-visible,
.leader-modal--staff select:focus-visible,
.leader-modal--staff textarea:focus-visible {
    outline: none;
    border-color: rgba(14, 165, 233, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
    background-color: var(--field-surface-focus);
}

.leader-checkbox-inline {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.5rem;
    cursor: pointer;
    font-weight: normal;
}

.leader-checkbox-inline input[type="checkbox"] {
    margin-top: 0.2rem;
    flex-shrink: 0;
}

.leader-org-actual-same-checkbox {
    margin-top: 0.35rem;
    margin-bottom: 0.15rem;
}

.leader-org-settlements-card {
    margin-top: 1.25rem;
}

.leader-org-settlements-card__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 9px;
    margin-bottom: 10px;
}

.leader-org-settlements-card__title {
    margin: 0;
}

.leader-settlements-table__td-account {
    cursor: pointer;
    vertical-align: middle;
}

.leader-settlements-table__td-account:focus-visible {
    outline: 2px solid rgba(14, 165, 233, 0.55);
    outline-offset: 2px;
}

.leader-settlements-table__line {
    text-decoration: underline;
    text-decoration-style: dotted;
    text-underline-offset: 2px;
}

.leader-settlements-table__col-primary {
    width: 75px;
    text-align: center;
    vertical-align: middle;
}

.leader-settlements-table__col-actions {
    width: 90px;
    text-align: right;
    vertical-align: middle;
}

.leader-settlements-table__col-primary--readonly {
    text-align: center;
    font-size: 10px;
}

.leader-settlements-primary-badge {
    display: inline-block;
    padding: 2px 6px;
    border-radius: 749px;
    font-weight: 600;
    font-size: 9px;
    color: var(--primary-dark, #0369a1);
    background: rgba(14, 165, 233, 0.12);
    border: 1px solid rgba(14, 165, 233, 0.35);
}

.leader-settlements-inline-form {
    display: inline-block;
    margin: 0;
}

.leader-settlements-removed-details {
    margin-top: 1.25rem;
    border-top: 1px solid var(--border);
    padding-top: 9px;
}

.leader-settlements-removed-summary {
    cursor: pointer;
    font-weight: 600;
    list-style: none;
}

.leader-settlements-removed-summary::-webkit-details-marker {
    display: none;
}

.leader-settlement-bic-hint--error {
    color: var(--danger-text);
}

.leader-settlement-bic-row .leader-settlement-bic-wrap {
    position: relative;
    max-width: 100%;
}

.leader-settlement-bic-suggestions {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 3px);
    z-index: 10060;
    max-height: 165px;
    overflow-y: auto;
    margin: 0;
    padding: 4px 0;
    list-style: none;
    border-radius: 9px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 9px 21px rgba(15, 23, 42, 0.18);
}

.leader-settlement-bic-suggestions__item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    width: 100%;
    margin: 0;
    padding: 6px 9px;
    border: none;
    background: transparent;
    font: inherit;
    text-align: left;
    color: var(--text);
    cursor: pointer;
    transition: background-color 0.12s ease;
}

.leader-settlement-bic-suggestions__item:hover,
.leader-settlement-bic-suggestions__item--active {
    background: rgba(14, 165, 233, 0.1);
}

.leader-settlement-bic-suggestions__bic {
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
}

.leader-settlement-bic-suggestions__name {
    font-size: 10px;
    color: var(--muted);
    line-height: 1.35;
}

/* Модалки сотрудников и форма зарплаты админа — тот же вид полей, что и .form-card */
.leader-modal--staff .leader-staff-field,
.leader-admin-salary-form .leader-staff-field {
    width: 100%;
    max-width: 100%;
    padding: 8px 9px;
    border: 1px solid var(--border);
    border-radius: 9px;
    background-color: var(--field-surface);
    font: inherit;
    color: var(--text);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.leader-modal--staff select.leader-staff-field,
.leader-admin-salary-form select.leader-staff-field {
    cursor: pointer;
    appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%),
        linear-gradient(135deg, var(--muted) 50%, transparent 50%);
    background-position: calc(100% - 14px) calc(50% - 2px), calc(100% - 10px) calc(50% - 2px);
    background-size: 4px 4px, 4px 4px;
    background-repeat: no-repeat;
    padding-right: 24px;
}

.leader-modal--staff .leader-staff-field:focus-visible,
.leader-admin-salary-form .leader-staff-field:focus-visible {
    outline: none;
    border-color: rgba(14, 165, 233, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
    background-color: var(--field-surface-focus);
}

.leader-modal--staff .leader-staff-field:disabled,
.leader-admin-salary-form .leader-staff-field:disabled {
    opacity: 0.68;
    cursor: not-allowed;
    background-color: var(--field-surface-disabled);
}

.leader-staff-footer-actions {
    display: flex;
    align-items: center;
    gap: 9px;
    flex-wrap: wrap;
    margin-top: 12px;
}

/* Таблицы настроек: те же поля, что и в карточках */
.leader-staff-table input[type="text"],
.leader-staff-table input[type="number"],
.leader-staff-table input[type="time"],
.leader-staff-table input[type="date"] {
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--field-surface);
    font: inherit;
    color: var(--text);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.leader-staff-table input:focus-visible {
    outline: none;
    border-color: rgba(14, 165, 233, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.18);
    background-color: var(--field-surface-focus);
}

.leader-staff-table input[type="checkbox"] {
    width: 1.15em;
    height: 1.15em;
    min-width: 1.15em;
    margin: 0;
    vertical-align: middle;
    cursor: pointer;
    accent-color: var(--primary);
    border-radius: 3px;
}

.leader-staff-table input[type="number"] {
    width: 100%;
    min-width: 68px;
}

.leader-staff-table input[type="time"] {
    width: 100%;
    min-width: 82px;
}

/* Расписание → вкладка «Услуги»: заголовки колонок */
.booking-services-columns {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-bottom: 6px;
    font-size: 9px;
    font-weight: 700;
    color: var(--muted);
}

.booking-services-columns__col--service {
    flex: 1 1 0;
    min-width: 0;
    text-align: center;
}

.booking-services-columns__col--price {
    flex: 0 0 82px;
    text-align: center;
}

.booking-services-columns__col--discount {
    flex: 0 0 82px;
    text-align: center;
}

.booking-services-columns__col--sum {
    flex: 0 0 82px;
    text-align: center;
}

.booking-services-columns__col--washer {
    flex: 0 0 120px;
    text-align: center;
}

.booking-services-columns__col--del {
    flex: 0 0 auto;
    width: 27px;
    min-width: 27px;
}

.schedule-modal-tab--clarify {
    color: var(--danger-text) !important;
}

/* Расписание → модалка "Информация по записи" → ввод фактической цены услуги */
.booking-service-price-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
    min-width: 0;
}

.booking-service-combo {
    position: relative;
    flex: 1 1 0;
    min-width: 0;
}

.booking-service-dropdown {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    margin-top: 3px;
    max-height: min(40vh, 210px);
    overflow-y: auto;
    z-index: 40;
    background: var(--card-bg, var(--card));
    border: 1px solid var(--border);
    border-radius: 9px;
    box-shadow: 0 9px 30px rgba(15, 23, 42, 0.14);
    padding: 4px 0;
}

.booking-service-dropdown.booking-service-dropdown--up {
    top: auto;
    bottom: 100%;
    margin-top: 0;
    margin-bottom: 3px;
}

#booking-info-modal .booking-modal__services-scroll.booking-modal__services-scroll--dropdown-open {
    overflow: visible;
    z-index: 5;
    position: relative;
}

.booking-service-dropdown__section {
    font-size: 9px;
    font-weight: 700;
    color: var(--muted);
    padding: 6px 9px 3px;
    border-top: 1px solid var(--border);
    line-height: 1.35;
}

.booking-service-dropdown__section:first-child {
    border-top: 0;
}

.booking-service-dropdown__item {
    display: block;
    width: 100%;
    text-align: left;
    padding: 6px 9px;
    border: 0;
    background: transparent;
    cursor: pointer;
    font: inherit;
}

.booking-service-dropdown__item:hover,
.booking-service-dropdown__item.booking-service-dropdown__item--active {
    background: rgba(14, 165, 233, 0.08);
}

.booking-service-dropdown__name {
    font-weight: 600;
    color: var(--text);
}

.booking-service-dropdown__empty {
    padding: 8px 9px;
    font-size: 10px;
}

.booking-service-washer-select {
    width: 120px;
    flex: 0 0 120px;
    min-width: 90px;
}

.booking-service-price-row > .btn {
    flex: 0 0 auto;
}

.booking-service-title-input--readonly {
    background: rgba(15, 23, 42, 0.05);
    color: #334155;
}

.booking-service-title-input {
    flex: 1 1 auto;
    min-width: 0;
    width: 100%;
}

.booking-service-price-input {
    width: 82px;
    flex: 0 0 82px;
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.booking-service-discount-input,
.booking-service-sum-input {
    color: #334155;
}

.booking-service-price-input--readonly {
    background: rgba(15, 23, 42, 0.05);
    color: #334155;
}

.booking-total-clarify {
    color: var(--danger-text);
    font-weight: 700;
}

.booking-service-price-currency {
    flex: 0 0 auto;
    min-width: 1ch;
    opacity: 0.9;
}

.leader-layout {
    margin-top: 10px;
    display: grid;
    grid-template-columns: minmax(210px, 1fr) minmax(285px, 1.2fr);
    gap: 10px;
}

.leader-layout--single {
    grid-template-columns: 1fr;
}

/* Реквизиты: без display:grid родителя — карточки на всю ширину main (иначе при двух колонках .leader-layout поля grid-2 = четверть ширины) */
.leader-requisites-stack {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    min-width: 0;
}

.leader-settings-shell {
    display: grid;
    grid-template-columns: minmax(150px, 180px) minmax(0, 1fr);
    gap: 0 16px;
    align-items: start;
    margin-top: 10px;
}

.leader-settings-sidebar {
    position: sticky;
    top: calc(env(safe-area-inset-top, 0px) + var(--leader-sidebar-under-header));
    align-self: start;
    /* Ниже .site-header (10), выше контента main — без налезания на шапку по z-index */
    z-index: 8;
    min-height: 0;
    /* Вся рамка карточки — одна зона скролла; высота = отступ под шапку до низа вьюпорта */
    max-height: calc(
        100vh - env(safe-area-inset-top, 0px) - var(--leader-sidebar-under-header) - env(safe-area-inset-bottom, 0px)
    );
    max-height: calc(
        100dvh - env(safe-area-inset-top, 0px) - var(--leader-sidebar-under-header) - env(safe-area-inset-bottom, 0px)
    );
    overflow-y: auto;
    overscroll-behavior-y: contain;
    padding: 10px 10px 12px;
    border: 1px solid var(--leader-nav-sidebar-border, var(--border));
    border-radius: var(--radius);
    background: var(--leader-nav-sidebar-bg);
}

/* Кнопки в меню: сброс UA (в тёмной теме иначе «серые прямоугольники»). */
button.leader-settings-nav-primary__link,
button.leader-settings-nav-secondary__link,
button.leader-settings-nav-tertiary__link {
    appearance: none;
    -webkit-appearance: none;
    margin: 0;
    font: inherit;
    cursor: pointer;
}

button.leader-settings-nav-primary__link,
button.leader-settings-nav-secondary__link {
    width: 100%;
    text-align: left;
    background: transparent;
    color: var(--text);
}

.leader-settings-nav-primary {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.leader-settings-nav-primary__link {
    display: block;
    padding: 8px 9px;
    border-radius: 9px;
    text-decoration: none;
    color: var(--text);
    font-weight: 700;
    font-size: 10px;
    border: 1px solid transparent;
    transition: border-color 0.15s ease, background-color 0.15s ease;
}

.leader-settings-nav-primary__link:hover {
    border-color: var(--border);
    background: var(--leader-nav-primary-hover);
}

.leader-settings-nav-primary__link.is-active {
    background: var(--leader-nav-active-bg);
    border-color: var(--leader-nav-active-border);
    color: var(--primary-dark);
}

.leader-settings-nav-secondary {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.leader-settings-nav-secondary__link {
    display: block;
    padding: 6px 8px 6px 9px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--text);
    font-size: 10px;
    font-weight: 600;
    border: 1px solid transparent;
}

.leader-settings-nav-secondary__link:hover {
    background: var(--leader-nav-secondary-hover);
}

.leader-settings-nav-secondary__link.is-active {
    background: var(--leader-nav-active-bg-soft);
    color: var(--primary-dark);
    border-color: var(--leader-nav-active-border-soft);
}

/* Подстраницы зарплаты (Выплаты / Авансы / …): в основной колонке — в ряд; иначе width:100% у кнопок даёт столбец */
.leader-settings-nav-secondary--payroll-tabs {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-top: 0;
    margin-bottom: 12px;
    padding-top: 0;
    border-top: none;
}

.leader-settings-nav-secondary--payroll-tabs button.leader-settings-nav-secondary__link {
    width: auto;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

@media (max-width: 900px) {
    .leader-settings-nav-secondary--payroll-tabs {
        flex-direction: column;
        align-items: stretch;
    }

    .leader-settings-nav-secondary--payroll-tabs button.leader-settings-nav-secondary__link {
        width: 100%;
        justify-content: flex-start;
        text-align: left;
    }
}

.leader-settings-nav-tertiary {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
}

.leader-settings-nav-tertiary__link {
    display: inline-block;
    padding: 6px 10px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--text);
    font-size: 10px;
    font-weight: 700;
    border: 1px solid var(--border);
    background: var(--leader-nav-tertiary-bg);
}

.leader-settings-nav-tertiary__link:hover {
    background: var(--leader-nav-tertiary-hover);
}

.leader-settings-nav-tertiary__link.is-active {
    background: var(--leader-nav-active-bg);
    color: var(--primary-dark);
    border-color: var(--leader-nav-active-border);
}

.leader-settings-prices__block-title--first {
    margin-top: 0;
}

#leader-price-excel-label.btn {
    max-width: min(100%, 285px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: middle;
}

.leader-settings-main {
    min-width: 0;
}

/* Сайдбар и контент в одной сетке: у .leader-settings-shell уже есть margin-top;
   не дублировать отступ у первого блока с .leader-layout / реквизитами — иначе правая колонка (Маркетинг и др.) визуально ниже. */
.leader-settings-main > .leader-layout:first-child {
    margin-top: 0;
}

.leader-settings-main > .leader-requisites-stack:first-child {
    margin-top: 0;
}

.leader-settings-prices__block-title {
    margin-top: 16px;
    margin-bottom: 9px;
}

.leader-settings-prices .leader-price-excel-row + .leader-settings-prices__block-title {
    margin-top: 14px;
}

@media (max-width: 900px) {
    .leader-settings-shell {
        grid-template-columns: 1fr;
    }

    /* Боковое меню только в гамбургере шапки */
    .leader-settings-shell .leader-settings-sidebar {
        display: none !important;
    }

    .header-mobile-nav-tree {
        width: 100%;
    }

    .header-mobile-nav-tree__root {
        list-style: none;
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 5px;
        width: 100%;
    }

    .header-mobile-nav-tree__branch-title {
        font-size: 10px;
        font-weight: 800;
        letter-spacing: 0.02em;
        color: var(--muted);
        margin: 8px 0 4px;
        padding: 0;
    }

    .header-mobile-nav-tree__lvl1 {
        list-style: none;
        margin: 0 0 4px 0;
        padding: 0 0 0 12px;
        border-left: 2px solid color-mix(in srgb, var(--border) 80%, var(--primary) 22%);
    }

    .header-mobile-nav-tree__lvl1 > li {
        margin: 2px 0;
    }

    .header-mobile-nav-tree__group {
        margin: 6px 0 2px;
    }

    .header-mobile-nav-tree__group-title {
        font-size: 10px;
        font-weight: 700;
        color: var(--muted);
        margin: 4px 0 3px;
    }

    .header-mobile-nav-tree__lvl2 {
        list-style: none;
        margin: 0 0 6px 0;
        padding: 0 0 0 12px;
        border-left: 1px solid var(--border);
    }

    .header-mobile-nav-tree__lvl2 > li {
        margin: 2px 0;
    }

    .header-mobile-nav-tree .nav-link {
        display: block;
        width: 100%;
        text-align: left;
        box-sizing: border-box;
    }
}

.leader-page-text {
    margin-bottom: 10px;
}

.leader-appearance-form {
    position: relative;
}

.leader-appearance-implicit-save {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    opacity: 0;
    pointer-events: none;
}

.leader-appearance-brand-row {
    display: grid;
    grid-template-columns: minmax(105px, auto) 1fr;
    gap: 18px;
    align-items: start;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}

.leader-appearance-brand-col--text {
    min-width: 0;
}

@media (max-width: 720px) {
    .leader-appearance-brand-row {
        grid-template-columns: 1fr;
    }
}

.leader-appearance-block {
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}

.leader-appearance-block__title {
    font-weight: 800;
    font-size: 11px;
    margin-bottom: 8px;
}

/* Маркетинг: блок дат под общим заголовком */
.leader-marketing-period-block {
    margin-top: 2px;
}

.leader-marketing-period-block .leader-appearance-block__title {
    margin-bottom: 6px;
}

.leader-marketing-period-grid {
    margin-bottom: 0;
}

.leader-marketing-time-hint {
    margin-top: 3px;
    margin-bottom: 8px;
}

.leader-marketing-no-locations {
    margin-bottom: 9px;
}

.leader-marketing-address-hint {
    margin: 3px 0 6px;
}

/* Маркетинг: адреса и выбор услуг. Нерабочие дни: отдельный блок + боксы под адресом. */
.leader-marketing-address-combobox,
.leader-marketing-services-combobox,
.leader-dayoff-loc-combobox {
    position: relative;
    max-width: 100%;
}

.leader-marketing-address-combobox__control,
.leader-marketing-services-combobox__control,
.leader-dayoff-loc-combobox__control {
    display: flex;
    align-items: stretch;
    gap: 0;
    margin-top: 3px;
}

.leader-marketing-address-combobox__input,
.leader-marketing-services-combobox__input,
.leader-dayoff-loc-combobox__input {
    flex: 1;
    min-width: 0;
    cursor: pointer;
    border-radius: 3px 0 0 3px;
    border-right: none;
}

.leader-marketing-address-combobox__toggle,
.leader-marketing-services-combobox__toggle,
.leader-dayoff-loc-combobox__toggle {
    flex: 0 0 auto;
    border-radius: 0 3px 3px 0;
    border: 1px solid var(--border);
    border-left: none;
    padding: 0 8px;
    line-height: 1.2;
    min-height: 28px;
}

.leader-marketing-address-combobox__panel,
.leader-marketing-services-combobox__panel,
.leader-dayoff-loc-combobox__panel {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 3px);
    z-index: 40;
    max-height: 210px;
    overflow-y: auto;
    background: var(--surface, #fff);
    border: 1px solid var(--border);
    border-radius: 4px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.12);
    padding: 4px 0;
}

.leader-marketing-address-combobox__row,
.leader-marketing-services-combobox__row,
.leader-dayoff-loc-combobox__row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 9px;
    margin: 0;
    cursor: pointer;
    font-weight: normal;
}

.leader-marketing-address-combobox__row:hover,
.leader-marketing-services-combobox__row:hover,
.leader-dayoff-loc-combobox__row:hover {
    background: rgba(0, 0, 0, 0.04);
}

.leader-marketing-services-combobox__panel.leader-marketing-services-tree {
    max-height: min(60vh, 315px);
}

/* Портал дерева услуг внутри dialog: не обрезается формой и подвалом модалки */
.leader-marketing-services-popover {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
    background: var(--surface, #fff);
    border: 1px solid var(--border);
    border-radius: 4px;
    box-shadow: 0 8px 21px rgba(0, 0, 0, 0.18);
}

.leader-marketing-services-search {
    padding: 6px 6px 0;
    border-bottom: 1px solid var(--border);
    background: var(--surface, #fff);
}

.leader-marketing-services-search__input {
    width: 100%;
    min-height: 26px;
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 4px 8px;
    box-sizing: border-box;
    font: inherit;
}

.leader-marketing-services-tree__empty {
    padding: 8px 9px;
}

.leader-marketing-services-popover .leader-marketing-services-combobox__panel {
    position: static;
    left: auto;
    right: auto;
    top: auto;
    z-index: auto;
    flex: 1 1 auto;
    min-height: 0;
    max-height: none !important;
    overflow-y: auto;
    border: none;
    border-radius: 0;
    box-shadow: none;
}

.leader-marketing-services-tree__section span {
    font-weight: 600;
}

.leader-marketing-services-tree__item span {
    font-weight: normal;
}

.leader-marketing-bonus-inline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
    margin-top: 2px;
}

.leader-marketing-bonus-inline__cell {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 6px;
    flex: 0 1 auto;
    min-width: 0;
}

.leader-marketing-bonus-inline__cell--grow {
    flex: 1 1 150px;
    min-width: min(100%, 150px);
}

.leader-marketing-bonus-inline__cell--amount input {
    width: 84px;
    max-width: 100%;
    box-sizing: border-box;
}

.leader-marketing-bonus-inline__hint-wrap {
    position: relative;
    display: inline-block;
    vertical-align: middle;
}

.leader-marketing-bonus-inline__cell--amount .leader-marketing-bonus-inline__hint-wrap > input {
    width: min(150px, 100%);
}

.leader-marketing-bonus-inline__hint-wrap > input.leader-marketing-bonus-inline__input--zero-hint {
    color: transparent;
    caret-color: var(--text);
}

.leader-marketing-bonus-inline__hint-wrap > .leader-marketing-bonus-inline__zero-hint {
    position: absolute;
    z-index: 1;
    left: 8px;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.leader-marketing-bonus-inline__cell--value input {
    width: 90px;
    max-width: 100%;
    box-sizing: border-box;
}

.leader-marketing-bonus-inline__cell > label,
.leader-marketing-bonus-inline__field-label {
    display: inline-block;
    margin-bottom: 0;
    flex-shrink: 0;
    font-weight: 600;
    font-size: 10px;
    line-height: 1.3;
    color: var(--text);
    white-space: nowrap;
}

.leader-marketing-bonus-inline .leader-marketing-bonus-calc-select {
    width: auto;
    min-width: 98px;
    max-width: 195px;
}

.leader-marketing-bonus-inline__combobox {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 6px;
    flex: 1 1 auto;
    min-width: 0;
    position: relative;
}

.leader-marketing-bonus-inline__combobox > label {
    display: inline-block;
    margin-bottom: 0;
    flex-shrink: 0;
    font-weight: 600;
    font-size: 10px;
    white-space: nowrap;
}

.leader-marketing-bonus-inline__combobox .leader-marketing-address-combobox__control {
    flex: 1 1 auto;
    min-width: 0;
    margin-top: 0;
}

.leader-marketing-bonus-block {
    margin-top: 15px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

.leader-marketing-bonus-block__subtitle {
    font-size: 0.95em;
    margin-bottom: 4px;
}

.leader-marketing-settings-page {
    max-width: 570px;
}

.leader-marketing-settings-fieldset {
    margin-top: 15px;
}

.leader-marketing-settings-fieldset > .leader-marketing-settings-row + .leader-marketing-settings-row {
    margin-top: 12px;
}

.leader-marketing-settings-fieldset > .leader-marketing-settings-row + .form-row {
    margin-top: 12px;
}

.leader-marketing-settings-row {
    margin-bottom: 10px;
}

.leader-marketing-settings-discount-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 15px;
}

/* Побить .form-row label — чекбокс и «макс. %» в одну строку (строка без класса form-row) */
.leader-marketing-settings-fieldset .leader-marketing-settings-discount-row > label.leader-checkbox-inline {
    display: inline-flex;
    align-items: center;
    margin-bottom: 0;
    flex-shrink: 0;
    align-self: center;
}

.leader-marketing-settings-discount-row__max {
    display: inline-flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 6px 8px;
    flex-shrink: 0;
}

.leader-marketing-settings-fieldset .leader-marketing-settings-discount-row__max > label {
    display: inline;
    margin: 0;
    font-weight: 600;
    font-size: 10px;
    color: var(--text);
}

.leader-marketing-settings-bonus-inline-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 12px;
}

.leader-marketing-settings-fieldset .leader-marketing-settings-bonus-inline-row > label {
    display: inline-flex;
    align-items: center;
    margin-bottom: 0;
    font-weight: 600;
    font-size: 10px;
    color: var(--text);
}

.leader-marketing-settings-pct-input {
    width: 66px;
    max-width: 100%;
    box-sizing: border-box;
}

/* Сильнее .form-card input[type="number"] { width: 100% } — иначе поле на всю ширину и перенос на новую строку */
.form-card .leader-marketing-settings-fieldset input.leader-marketing-settings-pct-input[type="number"] {
    width: 66px;
    max-width: 90px;
    flex: 0 0 auto;
}

.leader-marketing-segment-label {
    display: block;
    font-weight: 600;
    font-size: 10px;
    margin-bottom: 6px;
    color: var(--text);
}

.leader-marketing-segment {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    width: fit-content;
    max-width: 100%;
}

.leader-marketing-segment label {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0;
    padding: 7px 10px;
    margin: 0;
    cursor: pointer;
    border-right: 1px solid var(--border);
    font-weight: 600;
    font-size: 10px;
    line-height: 1.25;
    background: var(--card);
    transition: background 0.12s ease, color 0.12s ease;
}

.leader-marketing-segment label:last-child {
    border-right: none;
}

.leader-marketing-segment input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    margin: 0;
    appearance: none;
    -webkit-appearance: none;
}

.leader-marketing-segment label:has(input:focus-visible) {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
    z-index: 1;
}

.leader-marketing-segment label:has(input:checked) {
    background: rgba(14, 165, 233, 0.14);
    color: var(--primary-dark);
}

.leader-marketing-segment label:hover:not(:has(input:checked)) {
    background: rgba(31, 41, 55, 0.04);
}

/* Четыре пункта «Доступность акций» — сетка 2×2 на всю ширину */
.leader-marketing-settings-fieldset .leader-marketing-segment.leader-marketing-segment--promo-scope {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.leader-marketing-settings-fieldset .leader-marketing-segment--promo-scope label {
    justify-content: center;
    text-align: center;
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}

.leader-marketing-settings-fieldset .leader-marketing-segment--promo-scope label:nth-child(2n) {
    border-right: none;
}

.leader-marketing-settings-fieldset .leader-marketing-segment--promo-scope label:nth-child(n + 3) {
    border-bottom: none;
}

.leader-marketing-bonus-calc-select {
    width: 100%;
    max-width: 390px;
    min-height: 28px;
    padding: 4px 8px;
    border-radius: 3px;
    border: 1px solid var(--border);
    background: var(--surface, #fff);
    font-size: 10px;
}

.leader-marketing-bonus-threshold-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 9px 15px;
}

.leader-marketing-bonus-threshold-row__basis {
    flex: 1 1 165px;
    min-width: 0;
}

.leader-marketing-bonus-threshold-row__basis .leader-marketing-bonus-calc-select {
    max-width: none;
}

.leader-marketing-bonus-threshold-row__amount {
    flex: 0 0 auto;
    width: 99px;
    max-width: 100%;
}

.leader-marketing-bonus-threshold-row__amount input {
    width: 100%;
    box-sizing: border-box;
}

.leader-marketing-bonus-threshold-row__amount--wide {
    width: 141px;
}

.leader-settings-marketing {
    min-width: 0;
}

.leader-marketing-campaigns-section__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 9px;
    flex-wrap: wrap;
    margin-bottom: 3px;
}

.leader-marketing-campaigns-section__head .leader-appearance-block__title {
    margin: 0;
}

.leader-marketing-campaigns-section__empty-actions {
    margin-top: 9px;
}

.leader-marketing-campaigns-completed {
    margin-top: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 6px 9px 9px;
    background: var(--leader-collapsible-bg);
}

.leader-marketing-campaigns-completed__summary {
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 3px 6px;
    margin: 0 0 3px;
}

.leader-marketing-campaigns-completed__summary::-webkit-details-marker {
    display: none;
}

.leader-marketing-campaigns-completed__summary::before {
    content: "";
    display: inline-block;
    width: 0.45em;
    height: 0.45em;
    margin-right: 0.35em;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(-45deg);
    vertical-align: 0.12em;
    opacity: 0.65;
}

.leader-marketing-campaigns-completed[open] .leader-marketing-campaigns-completed__summary::before {
    transform: rotate(45deg);
    vertical-align: 0.08em;
}

.leader-marketing-campaigns-completed__title {
    margin: 0;
    display: inline;
}

.leader-marketing-campaigns-completed__count {
    font-weight: 400;
}

.leader-marketing-campaign-list-toolbar {
    margin-top: 9px;
}

.leader-marketing-campaign-list-toolbar__row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-end;
    gap: 8px 9px;
}

.leader-marketing-campaign-list-toolbar__sort {
    flex: 0 1 auto;
    width: min(100%, 30rem);
    max-width: 100%;
    min-width: 0;
}

.leader-marketing-campaign-list-toolbar__select-wrap {
    display: block;
    width: 100%;
    position: relative;
    vertical-align: middle;
}

/* Внутри `.form-card` — специфичнее `.form-card select` (двойной градиент), иначе две «стрелки» */
.leader-marketing-campaign-list-toolbar__select,
.form-card .leader-marketing-campaign-list-toolbar__select {
    display: block;
    width: 100%;
    max-width: 100%;
    min-height: 30px;
    padding: 6px 4rem 6px 9px;
    border-radius: 6px;
    border: 1px solid var(--border);
    font: inherit;
    font-size: inherit;
    color: inherit;
    box-sizing: border-box;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    background-color: var(--input-bg, var(--field-surface));
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='none' stroke='%23666' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M3.5 5.25L7 9l3.5-3.75'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.85rem center;
    background-size: 10px 10px;
}

.leader-marketing-campaign-list-toolbar__select::-ms-expand,
.form-card .leader-marketing-campaign-list-toolbar__select::-ms-expand {
    display: none;
}

.leader-marketing-on-service-discount-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 10px 14px;
    margin-top: 6px;
}

.leader-marketing-on-service-discount-row__services {
    flex: 1 1 165px;
    min-width: 0;
}

.leader-marketing-on-service-discount-row__combobox {
    max-width: 100%;
}

.leader-marketing-on-service-discount-row__pct {
    display: flex;
    flex-direction: column;
    gap: 3px;
    flex: 0 0 auto;
}

.leader-marketing-on-service-discount-row__pct .leader-marketing-settings-pct-input {
    width: 90px;
    max-width: 100%;
}

.leader-marketing-on-service-discount-row__auto-add {
    flex: 0 0 auto;
    margin-bottom: 2px;
    max-width: 165px;
}

.leader-marketing-campaign-list-filter {
    position: relative;
    flex: 0 0 auto;
    display: flex;
    align-items: stretch;
}

.leader-marketing-campaign-list-filter__funnel {
    flex-shrink: 0;
    opacity: 0.88;
    display: block;
}

.leader-marketing-campaign-list-filter__trigger {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-height: 30px;
    min-width: 7.5rem;
    padding: 6px 12px;
    border: 1px solid var(--border);
    border-radius: 6px;
    font: inherit;
    font-size: inherit;
    background: var(--input-bg, var(--field-surface));
    color: inherit;
    box-sizing: border-box;
    user-select: none;
    margin: 0;
}

.leader-marketing-campaign-list-filter__count {
    font-weight: 400;
}

.leader-marketing-campaign-list-filter__panel {
    position: absolute;
    z-index: 4;
    right: 0;
    left: auto;
    top: calc(100% + 4px);
    min-width: 195px;
    max-width: min(240px, 92vw);
    padding: 8px 9px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--card-bg, var(--card));
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.08);
}

.leader-marketing-campaign-list-filter__item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 3px 0;
    font-size: 0.9rem;
    cursor: pointer;
}

.leader-marketing-campaign-list-filter__item input {
    flex-shrink: 0;
}

.leader-marketing-campaign-list-filter__actions {
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px solid var(--border);
}

.leader-marketing-campaign-list-pager {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    margin-top: 9px;
    flex-wrap: wrap;
}

.leader-marketing-campaign-list-pager__pos {
    min-width: 3.5em;
    text-align: center;
}

.leader-marketing-campaign-list {
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
}

.leader-marketing-campaign-list__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 9px;
    padding: 8px 9px;
    border: 1px solid var(--border);
    border-radius: 8px;
    margin-bottom: 6px;
}

.leader-marketing-campaign-list__main {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}

/* Клик по строке открывает модалку; отдельная кнопка «Завершить» справа */
.leader-marketing-campaign-list__hit {
    flex: 1 1 auto;
    min-width: 0;
    display: block;
    margin: 0;
    padding: 0;
    border: none;
    background: none;
    font: inherit;
    color: inherit;
    text-align: left;
    cursor: pointer;
    border-radius: 6px;
}

.leader-marketing-campaign-list__hit:hover .leader-marketing-campaign-list__main strong {
    text-decoration: underline;
}

.leader-marketing-campaign-list__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    flex: 0 0 auto;
}

/* Кнопка действия в строке (не .leader-marketing-campaign-list__hit): flex не сжимает, сброс нативного вида */
.leader-marketing-campaign-list__row > button.btn,
.leader-marketing-campaign-list__actions > button.btn {
    flex: 0 0 auto;
    align-self: center;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
    font-family: inherit;
}

/* «Скопировать» и «Завершить» — одинаковый основной (синий) вид; перебиваем btn-ghost и прочие коллизии */
.leader-marketing-campaign-list__actions > button.btn.btn-sm {
    background: var(--btn-primary-bg, var(--primary)) !important;
    color: #fff !important;
    border-color: transparent !important;
    border-radius: 9999px;
}

.leader-marketing-campaign-list__actions > button.btn.btn-sm:hover:not(:disabled) {
    background: var(--btn-primary-bg-hover, var(--primary-dark)) !important;
    color: #fff !important;
}

.leader-marketing-campaign-list__actions > button.btn.btn-sm:disabled {
    opacity: 0.48;
    cursor: not-allowed;
}

/*
 * Только при [open]: иначе display:flex и т.д. перебивают UA display:none у <dialog> —
 * окно «висит» на странице сразу и не скрывается.
 * inset:0 + margin:auto — центрирование при position:fixed (как у модалки записи).
 */
dialog.leader-modal.leader-modal--marketing[open] {
    /* Модалки акций: компактнее после снятия глобального zoom */
    position: fixed;
    inset: 0;
    --modal-width: 62vw;
    width: min(var(--modal-width), calc(100vw - 24px));
    max-width: min(var(--modal-width), calc(100vw - 24px));
    height: min(90vh, 640px);
    max-height: min(90vh, 640px);
    box-sizing: border-box;
    margin: auto;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 10px;
    z-index: 10050;
}

/* Модалки сотрудников (добавить/редактировать): +20% к базовой ширине */
dialog.leader-modal.leader-modal--staff:not(.leader-modal--marketing)[open],
.leader-modal.leader-modal--staff:not(.leader-modal--marketing).leader-modal--polyfill-open {
    max-width: 414px;
}

/* Импорт прайса: фиксированная высота во вьюпорт — тело flex:1 со скроллом, подвал всегда у нижнего края */
dialog.leader-modal.leader-modal--staff.leader-modal--price-import[open],
.leader-modal.leader-modal--staff.leader-modal--price-import.leader-modal--polyfill-open {
    position: fixed;
    inset: 0;
    z-index: 10050;
    width: min(90vw, calc(100vw - 24px));
    max-width: none;
    height: min(92vh, calc(100dvh - 24px));
    max-height: calc(100dvh - 24px);
    margin: auto;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    align-items: stretch;
    transform: none; /* polyfill: иначе translate(-50%,-50%) ломает центрирование margin:auto */
}

.leader-modal--price-import .leader-modal__head {
    flex-shrink: 0;
    padding: 10px 14px;
}

.leader-modal--price-import .leader-modal--price-import__body {
    display: flex;
    flex-direction: column;
    flex: 1 1 0%;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
    padding-top: 10px;
    padding-bottom: 8px;
}

/* Вкладки / подсказки не сжимаем; вертикаль+горизонталь — только у области таблицы — полоса прокрутки X у низа видимой зоны */
.leader-modal--price-import .leader-modal--price-import__body > .leader-settings-nav-tertiary,
.leader-modal--price-import .leader-modal--price-import__body > p.muted,
.leader-modal--price-import .leader-modal--price-import__body > div.muted.small {
    flex-shrink: 0;
}

/* Иначе вложенный max-height + overflow-y дают второй скролл и пустоту под таблицей */
.leader-modal--price-import .leader-price-list-scroll {
    flex: 1 1 0%;
    min-height: 0;
    min-width: 0;
    max-height: none;
    overflow: auto;
    margin-bottom: 0;
}

.leader-modal--price-import .leader-modal__actions {
    flex-shrink: 0;
    margin-top: 0;
    padding: 6px 12px 8px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.leader-modal.leader-modal--marketing .leader-modal__head {
    flex-shrink: 0;
}

.leader-modal.leader-modal--marketing .leader-modal__form.leader-marketing-campaign-modal-form {
    flex: 1 1 0%;
    min-height: 0;
    min-width: 0;
    overflow-x: hidden;
    overflow-y: auto;
}

.leader-modal.leader-modal--marketing .leader-modal__actions.leader-modal__actions--marketing-campaign {
    flex-shrink: 0;
    margin-top: 0;
    padding: 9px 14px 12px;
}

.leader-marketing-campaign-modal-tabs {
    margin-bottom: 9px;
}

.leader-marketing-campaign-modal-tabs__nav {
    flex-wrap: wrap;
    margin-bottom: 0;
}

.leader-marketing-campaign-promotion-kind {
    margin-bottom: 12px;
}

.leader-marketing-campaign-bonuses-block {
    margin-top: 3px;
}

.leader-marketing-discount-block {
    margin-top: 9px;
}

.leader-marketing-discount-tiers-wrap {
    overflow-x: auto;
    max-width: 100%;
}

.leader-marketing-discount-tiers-table {
    width: 100%;
    table-layout: fixed;
    border-collapse: collapse;
    font-size: 10px;
}

.leader-marketing-discount-tiers-table th,
.leader-marketing-discount-tiers-table td {
    padding: 6px 6px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}

.leader-marketing-discount-tiers-table th:not(.leader-marketing-discount-tiers-table__actions),
.leader-marketing-discount-tiers-table td:not(.leader-marketing-discount-tiers-table__actions) {
    text-align: center;
}

.leader-marketing-discount-tiers-table th {
    font-weight: 600;
    color: var(--text-muted, #64748b);
    white-space: nowrap;
}

.leader-marketing-discount-tiers-table td input[type="number"] {
    width: 100%;
    max-width: none;
    min-width: 0;
    box-sizing: border-box;
    text-align: center;
}

.leader-marketing-discount-tiers-table__actions {
    width: 33px;
    padding-left: 3px !important;
    padding-right: 0 !important;
    text-align: center;
    vertical-align: middle;
}

.leader-marketing-discount-tier-from-readonly {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 28px;
    padding: 4px 8px;
    box-sizing: border-box;
    font-size: 10px;
    font-variant-numeric: tabular-nums;
    color: var(--text);
}

.leader-marketing-discount-tier-to-input::placeholder {
    color: var(--text-muted, #64748b);
    font-weight: 500;
    text-align: center;
}

.leader-marketing-discount-tier-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--text-muted, #64748b);
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
    transition: background 0.12s ease, color 0.12s ease;
}

.leader-marketing-discount-tier-remove:hover:not(:disabled) {
    background: color-mix(in srgb, var(--danger-soft-bg) 75%, transparent);
    color: var(--danger-text);
}

.leader-marketing-discount-tier-remove:disabled {
    opacity: 0.28;
    cursor: not-allowed;
}

.leader-marketing-discount-service-lines-wrap {
    overflow-x: auto;
    max-width: 100%;
}

.leader-marketing-discount-service-lines-table {
    width: 100%;
    table-layout: fixed;
    border-collapse: collapse;
    font-size: 10px;
}

.leader-marketing-discount-service-lines-table th,
.leader-marketing-discount-service-lines-table td {
    padding: 6px 6px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}

.leader-marketing-discount-service-lines-table th {
    font-weight: 600;
    color: var(--text-muted, #64748b);
    text-align: left;
}

.leader-marketing-discount-service-lines-table__del {
    width: 30px;
    text-align: center;
    white-space: nowrap;
}

.leader-marketing-discount-svc-picker-wrap {
    position: relative;
    min-width: 0;
}

/* Портал в body: не режется overflow формы модалки и не уходит под подвал */
.leader-marketing-discount-svc-picker__popover {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
    background: var(--input-bg, var(--field-surface));
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 9px 24px rgba(15, 23, 42, 0.18);
}

.leader-marketing-discount-svc-picker__panel {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 3px);
    z-index: 30;
    max-height: min(240px, 55vh);
    overflow: auto;
    background: var(--input-bg, var(--field-surface));
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.12);
}

.leader-marketing-discount-svc-picker__panel.leader-marketing-discount-svc-picker__panel--portal {
    position: static;
    left: auto;
    right: auto;
    top: auto;
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    z-index: auto;
    overflow: auto;
    box-shadow: none;
    border: none;
    border-radius: 0;
}

.leader-marketing-discount-svc-picker__section {
    font-weight: 600;
    color: var(--text-muted, #64748b);
    cursor: default;
}

.leader-marketing-discount-svc-picker__item {
    display: block;
    width: 100%;
    margin: 0;
    padding: 6px 8px;
    border: none;
    border-radius: 0;
    background: transparent;
    font: inherit;
    font-size: 10px;
    text-align: left;
    color: var(--text);
    cursor: pointer;
    box-sizing: border-box;
}

.leader-marketing-discount-svc-picker__item:hover:not(:disabled) {
    background: rgba(14, 165, 233, 0.08);
}

.leader-marketing-discount-svc-picker__item:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.leader-marketing-discount-svc-row-del {
    font-size: 15px;
    line-height: 1;
    padding: 3px 6px;
}

.leader-marketing-discount-svc-auto {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 0;
    white-space: nowrap;
}

.leader-marketing-discount-svc-auto__text {
    font-size: 10px;
    color: var(--text-muted, #64748b);
}

.leader-marketing-campaign-modal-form .leader-marketing-settings-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 12px;
}

.leader-marketing-campaign-modal-form .leader-marketing-settings-row > label {
    font-weight: 600;
    margin: 0;
}

.leader-marketing-promocode-fields {
    display: grid;
    gap: 8px;
    margin-top: 8px;
}

.leader-marketing-campaign-modal-form .leader-marketing-settings-row.leader-marketing-promocode-row {
    display: grid;
    grid-template-columns: minmax(195px, auto) minmax(0, 1fr);
    align-items: center;
    gap: 9px 12px;
}

.leader-marketing-promocode-row__segment {
    justify-self: start;
}

.leader-marketing-campaign-modal-tabpanel {
    min-width: 0;
}

.leader-marketing-campaign-modal__fieldset {
    border: 0;
    margin: 0;
    padding: 0;
    min-width: 0;
}

.leader-marketing-campaign-restrictions {
    margin-top: 4px;
    margin-bottom: 2px;
    padding: 9px 10px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--card-bg, var(--card));
    min-width: 0;
}

.leader-marketing-campaign-restrictions__title {
    font-weight: 700;
    font-size: 10px;
    line-height: 1.3;
    margin: 0 0 9px;
    color: var(--text);
}

.leader-marketing-weekdays-inline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px 6px;
}

.form-row label.leader-marketing-weekday-chip {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    margin: 0;
    padding: 4px 7px;
    border: 1px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
    font-weight: 600;
    font-size: 10px;
    line-height: 1.2;
    background: var(--surface, #fff);
    color: var(--text);
}

.form-row label.leader-marketing-weekday-chip input[type="checkbox"] {
    margin: 0;
    width: 11px;
    height: 11px;
    flex-shrink: 0;
}

.form-row label.leader-marketing-weekday-chip:has(input:checked) {
    background: rgba(14, 165, 233, 0.14);
    border-color: rgba(14, 165, 233, 0.45);
    color: var(--primary-dark, #0369a1);
}

.leader-marketing-campaign-title-row__label {
    display: block;
    font-weight: 600;
    margin-bottom: 4px;
}

/* Применение + сегмент доступности в одну строку (побить .form-row label { display: block }) */
.leader-marketing-campaign-app-and-scope-row {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 6px 10px;
    overflow-x: auto;
}

.form-row.leader-marketing-campaign-app-and-scope-row > label.leader-marketing-campaign-app-and-scope-row__label {
    display: inline-flex;
    align-items: center;
    margin-bottom: 0;
    flex: 0 0 auto;
}

.leader-marketing-campaign-app-and-scope-row__segment.leader-marketing-segment {
    flex: 0 0 auto;
    min-width: 0;
    margin-left: auto;
    width: auto;
}

.leader-marketing-campaign-app-and-scope-row__segment--audience.leader-marketing-segment {
    margin-left: 0;
}

.leader-marketing-campaign-app-and-scope-row .leader-marketing-segment label {
    white-space: nowrap;
}

@media (max-width: 720px) {
    .leader-marketing-campaign-app-and-scope-row__segment.leader-marketing-segment {
        margin-left: 0;
    }
}

.leader-marketing-campaign-title-editor {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    position: relative;
    z-index: 2;
}

/* Палитры и подсказки Quill поверх содержимого модалки */
.leader-modal.leader-modal--marketing .ql-tooltip,
.leader-modal.leader-modal--marketing .ql-picker-options {
    z-index: 10060;
}

.leader-marketing-campaign-title-editor .ql-toolbar {
    border-radius: 6px 6px 0 0;
    border-color: var(--border);
    font-family: inherit;
    padding-top: 3px;
    padding-bottom: 3px;
}

.leader-marketing-campaign-title-editor .ql-snow .ql-picker.ql-size {
    width: 64px;
}

.leader-marketing-campaign-title-editor .ql-snow .ql-picker.ql-size .ql-picker-label::before,
.leader-marketing-campaign-title-editor .ql-snow .ql-picker.ql-size .ql-picker-item::before {
    content: attr(data-value);
}

.leader-marketing-campaign-title-editor .ql-snow .ql-picker.ql-size .ql-picker-label[data-value=""]::before {
    content: "10px";
}

.leader-marketing-campaign-title-editor .ql-container {
    border-radius: 0 0 6px 6px;
    border-color: var(--border);
    font-family: inherit;
    font-size: 10px;
    min-height: 45px;
}

.leader-marketing-campaign-title-editor .ql-editor {
    min-height: 45px;
    line-height: 1.45;
}

.leader-marketing-campaign-title-editor .ql-editor.ql-blank::before {
    color: var(--muted);
    font-style: normal;
}

.leader-marketing-campaign-title-editor--loading {
    min-height: 45px;
    display: flex;
    align-items: center;
    padding: 6px 0;
    box-sizing: border-box;
}

.leader-marketing-application-inline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 10px;
}

.leader-marketing-application-inline__label {
    display: inline-block;
    margin-bottom: 0;
    flex: 0 0 auto;
    font-weight: 600;
    font-size: 10px;
    line-height: 1.4;
    color: var(--text);
}

.leader-marketing-application-inline__select {
    flex: 1 1 auto;
    min-width: min(100%, 165px);
    max-width: 100%;
}

/* Селект фиксированной гибкости; сегмент забирает остаток строки */
.leader-marketing-campaign-app-and-scope-row .leader-marketing-application-inline__select.leader-marketing-campaign-app-and-scope-row__application-select {
    flex: 0 1 165px;
    min-width: min(100%, 120px);
    max-width: 210px;
}

.leader-marketing-period-inline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 8px;
}

.leader-marketing-period-inline__lead {
    font-weight: 600;
    font-size: 10px;
    line-height: 1.4;
    color: var(--text);
}

.leader-marketing-period-inline__prep {
    color: var(--muted);
    font-weight: 600;
    font-size: 10px;
}

.leader-marketing-period-inline__date {
    min-width: 0;
}

.leader-marketing-period-inline__indef {
    font-weight: 600;
}

.form-row label.leader-marketing-period-inline__indef-check,
.form-row label.leader-marketing-time-inline__check,
.form-row label.leader-marketing-services-inline__check {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-weight: 700;
    font-size: 10px;
    line-height: 1.4;
    color: var(--text);
}

.leader-marketing-period-inline__indef-check input[type="checkbox"],
.leader-marketing-time-inline__check input[type="checkbox"],
.leader-marketing-services-inline__check input[type="checkbox"] {
    margin-top: 0;
    width: 12px;
    height: 12px;
}

.leader-marketing-period-inline__indef-check span,
.leader-marketing-time-inline__check span,
.leader-marketing-services-inline__check span {
    display: inline-block;
    line-height: 1.2;
    vertical-align: middle;
}

/* Чекбокс «Только на услуги» и поле выбора разделов/услуг в одну строку */
.leader-marketing-services-limit-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
}

.leader-marketing-services-limit-row__check {
    flex: 0 0 auto;
}

.leader-marketing-services-limit-row__combobox {
    flex: 1 1 150px;
    min-width: min(100%, 120px);
    max-width: 100%;
}

.leader-marketing-services-limit-row__combobox .leader-marketing-services-combobox__control {
    margin-top: 0;
}

/* Подпись поля, скрытая визуально (остаётся для доступности) */
.leader-marketing-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.leader-marketing-time-inline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 9px;
}

.leader-marketing-time-inline__check {
    margin: 0;
}

.leader-marketing-time-inline__prep {
    color: var(--muted);
    font-weight: 600;
    font-size: 10px;
}

.leader-marketing-time-inline__clock {
    min-width: 0;
}

.leader-marketing-campaign-image-upload-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 9px;
}

/* Одинаковая высота label и button (браузер по-разному рисует native button) */
.leader-marketing-campaign-image-upload-actions .btn.btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    min-height: 33px;
    padding: 8px 10px;
    margin: 0;
    font: inherit;
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    vertical-align: middle;
    cursor: pointer;
}

.leader-marketing-campaign-image-upload-actions button.btn.btn-primary {
    -webkit-appearance: none;
    appearance: none;
    font-family: inherit;
}

.leader-marketing-campaign-image-upload-btn {
    max-width: min(100%, 210px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.leader-marketing-campaign-image-upload-input {
    position: absolute;
    width: 0.1px;
    height: 0.1px;
    padding: 0;
    margin: 0;
    opacity: 0;
    overflow: hidden;
    z-index: -1;
    border: none;
}

.leader-marketing-campaign-description-editor .ql-container {
    min-height: 135px;
}

.leader-marketing-campaign-description-editor .ql-editor {
    min-height: 135px;
}

.leader-marketing-campaign-image-preview {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}

.leader-marketing-campaign-image-preview__box {
    max-width: 100%;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    background: var(--surface-muted, #f5f5f5);
}

.leader-marketing-campaign-image-preview__box img {
    display: block;
    max-width: 100%;
    max-height: 165px;
    width: auto;
    height: auto;
    object-fit: contain;
}

.leader-marketing-campaign-image-preview__box--inline {
    flex: 0 0 auto;
    max-width: 90px;
    max-height: 68px;
}

.leader-marketing-campaign-image-preview__box--inline img {
    max-height: 63px;
    max-width: 90px;
}

.leader-modal__actions.leader-modal__actions--marketing-campaign {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.leader-dayoff-loc-combobox__loc-group {
    border-bottom: 1px solid var(--border);
    padding-bottom: 3px;
    margin-bottom: 2px;
}

.leader-dayoff-loc-combobox__loc-group:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.leader-dayoff-loc-combobox__box-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px 10px;
    padding: 2px 9px 6px 27px;
}

.leader-dayoff-loc-combobox__box-lab {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin: 0;
    cursor: pointer;
    font-weight: normal;
    font-size: 10px;
}

.leader-appearance-block__title--header-bg {
    margin-bottom: 6px;
}

.leader-appearance-header-bg-title-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    cursor: pointer;
    font-weight: 800;
    font-size: 11px;
    line-height: 1.3;
}

.leader-appearance-header-bg-title-label input[type="checkbox"] {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    margin: 0;
}

.leader-ui-mode-row {
    margin-top: 9px;
}

.leader-ui-mode-label {
    display: block;
    font-weight: 600;
    margin-bottom: 6px;
}

.leader-ui-mode-radios {
    display: flex;
    flex-wrap: wrap;
    gap: 9px 15px;
    list-style: none;
    padding: 0;
    margin: 0 0 6px;
}

.leader-ui-mode-radios li {
    margin: 0;
}

.leader-general-after-addresses {
    margin-top: 15px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

.leader-appearance-asset-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-bottom: 6px;
}

/* Одна высота строки: иначе label и button разной высоты, при align-items:center «Выбрать файл» визуально выше «Удалить» */
.leader-appearance-form .leader-appearance-asset-actions {
    align-items: stretch;
}

.leader-appearance-form .leader-appearance-asset-actions > .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding: 5px 9px;
    line-height: 1.2;
    font-size: 10px;
}

/* Label как кнопка «Выбрать файл» — те же классы, что у «Сохранить внешний вид»; только позиционирование для скрытого input */
.leader-appearance-form .leader-appearance-asset-actions label.btn {
    position: relative;
    cursor: pointer;
}

.leader-admin-salary-form .leader-admin-salary-kind-label {
    display: block;
    font-weight: 800;
    font-size: 11px;
    margin-bottom: 6px;
}

.leader-admin-salary-form ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.leader-contacts-addresses-block {
    margin-top: 15px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

.leader-locations-root {
    margin-top: 8px;
}

.leader-locations-active-wrap {
    width: 100%;
}

.leader-locations-active-head {
    display: grid;
    grid-template-columns: 1fr minmax(105px, 150px) minmax(66px, 78px) minmax(69px, 81px) auto;
    gap: 8px;
    align-items: center;
    padding: 0 2px 6px;
    margin-bottom: 3px;
    border-bottom: 1px solid var(--border);
}

.leader-locations-active-head__cell {
    font-size: 9px;
    font-weight: 700;
    color: var(--muted, #64748b);
    letter-spacing: 0.02em;
    text-align: center;
}

.leader-locations-active-head__cell--actions {
    min-width: 5.5rem;
}

.leader-location-row {
    display: grid;
    grid-template-columns: 1fr minmax(105px, 150px) minmax(66px, 78px) minmax(69px, 81px) auto;
    gap: 8px;
    align-items: center;
    margin-bottom: 9px;
}

.leader-location-row__boxes-label {
    display: flex;
    flex-direction: column;
    gap: 3px;
    margin: 0;
    font-size: 9px;
    font-weight: 600;
    color: var(--muted, #64748b);
}

.leader-locations-active-wrap .leader-location-row__boxes-caption {
    display: none;
}

.leader-location-row__boxes-caption {
    white-space: nowrap;
}

.leader-location-row__boxes {
    width: 100%;
    max-width: 66px;
    padding: 8px 6px;
    border-radius: 9px;
    border: 1px solid var(--border);
    font: inherit;
    background: var(--field-surface);
    color: var(--text);
    box-sizing: border-box;
}

.leader-location-row__reorder {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    justify-content: center;
    align-items: center;
}

.leader-location-row__reorder .btn-sm {
    min-width: 2.25rem;
    padding-left: 6px;
    padding-right: 6px;
}

.leader-location-row--closed {
    grid-template-columns: 1fr auto;
    align-items: start;
    padding: 8px 9px;
    border-radius: 9px;
    background: var(--field-surface);
    color: var(--text);
    border: 1px solid var(--border);
}

.leader-location-row__addr,
.leader-location-row__phone {
    width: 100%;
    padding: 8px 9px;
    border-radius: 9px;
    border: 1px solid var(--border);
    font: inherit;
    background: var(--field-surface);
    color: var(--text);
}

.leader-location-row__closed-text {
    min-width: 0;
    line-height: 1.35;
}

.leader-location-row__closed-addr {
    display: block;
    font-weight: 600;
    color: var(--text);
}

.leader-general-min-price-row {
    margin-top: 0;
}

.leader-locations-closed-details {
    margin-top: 12px;
    border: 1px solid var(--border);
    border-radius: 9px;
    padding: 6px 9px 9px;
    background: var(--leader-collapsible-bg);
}

.leader-locations-closed-summary {
    cursor: pointer;
    font-weight: 800;
    font-size: 10px;
    list-style: none;
    padding: 6px 3px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    user-select: none;
    border-radius: 6px;
    color: var(--text);
}

.leader-locations-closed-summary:hover {
    background: rgba(14, 165, 233, 0.08);
}

.leader-locations-closed-summary::-webkit-details-marker {
    display: none;
}

.leader-locations-closed-summary::before {
    content: "▸";
    display: inline-block;
    font-size: 9px;
    line-height: 1;
    color: var(--muted, #64748b);
    transition: transform 0.15s ease;
}

.leader-locations-closed-details[open] > .leader-locations-closed-summary::before {
    transform: rotate(90deg);
}

.leader-locations-closed-empty {
    margin: 3px 0 0;
    line-height: 1.45;
}

.leader-locations-closed-badge {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 6px;
    border-radius: 749px;
    font-size: 9px;
    font-weight: 700;
    background: rgba(14, 165, 233, 0.15);
    color: var(--primary-dark);
}

.leader-locations-closed {
    margin-top: 6px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.leader-locations-closed > .leader-location-row {
    margin-bottom: 0;
}

@media (max-width: 640px) {
    .leader-locations-active-head {
        display: none;
    }

    .leader-locations-active-wrap .leader-location-row__boxes-caption {
        display: block;
    }

    .leader-location-row {
        grid-template-columns: 1fr;
    }

    .leader-location-row__reorder {
        justify-content: flex-start;
    }

    .leader-location-row__boxes-label {
        flex-direction: row;
        align-items: center;
        gap: 8px;
    }
    .leader-location-row__boxes {
        max-width: 90px;
    }
    .leader-location-row .js-loc-delete {
        justify-self: start;
    }
}

.leader-appearance-preview-box {
    width: 100%;
    max-width: 300px;
    height: 90px;
    box-sizing: border-box;
    border-radius: 9px;
    border: 1px solid var(--border);
    overflow: hidden;
    background: rgba(246, 247, 251, 0.9);
}

.leader-brand-asset__preview.leader-appearance-preview-box {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 6px;
}

.leader-brand-asset__preview.leader-appearance-preview-box .leader-brand-thumb--site {
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    object-fit: cover;
    border: none;
    border-radius: 0;
}

.leader-header-focal-viewport {
    position: relative;
    cursor: grab;
    touch-action: none;
    user-select: none;
    -webkit-user-select: none;
}

.leader-header-focal-viewport.leader-header-focal-viewport--dragging {
    cursor: grabbing;
}

.leader-header-focal-viewport.leader-header-focal-viewport--empty {
    cursor: default;
}

.leader-header-focal-viewport + .leader-appearance-asset-actions {
    margin-top: 9px;
}

.leader-header-focal-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
    position: relative;
    z-index: 0;
}

.leader-header-focal-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 9px 12px;
    font-size: 10px;
    color: var(--muted);
    line-height: 1.4;
}

.leader-header-focal-viewport:not(.leader-header-focal-viewport--empty) .leader-header-focal-placeholder {
    display: none;
}

/*
 * Превью фона шапки: верх и низ размыты. Только ::after (последний слой поверх img);
 * ::before шёл бы под картинкой и не был бы виден.
 */
.leader-header-focal-viewport:not(.leader-header-focal-viewport--empty)::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    border-radius: inherit;
    -webkit-backdrop-filter: blur(14px) saturate(1.08);
    backdrop-filter: blur(14px) saturate(1.08);
    /* Верхняя и нижняя полосы: непрозрачны у краёв, мягко к прозрачному к центру */
    -webkit-mask-image: linear-gradient(
        to bottom,
        #000 0%,
        #000 12%,
        rgba(0, 0, 0, 0.65) 22%,
        transparent 32%,
        transparent 68%,
        rgba(0, 0, 0, 0.65) 78%,
        #000 88%,
        #000 100%
    );
    mask-image: linear-gradient(
        to bottom,
        #000 0%,
        #000 12%,
        rgba(0, 0, 0, 0.65) 22%,
        transparent 32%,
        transparent 68%,
        rgba(0, 0, 0, 0.65) 78%,
        #000 88%,
        #000 100%
    );
    background: linear-gradient(
        to bottom,
        rgba(15, 23, 42, 0.22) 0%,
        rgba(15, 23, 42, 0.06) 28%,
        transparent 32%,
        transparent 68%,
        rgba(15, 23, 42, 0.06) 72%,
        rgba(15, 23, 42, 0.22) 100%
    );
}

.leader-brand-asset__preview {
    margin-bottom: 6px;
}

.leader-appearance-form-actions {
    margin-top: 14px;
    padding-top: 6px;
    border-top: 1px solid var(--border);
}

.leader-opacity-row__value {
    font-weight: 800;
    color: var(--primary-dark);
    margin-left: 3px;
}

.leader-opacity-hint {
    margin-top: -4px;
    margin-bottom: 6px;
}

.leader-opacity-range {
    display: block;
    width: 100%;
    max-width: 315px;
    height: 8px;
    margin-top: 3px;
    accent-color: var(--primary);
    cursor: pointer;
}

.leader-opacity-row {
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border);
}

.leader-brand-thumb {
    max-width: 100%;
    border-radius: 8px;
    border: 1px solid var(--border);
}

.leader-brand-thumb--logo {
    max-height: 72px;
    width: auto;
}

.leader-brand-thumb--header {
    width: 100%;
    max-width: 300px;
    max-height: 90px;
    object-fit: cover;
}

.btn-sm {
    padding: 4px 8px;
    font-size: 10px;
}

.form-card input.leader-brand-file-input[type="file"],
.form-card input.leader-appearance-file-input[type="file"] {
    width: 100%;
    padding: 6px 0;
    border: none;
    border-radius: 0;
    background: transparent;
}

/* .form-card input… не должен стилизовать скрытый file внутри label-кнопки «Внешний вид» */
.leader-appearance-form .leader-appearance-asset-actions label.btn input.leader-appearance-file-input[type="file"] {
    position: absolute;
    width: 0.1px;
    height: 0.1px;
    padding: 0;
    margin: 0;
    opacity: 0;
    overflow: hidden;
    z-index: -1;
    border: none;
    border-radius: 0;
    background: transparent;
}

.leader-price-excel-row {
    margin-top: 9px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.leader-price-excel-form {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin: 0;
}

.leader-price-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
}

.leader-price-title-row__h {
    margin: 0;
}

.leader-price-unsaved {
    color: var(--danger-text);
    font-weight: 700;
    background: var(--danger-soft-bg);
    border: 1px solid var(--danger-border);
    border-radius: 8px;
    padding: 6px 8px;
}

.leader-price-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.leader-price-list-scroll {
    max-height: min(58vh, 390px);
    overflow-y: auto;
    margin-bottom: 8px;
    padding: 6px;
    border: 1px solid var(--border);
    border-radius: 9px;
    /* Как у нерабочих дней / сворачиваемых списков — не белая «коробка» в тёмной теме */
    background: var(--leader-collapsible-bg);
}

.leader-price-cols-wrap {
    margin-top: 4px;
}

/* Редактор прайса: «От/До» только для режима «Диапазон» — не даём темам перебить [hidden] */
#leader-price-form #price-single-range-wrap[hidden],
#leader-price-form #price-cols-range-table[hidden] {
    display: none !important;
}

.leader-price-vehicle-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 10px;
}

.leader-price-vehicle-table th,
.leader-price-vehicle-table td {
    padding: 6px 8px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}

.leader-price-vehicle-table thead th {
    color: var(--muted);
    font-weight: 700;
    font-size: 10px;
    text-align: left;
}

.leader-price-vehicle-table tbody td:first-child {
    width: 44%;
}

.leader-price-vehicle-table input[type="text"] {
    width: 100%;
    max-width: 100%;
    margin: 0;
}

/* Импорт / редактор прайса в модалке: глобальные 100% ширины ячейки делают поля крошечными — фиксируем комфортный минимум */
.leader-modal--price-import .leader-price-vehicle-table input[type="text"] {
    width: auto;
    min-width: 8rem;
    max-width: none;
}

.leader-price-list__btn {
    display: block;
    width: 100%;
    text-align: left;
    font: inherit;
    color: var(--text);
    appearance: none;
    -webkit-appearance: none;
    margin: 0;
    background: var(--field-surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 6px 8px;
    cursor: pointer;
    transition: border-color 0.15s ease, background-color 0.15s ease;
}

.leader-price-list__btn:hover {
    background: var(--leader-nav-primary-hover);
}

.leader-price-list__btn:focus-visible {
    outline: none;
    border-color: var(--leader-nav-active-border);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.22);
}

.leader-price-list__btn.is-selected {
    border-color: var(--leader-nav-active-border);
    background: var(--leader-nav-active-bg);
    color: var(--text);
}

.leader-price-list__btn--inactive {
    opacity: 0.75;
}

.leader-price-inactive-details summary {
    cursor: pointer;
    color: var(--muted);
}

.leader-price-inactive-details {
    margin-top: 8px;
}

.leader-price-form-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 8px;
}

.leader-price-delete-btn--remove {
    color: var(--danger-text);
}

.leader-btn-block {
    margin-top: 8px;
    width: 100%;
    text-align: center;
}

.leader-btn-icon {
    min-width: 34px;
    text-align: center;
}

.leader-btn-save {
    margin-left: auto;
}

.leader-price-column-mode-row {
    margin-bottom: 10px;
}

.leader-price-mode-radios {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.leader-price-mode-radios__label {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: 500;
}

.leader-price-tree__section {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--muted);
    padding: 4px 8px 3px;
    margin-top: 4px;
    pointer-events: none;
    user-select: none;
}

.leader-price-tree__section:first-child {
    margin-top: 0;
}

/* Диапазон + «Все кузова»: От и До в одну строку */
.leader-price-range-pair {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 9px 12px;
}

.leader-price-range-pair.form-row label {
    display: inline;
    margin-bottom: 0;
}

.leader-price-range-pair__field {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 6px;
    flex: 1;
    min-width: 0;
}

.leader-price-range-pair__field label {
    flex-shrink: 0;
    font-weight: 700;
}

.leader-price-range-pair__field input {
    flex: 1;
    min-width: 54px;
    max-width: 100%;
}

.leader-checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-weight: 500;
}

/* График работы (общие настройки): мобильная вёрстка — день + выходной, затем «С» / «По» */
.leader-working-days {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 10px 0 14px;
}

.leader-working-day {
    padding: 10px 10px 9px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--field-surface, var(--leader-collapsible-bg));
    color: var(--text);
}

.leader-working-day__row1 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 8px;
}

.leader-working-day__name {
    font-weight: 700;
    font-size: 14px;
    min-width: 0;
}

.leader-working-day__closed {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    color: var(--text);
    flex-shrink: 0;
}

.leader-working-day__row2 {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 10px 14px;
}

.leader-working-day__time-field {
    display: flex;
    flex-direction: column;
    gap: 3px;
    flex: 1;
    min-width: 0;
}

.leader-working-day__time-lbl {
    font-size: 10px;
    font-weight: 800;
    color: var(--muted);
    letter-spacing: 0.02em;
}

.leader-working-day__row2 input[type="time"] {
    width: 100%;
    min-width: 0;
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    font: inherit;
    background: var(--input-bg, var(--field-surface));
    color: var(--text);
}

.leader-working-day__row2 input[type="time"]:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.leader-staff-table-wrap {
    overflow-x: auto;
}

.leader-staff-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 600px;
}

.leader-staff-table th,
.leader-staff-table td {
    border-top: 1px solid var(--border);
    text-align: left;
    padding: 6px 8px;
    vertical-align: middle;
}

.leader-staff-table th {
    border-top: 0;
    color: var(--muted);
    font-size: 10px;
}

.leader-staff-table input[type="number"] {
    width: 100%;
    min-width: 68px;
}

.leader-staff-table input[type="time"] {
    width: 100%;
    min-width: 82px;
}

.leader-staff-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 9px;
    margin-bottom: 10px;
}

.leader-staff-toolbar__title {
    margin: 0;
}

.leader-staff-table__input {
    max-width: 90px;
}

.leader-staff-table__cell--editable {
    cursor: pointer;
    border-radius: 6px;
    outline-offset: 2px;
    transition: background-color 0.12s ease;
}

.leader-staff-table__cell--editable:hover {
    background-color: rgba(14, 165, 233, 0.08);
}

.leader-staff-table__cell--editable:focus-visible {
    outline: 2px solid rgba(14, 165, 233, 0.55);
}

.leader-staff-table__cell--name {
    color: rgba(14, 165, 233, 0.98);
    font-weight: 600;
    text-decoration: underline;
    text-decoration-style: dotted;
    text-underline-offset: 2px;
}

.leader-staff-table__actions {
    white-space: nowrap;
    text-align: right;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    flex-wrap: wrap;
}

.leader-staff-inline-form {
    display: inline;
    margin: 0;
}

.leader-staff-inline-form--hidden {
    display: none;
}

.leader-staff-dismissed-details {
    margin-top: 16px;
    border: 1px solid var(--border);
    border-radius: 9px;
    padding: 8px 10px 10px;
    background: var(--leader-collapsible-bg);
}

.leader-staff-dismissed-summary {
    cursor: pointer;
    font-weight: 800;
    font-size: 10px;
    list-style: none;
}

.leader-staff-dismissed-summary::-webkit-details-marker {
    display: none;
}

.leader-staff-dismissed-body {
    margin-top: 8px;
}

.leader-staff-dismissed-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.leader-staff-dismissed-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
}

.leader-staff-dismissed-row:last-child {
    border-bottom: none;
}

.leader-modal {
    border: none;
    border-radius: 12px;
    padding: 0;
    max-width: 345px;
    width: calc(100vw - 24px);
    max-height: min(90vh, 480px);
    overflow: auto;
    box-shadow: 0 15px 38px rgba(15, 23, 42, 0.25);
    background: var(--surface, #fff);
}

.leader-modal::backdrop {
    background: rgba(15, 23, 42, 0.45);
}

/* Fallback when <dialog>.showModal() is missing or throws (older browsers) */
.leader-modal.leader-modal--polyfill-open {
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 10050;
    max-height: min(90vh, 480px);
    overflow: auto;
    background: var(--surface, #fff);
}

body[data-leader-dialog-polyfill]::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 10040;
    background: rgba(15, 23, 42, 0.45);
}

.leader-modal__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 9px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
}

.leader-modal__title {
    margin: 0;
    font-size: 1.1rem;
}

.leader-modal__form {
    padding: 12px 14px 14px;
}

.leader-modal__actions {
    margin-top: 12px;
    padding-top: 9px;
    border-top: 1px solid var(--border);
}

.leader-staff-modal-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px 12px;
    margin-bottom: 10px;
}

.leader-staff-modal-row .form-row {
    margin-bottom: 0;
}

@media (max-width: 480px) {
    .leader-staff-modal-row {
        grid-template-columns: 1fr;
    }
}

.leader-dayoff-list {
    display: grid;
    gap: 8px;
}

.leader-dayoff-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 9px;
    padding: 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--leader-collapsible-bg);
    color: var(--text);
}

.leader-general-dayoff-card {
    margin-top: 14px;
}

.leader-dayoff-editor {
    margin-top: 8px;
}

.leader-dayoff-table-head {
    display: grid;
    grid-template-columns: minmax(98px, 1fr) minmax(54px, 0.55fr) minmax(54px, 0.55fr) minmax(0, 1.6fr) auto;
    gap: 8px;
    align-items: center;
    padding: 0 8px 6px;
    font-weight: 800;
    font-size: 10px;
    color: var(--muted);
    border-bottom: 1px solid var(--border);
    margin-bottom: 6px;
}

.leader-dayoff-row--edit {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
}

.leader-dayoff-boxes-subrow {
    width: 100%;
    padding: 0 8px;
    margin-top: 6px;
    box-sizing: border-box;
}

.leader-dayoff-boxes-subrow .leader-dayoff-boxes-row {
    margin-top: 0;
}

.leader-dayoff-row--edit .leader-dayoff-edit-fields {
    display: grid;
    grid-template-columns: minmax(98px, 1fr) minmax(54px, 0.55fr) minmax(54px, 0.55fr) minmax(0, 1.6fr) auto;
    gap: 8px;
    align-items: end;
    width: 100%;
    min-width: 0;
}

.leader-dayoff-stacked-field {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
    margin: 0;
    cursor: default;
}

.leader-dayoff-stacked-field__hint {
    font-size: 10px;
    font-weight: 800;
    color: var(--muted);
    letter-spacing: 0.02em;
}

.leader-dayoff-row--edit .leader-dayoff-edit-fields .btn-sm {
    justify-self: start;
    position: relative;
    z-index: 1;
}

.leader-dayoff-row--edit .leader-dayoff-date-input,
.leader-dayoff-row--edit .leader-dayoff-time-input,
.leader-dayoff-row--edit .leader-dayoff-note-input {
    width: 100%;
    min-width: 0;
    padding: 8px 9px;
    border: 1px solid var(--border);
    border-radius: 9px;
    font: inherit;
    background: var(--field-surface);
    color: var(--text);
}

.leader-dayoff-row--edit .leader-dayoff-time-input {
    padding: 6px 8px;
}

.leader-dayoff-boxes-row {
    margin-top: 8px;
    padding: 0 2px 0 0;
    font-size: 10px;
    color: var(--text);
}

.leader-dayoff-boxes-row--empty {
    color: var(--muted);
    font-size: 10px;
}

.leader-dayoff-all-boxes-lab {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: 600;
    margin-bottom: 6px;
    cursor: pointer;
    color: var(--text);
}

.leader-dayoff-box-checks {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    align-items: center;
}

.leader-dayoff-box-lab {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    font-weight: 500;
    color: var(--text);
}

.leader-dayoff-loc-block {
    margin-bottom: 9px;
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--field-surface);
    color: var(--text);
}

.leader-dayoff-loc-head {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    cursor: pointer;
    font-weight: 700;
    margin-bottom: 0;
}

.leader-dayoff-loc-address {
    font-weight: 700;
    flex: 1;
    min-width: 0;
    line-height: 1.35;
}

.leader-dayoff-loc-boxes {
    margin-top: 8px;
    padding-left: 16px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px 10px;
}

.leader-dayoff-loc-boxes .leader-dayoff-box-lab--nested {
    cursor: pointer;
}

.leader-dayoff-box-lab--nested {
    font-weight: 500;
    color: var(--text);
}

.leader-general-dayoff-save {
    margin-top: 12px;
}

@media (max-width: 640px) {
    .leader-dayoff-table-head {
        display: none;
    }

    .leader-dayoff-row--edit .leader-dayoff-edit-fields {
        grid-template-columns: 1fr;
    }
}

.schedule-toolbar {
    display: flex;
    align-items: end;
    gap: 9px;
    flex-wrap: wrap;
}

.page.page--schedule {
    /* Убираем общий верхний padding .site-main (20px), чтобы лента дат была сразу под шапкой */
    margin-top: -20px;
}

.schedule-strip-wrap {
    margin-top: 0;
    margin-bottom: 1rem;
    position: sticky;
    /* Липнем сразу под шапкой (значение выставляется из JS на странице графика) */
    top: var(--schedule-sticky-top, calc(env(safe-area-inset-top, 0px) + var(--leader-sidebar-under-header)));
    z-index: 9;
    padding: 8px 9px;
    border-radius: 9px;
    border: 1px solid var(--border);
    background: var(--leader-collapsible-bg);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.schedule-location-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 12px;
    margin-bottom: 1rem;
    padding: 9px 12px;
    border-radius: 9px;
    border: 1px solid var(--border);
    background: var(--leader-collapsible-bg);
}

.schedule-location-bar__label {
    font-weight: 700;
    font-size: 10px;
}

.schedule-location-bar__select {
    min-width: min(100%, 240px);
    max-width: 100%;
    padding: 8px 9px;
    border-radius: 9px;
    border: 1px solid var(--border);
    font: inherit;
    background: var(--field-surface);
    color: var(--text);
}

.schedule-days-strip {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 0;
}

.leader-shift-strip-ellipsis {
    padding: 0 2px;
    color: var(--muted);
    user-select: none;
    align-self: center;
    font-weight: 700;
}

.leader-shift-calendar-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    cursor: pointer;
    min-width: 2.75rem;
}

.leader-shift-calendar-native {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
    margin: 0;
}

.leader-shift-roster-form #shift-admin-select,
.leader-shift-washer-row select {
    max-width: 315px;
    width: 100%;
}

.leader-shift-roster-form .leader-shift-field-pay-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
}

.leader-shift-roster-form .leader-shift-pay-for-shift {
    white-space: nowrap;
}

/* Успешное завершение записи (график): без перезагрузки страницы */
.schedule-completion-toast {
    position: fixed;
    right: max(12px, env(safe-area-inset-right));
    bottom: max(12px, env(safe-area-inset-bottom));
    z-index: 10050;
    max-width: min(270px, calc(100vw - 24px));
    padding: 9px 12px;
    border-radius: 8px;
    background: var(--card);
    color: var(--text, #111827);
    border: 1px solid var(--border);
    box-shadow: 0 8px 27px rgba(15, 23, 42, 0.14);
    font-size: 0.95rem;
    line-height: 1.35;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.4s ease, transform 0.4s ease;
    pointer-events: none;
}

.schedule-completion-toast--in {
    opacity: 1;
    transform: translateY(0);
}

.schedule-completion-toast--out {
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.card.schedule-wrap {
    /* Общий полупрозрачный слой графика; липкие колонки времени используют тот же цвет */
    --schedule-surface: color-mix(in srgb, var(--leader-collapsible-bg) 92%, transparent);
    /* Ширина колонок «Время» (фикс.); боксы делят остаток: (контейнер − время×N) / min(боксов, 4) */
    --schedule-time-col-width: 3.25rem;
    margin-top: 10px;
    background: var(--schedule-surface);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.schedule-scroll {
    overflow-x: auto;
    width: 100%;
    container-type: inline-size;
    container-name: schedule-scroll;
}

.schedule-table {
    border-collapse: separate;
    border-spacing: 0;
}

/* До 4 боксов — таблица на всю ширину карточки, боксы равной ширины */
.schedule-scroll--fit .schedule-table {
    width: 100%;
    table-layout: fixed;
}

.schedule-scroll--fit .schedule-col-time {
    width: var(--schedule-time-col-width);
    min-width: var(--schedule-time-col-width);
    max-width: var(--schedule-time-col-width);
}

.schedule-scroll--fit .schedule-col-box {
    width: calc((100% - (var(--schedule-time-col-count, 2) * var(--schedule-time-col-width))) / max(1, var(--schedule-box-count, 1)));
    /* min-width: 0 давало сильное сжатие «Свободно» / «Прошло» и боксов */
    min-width: max(9rem, 118px);
}

/* Больше 4 боксов — горизонтальный скролл; мин. ширина бокса ≈ (ширина области − колонки времени) / min(боксов, 4) */
.schedule-scroll:not(.schedule-scroll--fit) .schedule-table {
    width: auto;
    min-width: 100%;
    table-layout: auto;
}

.schedule-scroll:not(.schedule-scroll--fit) .schedule-col-time {
    width: var(--schedule-time-col-width);
    min-width: var(--schedule-time-col-width);
    box-sizing: border-box;
}

.schedule-scroll:not(.schedule-scroll--fit) .schedule-col-box {
    min-width: max(
        7.5rem,
        calc(
            (100cqi - (var(--schedule-time-col-count, 2) * var(--schedule-time-col-width)))
                / max(1, var(--schedule-slot-divisor, 1))
        )
    );
    box-sizing: border-box;
}

.schedule-table th,
.schedule-table td {
    border-top: 1px solid var(--border);
    padding: 6px 8px;
    vertical-align: top;
}

/* Фиксированная высота слота: «Свободно/Прошло» не растягиваются от соседних записей */
.schedule-table tbody tr {
    height: calc(2 * 1.35em + 12px);
    height: calc(2lh + 12px);
}

/* «Свободно»: кнопка по содержимому, высота строки задаётся tr (не тянем на весь rowspan соседа) */
.schedule-table tbody td.schedule-td-free {
    padding: 6px 8px;
    vertical-align: middle;
    text-align: center;
}

.schedule-table tbody td.schedule-td-common-off {
    background: color-mix(in srgb, var(--field-surface) 72%, var(--bg) 28%);
}

.schedule-table .schedule-common-off-msg {
    display: block;
    white-space: normal;
    word-break: break-word;
    line-height: 1.25;
    max-width: 12rem;
    margin: 0 auto;
    text-align: center;
    font-size: 0.8125rem;
}

.schedule-table tbody td.schedule-td-free .schedule-free-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

/* Удержание слота (онлайн / форма «Новая запись») */
.schedule-table tbody td.schedule-td-slot-hold {
    padding: 6px 8px;
    vertical-align: middle;
    text-align: center;
    background: transparent;
}
/* Несколько слотов подряд — тянем подпись на всю объединённую ячейку */
.schedule-table tbody td.schedule-td-slot-hold-span {
    position: relative;
    padding: 0;
    vertical-align: top;
}
.schedule-table tbody td.schedule-td-slot-hold-span .schedule-hold-btn {
    position: absolute;
    top: 6px;
    left: 8px;
    right: 8px;
    bottom: 6px;
    width: auto;
    height: auto;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

/* Запись: отступ плашки от сетки задаётся в index.css (как у «Свободно» absolute inset 6px / 8px) */
.schedule-table tbody td.schedule-td-booking {
    position: relative;
    padding: 0;
    vertical-align: top;
    height: 100%;
    box-sizing: border-box;
}

.schedule-table tbody td.schedule-td-booking-span {
    padding: 0;
    vertical-align: top;
    background: var(--schedule-surface);
}

/*
 * Многосегментная запись: absolute у .schedule-booking-btn убран — с абсолютным
 * дочерним кнопка не задаёт высоту .schedule-booking-panel, и в ячейке
 * с rowspan остаётся пустая полоса «между слотами». Высоту тянет flex в index.css.
 */

.schedule-table th {
    border-top: 0;
    text-align: left;
    color: var(--muted);
    font-size: 10px;
}

.schedule-table th.schedule-th-box {
    text-align: center;
}

.schedule-table .schedule-th-time,
.schedule-table .schedule-td-time {
    white-space: nowrap;
    padding: 4px 3px;
    font-variant-numeric: tabular-nums;
    text-align: center;
    vertical-align: middle;
    box-sizing: border-box;
}

.schedule-col-time--sticky-left {
    position: sticky;
    left: 0;
    z-index: 2;
    background: var(--schedule-surface);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 3px 0 6px -3px rgba(15, 23, 42, 0.12);
}

.schedule-col-time--sticky-right {
    position: sticky;
    right: 0;
    z-index: 2;
    background: var(--schedule-surface);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: -3px 0 6px -3px rgba(15, 23, 42, 0.12);
}

.schedule-booking-btn,
.schedule-free-btn,
.schedule-hold-btn {
    width: 100%;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--field-surface);
    color: var(--text);
    padding: 7px 8px;
    text-align: left;
    cursor: pointer;
    box-sizing: border-box;
    font-size: 13px;
    line-height: 1.32;
}

.schedule-booking-btn {
    background: rgba(14, 165, 233, 0.08);
    border-color: rgba(14, 165, 233, 0.4);
}

/* Тёмная тема: ячейка «запись» не светится как на светлом фоне */
html[data-simple-ui-theme="dark"] .schedule-booking-btn {
    background: rgba(56, 189, 248, 0.1);
    border-color: rgba(56, 189, 248, 0.26);
    color: var(--text);
}

html[data-simple-ui-theme="dark"] .schedule-cell-services-preview {
    border-color: rgba(56, 189, 248, 0.28);
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.38);
}

@media (prefers-color-scheme: dark) {
    html[data-simple-ui-theme="system"] .schedule-booking-btn {
        background: rgba(56, 189, 248, 0.1);
        border-color: rgba(56, 189, 248, 0.26);
        color: var(--text);
    }

    html[data-simple-ui-theme="system"] .schedule-cell-services-preview {
        border-color: rgba(56, 189, 248, 0.28);
        box-shadow: 0 8px 22px rgba(0, 0, 0, 0.38);
    }
}

.schedule-booking-panel {
    position: relative;
}

.schedule-cell-services-preview {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% - 1px);
    z-index: 25;
    padding: 8px 10px 10px;
    border: 1px solid rgba(14, 165, 233, 0.35);
    border-top: 0;
    border-radius: 0 0 8px 8px;
    background: var(--card-bg, var(--card));
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
    max-height: 210px;
    opacity: 0;
    overflow-y: auto;
    pointer-events: none;
    transform: translateY(-4px);
    transition: opacity 0.14s ease, transform 0.14s ease;
}

.schedule-booking-panel:hover .schedule-cell-services-preview,
.schedule-booking-panel:focus-within .schedule-cell-services-preview {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

/* Плашка записи и превью услуг — поверх соседних ячеек */
.schedule-table tbody td.schedule-td-booking:hover,
.schedule-table tbody td.schedule-td-booking:focus-within {
    z-index: 30;
}

.schedule-booking-panel:hover,
.schedule-booking-panel:focus-within {
    z-index: 40;
}

.schedule-booking-panel:hover .schedule-booking-btn,
.schedule-booking-panel:focus-within .schedule-booking-btn {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    box-shadow: none;
}

.schedule-cell-services-preview__label {
    display: block;
    font-size: 13px;
    color: var(--text);
    font-weight: 600;
    margin-bottom: 4px;
}

.schedule-cell-services-preview__list {
    margin: 0;
    padding-left: 16px;
    font-size: 13px;
    line-height: 1.35;
}

.schedule-booking-actions .btn {
    min-height: 30px;
    font-size: 12px;
    padding: 6px 10px;
}

.schedule-free-btn {
    background: rgba(34, 197, 94, 0.10);
    border-color: rgba(34, 197, 94, 0.35);
}

.schedule-hold-btn {
    background: #fff9c4;
    border-color: rgba(180, 150, 0, 0.35);
    color: #5d4a00;
    cursor: default;
    font-weight: 600;
    line-height: 1.25;
    white-space: normal;
    word-break: break-word;
    text-align: center;
}

.booking-modal {
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0;
    width: min(510px, 92vw);
}

/* Все модалки, кроме «Информация о записи» и «Новая запись»: +20% к базовым габаритам */
.booking-modal:not(#booking-info-modal):not(#booking-create-modal) {
    width: min(612px, 96vw);
    max-height: min(96vh, 738px);
}

/* ЛК (React): только showModal() выводит <dialog> в top layer; иначе с атрибутом open окно оказывалось внизу страницы */
dialog.booking-modal.cabinet-page-dialog {
    margin: auto;
    max-height: min(90vh, 615px);
}

/* «Информация о записи» и «Новая запись» — 80% от ширины основного интерфейса */
#booking-info-modal.booking-modal,
#booking-create-modal.booking-modal {
    width: min(var(--modal-width), calc(100vw - 24px));
    max-width: min(var(--modal-width), calc(100vw - 24px));
    box-sizing: border-box;
}

#booking-info-modal.booking-modal {
    --modal-width: 70vw;
    height: calc(100vh - 24px);
    max-height: calc(100vh - 24px);
    overflow: hidden;
}

#booking-info-modal.booking-modal[open] {
    display: flex;
    flex-direction: column;
}

#booking-create-modal.booking-modal {
    --modal-width: 70vw;
    height: calc(100vh - 24px);
    max-height: calc(100vh - 24px);
    overflow: hidden;
}

#booking-create-modal.booking-modal[open] {
    display: flex;
    flex-direction: column;
}

#booking-create-modal .booking-modal__inner {
    height: 100%;
    max-height: none;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}

#booking-create-modal .booking-create-modal__footer-actions {
    position: sticky;
    bottom: 0;
    background: var(--card-bg, var(--card));
    border-top: 1px solid var(--border);
    padding: 8px 12px 12px;
    margin-top: auto;
    justify-content: flex-end;
    z-index: 3;
    flex-shrink: 0;
}

/* Модалки «Информация о записи» и «Новая запись»: слегка компактнее элементы */
#booking-info-modal .booking-modal__inner,
#booking-create-modal .booking-modal__inner {
    font-size: 0.93rem;
}

#booking-info-modal .booking-modal__inner input:not([type]),
#booking-info-modal .booking-modal__inner input[type="text"],
#booking-info-modal .booking-modal__inner input[type="tel"],
#booking-info-modal .booking-modal__inner input[type="email"],
#booking-info-modal .booking-modal__inner input[type="password"],
#booking-info-modal .booking-modal__inner input[type="number"],
#booking-info-modal .booking-modal__inner input[type="date"],
#booking-info-modal .booking-modal__inner input[type="time"],
#booking-info-modal .booking-modal__inner input[type="datetime-local"],
#booking-info-modal .booking-modal__inner input[type="search"],
#booking-info-modal .booking-modal__inner select,
#booking-info-modal .booking-modal__inner textarea,
#booking-create-modal .booking-modal__inner input:not([type]),
#booking-create-modal .booking-modal__inner input[type="text"],
#booking-create-modal .booking-modal__inner input[type="tel"],
#booking-create-modal .booking-modal__inner input[type="email"],
#booking-create-modal .booking-modal__inner input[type="password"],
#booking-create-modal .booking-modal__inner input[type="number"],
#booking-create-modal .booking-modal__inner input[type="date"],
#booking-create-modal .booking-modal__inner input[type="time"],
#booking-create-modal .booking-modal__inner input[type="datetime-local"],
#booking-create-modal .booking-modal__inner input[type="search"],
#booking-create-modal .booking-modal__inner select,
#booking-create-modal .booking-modal__inner textarea {
    padding: 6px 7px;
}

/* Авто из списка клиента — марка/модель/номер/кузов только для просмотра */
#booking-create-modal input.bc-vehicle-locked,
#booking-create-modal select.bc-vehicle-locked {
    cursor: not-allowed;
    background-color: rgba(241, 245, 249, 0.92);
    color: var(--text);
}

/* Модалка «Новая запись»: незаполненные обязательные блоки */
#booking-create-modal .bc-create-req-group.bc-field-required--missing {
    border-radius: 8px;
    border: 1px solid var(--danger-border);
    background: color-mix(in srgb, var(--danger-soft-bg) 42%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--danger-border) 35%, transparent);
    padding: 8px 9px;
    margin-left: -2px;
    margin-right: -2px;
    box-sizing: border-box;
}

#booking-create-modal .booking-modal__create-phone-name-row.bc-field-required--missing {
    padding: 8px 9px;
}

/* Марка + модель + номер + кузов: одна строка (4 колонки), пока не выбран авто из гаража клиента */
#bc-manual-vehicle-block[hidden] {
    display: none !important;
    margin-bottom: 0;
}

#bc-manual-vehicle-block {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 9px 12px;
    margin-bottom: 10px;
}

#bc-manual-vehicle-block .form-row {
    margin-bottom: 0;
}

/* Марка + модель: занимают две ячейки сетки, внутри — две колонки */
#bc-manual-vehicle-block > .bc-req-vehicle-pair {
    grid-column: span 2;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px 12px;
    align-self: stretch;
}

#bc-manual-vehicle-block > .bc-req-vehicle-pair > .form-row {
    margin-bottom: 0;
}

@media (max-width: 520px) {
    #bc-manual-vehicle-block > .bc-req-vehicle-pair {
        grid-column: 1 / -1;
        grid-template-columns: 1fr;
    }
}

/* «Записать»: недоступна — явно серая */
#booking-create-modal .bc-submit-btn.btn-primary:disabled {
    background: #e2e8f0;
    border-color: #cbd5e1;
    color: #94a3b8;
    cursor: not-allowed;
    opacity: 1;
    box-shadow: none;
}

/* Телефон, автомобиль клиента и ФИО — одна строка */
.booking-modal__create-phone-name-row {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-end;
    gap: 9px 12px;
    margin-bottom: 10px;
}

.booking-modal__create-phone-name-row > .form-row {
    flex: 1 1 0;
    min-width: 0;
    margin-bottom: 0;
}

.booking-modal__create-phone-name-row #bc-client-car-select {
    width: 100%;
    max-width: 100%;
}

#bc-visit-contact-field[hidden] {
    display: none !important;
}

#bc-visit-contact-select {
    width: 100%;
    max-width: 100%;
}

@media (max-width: 720px) {
    .booking-modal__create-phone-name-row {
        flex-wrap: wrap;
    }

    .booking-modal__create-phone-name-row > .form-row {
        flex: 1 1 100%;
    }
}

.booking-modal__create-vehicle-row {
    margin-bottom: 0;
}

.booking-services-columns--create {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-bottom: 6px;
    font-size: 9px;
    font-weight: 700;
    color: var(--muted);
}

.booking-services-columns--create .booking-services-columns__col--service {
    flex: 1 1 0;
    min-width: 0;
}

.booking-services-columns--create .booking-services-columns__col--del {
    flex: 0 0 27px;
    width: 27px;
    min-width: 27px;
}

.booking-service-price-row--create .booking-service-combo {
    flex: 1 1 0;
    min-width: 0;
}

.booking-service-price-row__del-spacer {
    flex: 0 0 27px;
    width: 27px;
    min-width: 27px;
}

/* Онлайн-запись: колонка «Удалить» подпись */
#bk-services-field .booking-services-columns--create .booking-services-columns__col--del {
    flex: 0 0 69px;
    width: 69px;
    min-width: 69px;
}

#bk-services-field .booking-service-price-row__del-spacer {
    flex: 0 0 69px;
    width: 69px;
    min-width: 69px;
}

@media (max-width: 900px) {
    #bc-manual-vehicle-block {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 520px) {
    #bc-manual-vehicle-block {
        grid-template-columns: 1fr;
    }
}

.bc-time-field-label {
    display: block;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--text);
}

.bc-time-tiles {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: stretch;
    max-height: min(28vh, 165px);
    overflow-y: auto;
    padding: 2px 0 4px;
}

/* Общая геометрия: занятые слоты раньше тянули padding от .btn (8px) и визуально «прыгали» */
.bc-time-tile {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    min-height: 30px;
    padding: 6px 9px !important;
    font-variant-numeric: tabular-nums;
    box-sizing: border-box;
}

/* Тот же зелёный, что у кнопки «Свободно» в графике (.schedule-free-btn) */
.bc-time-tile:not(:disabled) {
    background: rgba(34, 197, 94, 0.1) !important;
    border-color: rgba(34, 197, 94, 0.35) !important;
    color: var(--text) !important;
}

.bc-time-tile--selected:not(:disabled) {
    border-color: #15803d !important;
    background: #22c55e !important;
    color: #fff !important;
    font-weight: 700;
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.45), 0 2px 6px rgba(21, 128, 61, 0.35);
}

/* Модалка переноса: .btn перебивает фон — явно усиливаем выбранный слот */
.booking-modal .bc-time-tile.btn.bc-time-tile--selected:not(:disabled) {
    border-color: #15803d !important;
    background: #22c55e !important;
    color: #fff !important;
    font-weight: 700;
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.45), 0 2px 6px rgba(21, 128, 61, 0.35);
}

.br-time-selected-line {
    margin-top: 8px;
    margin-bottom: 0;
    min-height: 1.35em;
}

.br-date-selected-line {
    margin-top: 6px;
    margin-bottom: 0;
    min-height: 1.35em;
}

.br-date-selected-line--picked {
    font-weight: 600;
    color: var(--text);
    font-size: 0.98rem;
}

.br-time-selected-line--picked {
    font-weight: 600;
    color: var(--text);
    font-size: 0.98rem;
}

.bc-time-tile:not(:disabled):hover {
    background: rgba(34, 197, 94, 0.16) !important;
    border-color: rgba(34, 197, 94, 0.45) !important;
}

.bc-time-tile--selected:not(:disabled):hover {
    background: #16a34a !important;
    border-color: #166534 !important;
    color: #fff !important;
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.55), 0 2px 8px rgba(21, 128, 61, 0.4);
}

.bc-time-tile--disabled,
.bc-time-tile:disabled {
    opacity: 0.48;
    cursor: not-allowed !important;
    color: var(--muted) !important;
    background: rgba(15, 23, 42, 0.06) !important;
    border-color: var(--border) !important;
}

/* Выбранное время перестало помещаться в интервал после смены услуг (онлайн-запись) */
.bc-time-tile.bc-time-tile--invalid-duration:disabled {
    opacity: 1 !important;
    color: #fff !important;
    background: var(--danger) !important;
    border-color: var(--danger-strong) !important;
    font-weight: 700;
    box-shadow: 0 0 0 2px var(--danger-ring);
}

.bk-time-invalid-sticky {
    flex: 1 1 100%;
    margin-top: 4px;
    color: var(--danger-text);
    font-weight: 600;
}

.booking-modal::backdrop {
    background: rgba(15, 23, 42, 0.45);
}

.booking-modal__inner {
    padding: 12px;
    max-height: min(86vh, 570px);
    overflow: auto;
}

/* Модалка «Информация о записи»: без прокрутки всей формы — скролл только у списка услуг */
#booking-info-modal .booking-modal__inner {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
    max-height: 100%;
    overflow: hidden;
    box-sizing: border-box;
}

#booking-info-modal .booking-modal__header,
#booking-info-modal .schedule-modal-tabs--sticky {
    flex-shrink: 0;
}

/*
 * flex-basis: 0% — высота не от контента вкладки, только доля свободного места (стабильная смена вкладок).
 */
#booking-info-modal .booking-modal__scroll {
    flex: 1 1 0%;
    min-height: 60px;
    min-width: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-sizing: border-box;
}

/*
 * Футер может сжиматься (flex-shrink), чтобы на вкладке «Услуги» не обрезались кнопки снизу диалога.
 * Прокрутка только внутри .footer-scroll; «По мойщикам» не обрезается снизу за счёт padding-bottom и общего лимита высоты футера.
 */
#booking-info-modal .booking-modal__footer-sticky {
    flex: 0 1 auto;
    min-height: 0;
    min-width: 0;
    max-height: min(46vh, 315px);
    /* Не sticky: иначе блок кнопок может перекрывать длинный контент вкладки «Расчёт» */
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-sizing: border-box;
}

#booking-info-modal .booking-modal__footer-scroll {
    flex: 1 1 auto;
    min-height: 0;
    min-width: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 3px;
    padding-bottom: 12px;
    box-sizing: border-box;
    -webkit-overflow-scrolling: touch;
}

/* Основные действия слева; «Подтвердить номер» справа в том же ряду */
#booking-info-modal #bi-footer-actions #bi-confirm-phone-btn {
    flex-shrink: 0;
    align-self: center;
    margin-left: auto;
}

/* Перебить .btn (иначе [hidden] может не скрыть кнопку в части браузеров) */
#booking-info-modal #bi-footer-actions #bi-confirm-phone-btn[hidden] {
    display: none !important;
}

#booking-info-modal .booking-modal__footer-actions {
    flex-shrink: 0;
    margin-top: 0;
    padding-top: 8px;
    padding-bottom: 2px;
    border-top: 1px solid var(--border);
    background: var(--card-bg, var(--card));
}

@media (max-width: 980px) {
    /* Общий grid для .leader-price-form-actions ломает margin-left: auto у последней кнопки */
    #booking-info-modal #bi-footer-actions.leader-price-form-actions {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 6px;
    }
}

/* [hidden] может не перебить display:flex у .leader-price-form-actions в некоторых каскадах */
#booking-info-modal.booking-modal--completed .booking-modal__footer-actions {
    display: none !important;
    pointer-events: none;
}

#booking-info-modal .schedule-modal-pane.is-active[data-pane="main"],
#booking-info-modal .schedule-modal-pane.is-active[data-pane="services"],
#booking-info-modal .schedule-modal-pane.is-active[data-pane="marketing_calc"],
#booking-info-modal .schedule-modal-pane.is-active[data-pane="comment"] {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    box-sizing: border-box;
}

#booking-info-modal .schedule-modal-pane.is-active[data-pane="main"] {
    justify-content: flex-start;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 3px;
    padding-bottom: 9px;
    box-sizing: border-box;
    -webkit-overflow-scrolling: touch;
}

#booking-info-modal .schedule-modal-pane.is-active[data-pane="comment"] {
    justify-content: flex-start;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 3px;
    padding-bottom: 9px;
    box-sizing: border-box;
    -webkit-overflow-scrolling: touch;
}

/* Скролл только здесь, на всю высоту панели «Услуги» */
#booking-info-modal .booking-modal__services-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 3px;
    box-sizing: border-box;
}

#booking-info-modal [data-bi-completion-highlight].booking-modal--completion-error-target {
    outline: 2px solid var(--danger);
    outline-offset: 2px;
    border-radius: 4px;
    transition: outline-color 0.15s ease, outline-offset 0.15s ease;
}

/* Панель «Расчёт скидок»: длинные таблицы и список акций — прокрутка внутри области вкладки, не под кнопками */
#booking-info-modal .schedule-modal-pane.is-active[data-pane="marketing_calc"] .booking-modal__marketing-calc-pane {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 3px;
    box-sizing: border-box;
    -webkit-overflow-scrolling: touch;
}

.booking-modal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 9px;
    margin-bottom: 3px;
}

.booking-modal__header .booking-modal__title {
    margin: 0;
    flex: 1;
    min-width: 0;
}

.booking-modal__header-close {
    flex-shrink: 0;
}

.booking-modal__line {
    margin: 6px 0;
}

.booking-modal__line--inline {
    margin: 0;
}

.booking-modal__fields-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px 12px;
    margin-bottom: 10px;
}

.booking-modal__fields-row .form-row {
    margin-bottom: 0;
}

#bi-bonus-inline {
    margin-top: 4px;
    white-space: normal;
    word-break: break-word;
}

.booking-modal__fields-row--car-bonus {
    align-items: start;
}

.booking-modal__bonus-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px;
    min-width: 0;
}

.booking-modal__bonus-item {
    margin: 0;
    display: grid;
    grid-template-columns: auto minmax(36px, 54px);
    align-items: center;
    gap: 4px;
    min-width: 0;
}

.booking-modal__bonus-item label {
    display: inline-block;
    font-weight: 700;
    margin-bottom: 0;
    white-space: nowrap;
    font-size: 9px;
}

.booking-modal__bonus-item input {
    min-width: 0;
    width: 100%;
    max-width: 54px;
    padding-left: 6px;
    padding-right: 6px;
}

#bi-bonus-block[hidden],
#bi-bonus-expiring-wrap[hidden] {
    display: none !important;
}

@media (max-width: 860px) {
    .booking-modal__bonus-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 520px) {
    .booking-modal__fields-row {
        grid-template-columns: 1fr;
    }
}

.booking-modal__footer-sticky .booking-modal__comment-block,
#booking-info-modal .booking-modal__footer-scroll .booking-modal__comment-block {
    margin-top: 6px;
    padding-top: 0;
    border-top: none;
}

.booking-modal__comment-block .form-row {
    margin-bottom: 0;
}

.booking-modal__comment-summary {
    cursor: pointer;
    font-weight: 700;
    margin-bottom: 6px;
}

.booking-modal__footer-layout {
    display: flex;
    flex-direction: column;
    gap: 9px;
    margin-bottom: 0;
    min-width: 0;
}

/* Вкладка «Расчёт скидок»: [hidden] + display:flex — в части браузеров/тем подвал оставался видимым */
#booking-info-modal .booking-modal__footer-layout[hidden] {
    display: none !important;
}

.booking-modal__footer-metrics-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 9px 12px;
    align-items: end;
}

.booking-modal__footer-metrics-row .booking-modal__footer-field {
    margin-bottom: 0;
}

/* Подвал «Информация о записи»: мойщик, суммы, ручная скидка, итого — одна строка без горизонтального скролла (поля делят ширину) */
.booking-modal__footer-metrics-row--one-line {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-end;
    gap: 6px 8px;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
}

.booking-modal__footer-metrics-row--one-line .booking-modal__footer-field--metric {
    flex: 1 1 0;
    min-width: 0;
    margin-bottom: 0;
}

.booking-modal__footer-metrics-row--one-line .booking-modal__footer-field--metric:first-child {
    flex: 1.15 1 0;
}

.booking-modal__footer-metrics-row--one-line .booking-modal__footer-field--itogo {
    flex: 1 1 0;
    min-width: 0;
}

.booking-modal__footer-metrics-row--one-line .form-row {
    min-width: 0;
}

.booking-modal__footer-metrics-row--one-line label {
    display: block;
    font-size: 0.74rem;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.booking-modal__footer-metrics-row--one-line select,
.booking-modal__footer-metrics-row--one-line input[type="text"] {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

.booking-modal__footer-metrics-row--one-line .booking-modal__input-with-suffix {
    min-width: 0;
    max-width: 100%;
}

/* Две таблицы пополам: виды оплат | оплаты мойщикам, разделитель — левая граница правой колонки */
.booking-modal__footer-pay-washers-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
    align-items: stretch;
    width: 100%;
    min-width: 0;
}

.booking-modal__footer-ledger-half {
    min-width: 0;
    padding-right: 9px;
    box-sizing: border-box;
}

.booking-modal__footer-ledger-half--washers {
    border-left: 1px solid var(--border);
    padding-left: 12px;
    padding-right: 0;
}

/* Две одинаковые по шапке таблицы: «Вид оплаты | Сумма» и «Мойщик | Сумма» — thead на одной линии */
#booking-info-modal table.booking-modal__footer-ledger--payments,
#booking-info-modal table.booking-modal__footer-ledger--washers {
    display: table;
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    font-size: 0.88rem;
    color: var(--text);
}

#booking-info-modal table.booking-modal__footer-ledger--payments thead,
#booking-info-modal table.booking-modal__footer-ledger--washers thead {
    display: table-header-group;
}

#booking-info-modal table.booking-modal__footer-ledger--payments tbody,
#booking-info-modal table.booking-modal__footer-ledger--washers tbody {
    display: table-row-group;
}

#booking-info-modal table.booking-modal__footer-ledger--payments tr,
#booking-info-modal table.booking-modal__footer-ledger--washers tr {
    display: table-row;
}

#booking-info-modal table.booking-modal__footer-ledger--payments th,
#booking-info-modal table.booking-modal__footer-ledger--payments td,
#booking-info-modal table.booking-modal__footer-ledger--washers th,
#booking-info-modal table.booking-modal__footer-ledger--washers td {
    display: table-cell;
    vertical-align: middle;
}

#booking-info-modal table.booking-modal__footer-ledger--payments th,
#booking-info-modal table.booking-modal__footer-ledger--washers th {
    text-align: left;
    font-weight: 600;
    font-size: 0.78rem;
    color: var(--muted);
    padding: 4px 6px 6px;
    border-bottom: 1px solid var(--border);
    line-height: 1.2;
}

#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__footer-ledger-th--amount,
#booking-info-modal table.booking-modal__footer-ledger--washers .booking-modal__footer-ledger-th--amount {
    text-align: right;
    width: 42%;
}

#booking-info-modal table.booking-modal__footer-ledger--payments td,
#booking-info-modal table.booking-modal__footer-ledger--washers td {
    padding: 4px 6px;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

#booking-info-modal table.booking-modal__footer-ledger--payments tbody tr:last-child td,
#booking-info-modal table.booking-modal__footer-ledger--washers tbody tr:last-child td {
    border-bottom: none;
}

#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__footer-ledger-td--amount,
#booking-info-modal table.booking-modal__footer-ledger--washers .booking-modal__footer-ledger-td--amount {
    text-align: right;
}

#booking-info-modal table.booking-modal__footer-ledger--washers .booking-modal__footer-ledger-td--num {
    text-align: right;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

#booking-info-modal table.booking-modal__footer-ledger--washers .booking-modal__footer-ledger-tr--unassigned td {
    color: var(--muted);
    font-style: italic;
}

#booking-info-modal table.booking-modal__footer-ledger--washers .booking-modal__footer-ledger-tr--common-picker select {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
    padding: 3px 6px;
    font-size: 0.88rem;
    line-height: 1.25;
    border-radius: 4px;
}

.booking-modal__marketing-calc-pane {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 3px 0;
}

.booking-modal__marketing-calc-section {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.booking-modal__marketing-calc-section > .section-title {
    margin-bottom: 0;
}

.booking-modal__marketing-calc-summary {
    display: grid;
    gap: 4px;
}

.booking-modal__marketing-calc-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 9px;
}

.booking-modal__marketing-calc-steps {
    display: grid;
    gap: 6px;
}

.booking-modal__marketing-calc-step {
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--leader-collapsible-bg);
}

.booking-modal__marketing-calc-warnings {
    display: grid;
    gap: 2px;
}

.booking-modal__marketing-calc-ledger-wrap {
    overflow-x: auto;
}

.booking-modal__marketing-calc-ledger {
    width: 100%;
    border-collapse: collapse;
    font-size: 10px;
}

.booking-modal__marketing-calc-ledger th,
.booking-modal__marketing-calc-ledger td {
    border-bottom: 1px solid var(--border);
    padding: 4px 6px;
    text-align: left;
    white-space: nowrap;
}

#booking-info-modal .booking-modal__marketing-calc-ledger td:first-child,
#booking-info-modal .booking-modal__marketing-calc-ledger th:first-child {
    white-space: normal;
    word-break: break-word;
    max-width: min(52vw, 240px);
}

.booking-modal__marketing-calc-ledger th {
    color: var(--muted);
    font-weight: 600;
}

#booking-info-modal .booking-modal__footer-field--compact {
    margin-bottom: 0;
}

#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__pay-select,
#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__pay-amount {
    width: 100%;
    box-sizing: border-box;
    min-height: 0;
    min-width: 0;
    padding: 3px 6px;
    font-size: 0.88rem;
    line-height: 1.25;
    border-radius: 4px;
}

#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__input-with-suffix--compact {
    gap: 3px;
    min-width: 0;
}

#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__input-with-suffix--compact .booking-modal__pay-amount {
    flex: 1;
    min-width: 0;
}

#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__suffix--compact {
    font-size: 0.85rem;
}

#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__footer-ledger-th--pay-remove,
#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__footer-ledger-td--pay-remove {
    width: 2.25rem;
    padding-left: 2px;
    padding-right: 2px;
    text-align: center;
    vertical-align: middle;
}

#booking-info-modal table.booking-modal__footer-ledger--payments .booking-modal__pay-remove-btn {
    min-width: 0;
    padding: 2px 4px;
    line-height: 1.2;
    font-size: 1rem;
}

@media (max-width: 720px) {
    .booking-modal__footer-metrics-row {
        grid-template-columns: 1fr;
    }

    .booking-modal__footer-metrics-row--one-line {
        flex-wrap: wrap;
    }

    .booking-modal__footer-metrics-row--one-line .booking-modal__footer-field--metric {
        flex: 1 1 calc(50% - 4px);
        min-width: min(100%, 105px);
    }

    .booking-modal__footer-pay-washers-row {
        grid-template-columns: 1fr;
    }

    .booking-modal__footer-ledger-half--washers {
        border-left: none;
        border-top: 1px solid var(--border);
        padding-left: 0;
        padding-top: 9px;
        margin-top: 6px;
    }
}

.booking-modal__input-with-suffix {
    display: flex;
    align-items: center;
    gap: 4px;
}

.booking-modal__input-with-suffix input {
    flex: 1;
    min-width: 0;
    width: auto;
}

.booking-modal__suffix {
    flex-shrink: 0;
    font-weight: 600;
    color: var(--muted);
}

.booking-modal__inner input[readonly],
.booking-modal__inner textarea[readonly] {
    background: color-mix(in srgb, var(--field-surface) 86%, var(--bg) 14%);
    color: var(--text);
    font-weight: 600;
    cursor: default;
}

.booking-modal__inner input[readonly].booking-total-clarify {
    color: var(--danger-text);
    font-weight: 700;
}

.schedule-modal-tabs {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 6px 0 9px;
    flex-wrap: wrap;
}

.schedule-modal-tabs__start {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.schedule-modal-tabs--sticky {
    position: sticky;
    top: 0;
    z-index: 3;
    background: var(--card-bg, var(--card));
    padding-bottom: 6px;
}


.schedule-modal-pane {
    display: none;
}

.schedule-modal-pane.is-active {
    display: block;
}

.booking-modal__footer-sticky {
    position: sticky;
    bottom: 0;
    z-index: 3;
    background: var(--card-bg, var(--card));
    border-top: 1px solid var(--border);
    padding-top: 8px;
    margin-top: 8px;
}

/* Как у .form-card: в т.ч. input без type (иначе дефолтные поля браузера в модалках) */
.booking-modal__inner input:not([type]),
.booking-modal__inner input[type="text"],
.booking-modal__inner input[type="tel"],
.booking-modal__inner input[type="email"],
.booking-modal__inner input[type="password"],
.booking-modal__inner input[type="number"],
.booking-modal__inner input[type="date"],
.booking-modal__inner input[type="time"],
.booking-modal__inner input[type="datetime-local"],
.booking-modal__inner input[type="search"],
.booking-modal__inner select,
.booking-modal__inner textarea {
    width: 100%;
    max-width: 100%;
    padding: 7px 8px;
    border: 1px solid var(--border);
    border-radius: 9px;
    background-color: var(--field-surface);
    font: inherit;
    color: var(--text);
    box-sizing: border-box;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.booking-modal__inner select {
    cursor: pointer;
    appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%),
        linear-gradient(135deg, var(--muted) 50%, transparent 50%);
    background-position: calc(100% - 14px) calc(50% - 2px), calc(100% - 10px) calc(50% - 2px);
    background-size: 4px 4px, 4px 4px;
    background-repeat: no-repeat;
    padding-right: 24px;
}

.booking-modal__inner textarea {
    resize: vertical;
    min-height: 66px;
}

.booking-modal__inner input:focus-visible,
.booking-modal__inner select:focus-visible,
.booking-modal__inner textarea:focus-visible {
    outline: none;
    border-color: rgba(14, 165, 233, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
    background-color: var(--field-surface-focus);
}

.booking-modal__inner input:disabled,
.booking-modal__inner select:disabled,
.booking-modal__inner textarea:disabled {
    opacity: 0.68;
    cursor: not-allowed;
    background-color: var(--field-surface-disabled);
}

@media (max-width: 980px) {
    .leader-layout {
        grid-template-columns: 1fr;
    }

    .leader-price-form-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .leader-btn-save {
        margin-left: 0;
        grid-column: 1 / -1;
    }
}

/* Явно одна колонка на всю ширину (перебивает базовый двухколоночный .leader-layout выше 735px) */
.leader-layout.leader-layout--single {
    grid-template-columns: minmax(0, 1fr);
}

/* Личный кабинет: отступы полей, история записей, модалка авто */
.cabinet-form-stack .form-row {
    margin-bottom: 10px;
}

.cabinet-form-stack .form-row:last-of-type {
    margin-bottom: 0;
}

.cabinet-form-stack .form-submit-btn {
    margin-top: 10px;
}

.cabinet-profile-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 10px;
}

.cabinet-form-stack .cabinet-profile-actions .form-submit-btn {
    margin-top: 0;
}

/* Смена пароля в кабинете: подсказка по критериям при фокусе на «Новый пароль» */
.cabinet-page-dialog .cabinet-chpwd-new1-wrap {
    position: relative;
}

.cabinet-page-dialog .cabinet-chpwd-rules-panel {
    margin-top: 6px;
    margin-bottom: 0;
}

/* Бонусы: под кнопкой «Сохранить», в том же стиле карточки кабинета */
.cabinet-bonus-section {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

.cabinet-bonus-section > .section-title {
    margin-bottom: 8px;
}

.cabinet-bonus-details {
    margin: 0;
}

.cabinet-bonus-details > summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 9px;
    flex-wrap: wrap;
    padding: 8px 9px;
    margin: 0;
    border: 1px solid var(--border);
    border-radius: 9px;
    background-color: var(--field-surface);
    font-size: 0.9375rem;
    color: var(--text);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.cabinet-bonus-details > summary::-webkit-details-marker {
    display: none;
}

.cabinet-bonus-summary__trail {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.cabinet-bonus-summary__caret {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    width: 24px;
    height: 24px;
    min-width: 24px;
    border-radius: 6px;
    border: 1px solid var(--border);
    background-color: color-mix(in srgb, var(--field-surface) 84%, transparent);
    color: var(--muted);
    font-size: 0.65rem;
    line-height: 1;
    box-shadow: none;
    transition: transform 0.15s ease, border-color 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}

.cabinet-bonus-details > summary:hover .cabinet-bonus-summary__caret {
    border-color: var(--border);
    background-color: var(--field-surface-focus);
    color: var(--text);
}

.cabinet-bonus-details[open] .cabinet-bonus-summary__caret {
    transform: rotate(-180deg);
}

.cabinet-bonus-details > summary:focus-visible {
    outline: none;
    border-color: rgba(14, 165, 233, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
}

.cabinet-bonus-summary__label {
    font-weight: 700;
}

.cabinet-bonus-summary__value {
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.cabinet-bonus-currency {
    font-weight: 600;
}

.cabinet-bonus-details[open] > summary {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-color: transparent;
}

.cabinet-bonus-reveal-body {
    margin: 0;
    padding: 9px 9px 8px;
    border: 1px solid var(--border);
    border-top: none;
    border-radius: 0 0 9px 9px;
    background-color: color-mix(in srgb, var(--field-surface) 92%, var(--bg) 8%);
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.cabinet-bonus-line {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 9px 12px;
    flex-wrap: wrap;
    font-size: 0.9375rem;
    line-height: 1.35;
}

.cabinet-bonus-line--muted {
    color: var(--muted);
}

.cabinet-bonus-line__label {
    flex: 1 1 auto;
    min-width: min(100%, 12rem);
}

.cabinet-bonus-line__hint {
    font-weight: 400;
    font-size: 0.8125rem;
    color: var(--muted);
}

.cabinet-bonus-line__value {
    flex-shrink: 0;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    text-align: right;
}

body.site-body--has-bg .cabinet-bonus-details > summary,
body.site-body--has-bg .cabinet-bonus-reveal-body {
    background-color: color-mix(in srgb, var(--field-surface) 82%, transparent);
}

body.site-body--has-bg .cabinet-bonus-details > summary:focus-visible {
    border-color: rgba(14, 165, 233, 0.65);
}

body.site-body--has-bg .cabinet-bonus-summary__caret {
    background-color: color-mix(in srgb, var(--field-surface) 70%, transparent);
    border-color: color-mix(in srgb, var(--border) 75%, transparent);
    color: var(--muted);
}

body.site-body--has-bg .cabinet-bonus-details > summary:hover .cabinet-bonus-summary__caret {
    background-color: color-mix(in srgb, var(--field-surface-focus) 75%, transparent);
    border-color: color-mix(in srgb, var(--border) 85%, transparent);
    color: var(--text);
}

.cabinet-filter-hint {
    margin-bottom: 8px;
}

.cabinet-filter-all {
    width: 100%;
    margin-top: 9px;
    box-sizing: border-box;
}

.cabinet-filter-hint-row .cabinet-filter-all {
    width: auto;
    margin-top: 0;
}

.cabinet-history-section {
    overflow-x: clip;
}

/* Статус (слева) и верхняя пагинация (по центру строки) */
.cabinet-history-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 8px 12px;
    margin-bottom: 10px;
    padding-bottom: 9px;
    border-bottom: 1px solid var(--border);
}

.cabinet-history-toolbar--with-pager {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    column-gap: 12px;
    row-gap: 8px;
}

.cabinet-history-toolbar__left {
    min-width: 0;
    justify-self: start;
}

.cabinet-history-toolbar__pager {
    justify-self: center;
}

.cabinet-history-toolbar__balance {
    min-width: 0;
}

.cabinet-history-toolbar .cabinet-bookings-pager {
    margin: 0;
    padding: 0;
    border: none;
}

.cabinet-bookings-status-select {
    min-width: min(100%, 16rem);
    max-width: 100%;
    padding: 6px 24px 6px 9px;
    border: 1px solid var(--border);
    border-radius: 9px;
    background-color: var(--field-surface);
    font: inherit;
    font-size: 0.9375rem;
    color: var(--text);
    cursor: pointer;
    appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%),
        linear-gradient(135deg, var(--muted) 50%, transparent 50%);
    background-position: calc(100% - 14px) calc(50% - 2px), calc(100% - 10px) calc(50% - 2px);
    background-size: 4px 4px, 4px 4px;
    background-repeat: no-repeat;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.cabinet-bookings-status-select:focus-visible {
    outline: none;
    border-color: rgba(14, 165, 233, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
    background-color: var(--field-surface-focus);
}

body.site-body--has-bg .cabinet-bookings-status-select {
    background-color: rgba(15, 23, 42, 0.55);
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.28);
    background-image: linear-gradient(45deg, transparent 50%, rgba(248, 250, 252, 0.75) 50%),
        linear-gradient(135deg, rgba(248, 250, 252, 0.75) 50%, transparent 50%);
}

body.site-body--has-bg .cabinet-bookings-status-select:focus-visible {
    background-color: rgba(15, 23, 42, 0.75);
    border-color: rgba(125, 211, 252, 0.55);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.25);
}

/* Нижняя пагинация — по центру строки */
.cabinet-bookings-pager-strip {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    box-sizing: border-box;
}

.cabinet-bookings-pager-strip--bottom {
    margin-top: 12px;
    padding-top: 9px;
    border-top: 1px solid var(--border);
}

.cabinet-bookings-pager-strip .cabinet-bookings-pager {
    margin: 0;
    padding: 0;
    border: none;
}

body.site-body--has-bg .cabinet-bookings-pager-strip--bottom {
    border-top-color: rgba(255, 255, 255, 0.22);
}

.cabinet-bookings-pager {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 9px 12px;
    color: var(--text);
}

.cabinet-bookings-pager--top {
    margin-bottom: 10px;
    padding-bottom: 9px;
    border-bottom: 1px solid var(--border);
}

.cabinet-bookings-pager--bottom {
    margin-top: 12px;
    padding-top: 9px;
    border-top: 1px solid var(--border);
}

.cabinet-bookings-pager__meta {
    text-align: center;
    line-height: 1.45;
    max-width: min(100%, 28rem);
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.45rem 1rem;
    border-radius: 9999px;
    /* Плашка: текст читается и на светлой странице, и поверх фото (site-body--has-bg) */
    background: rgba(255, 255, 255, 0.96);
    color: #0f172a;
    border: 1px solid rgba(15, 23, 42, 0.1);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}

.cabinet-bookings-pager__arrow {
    font-weight: 700;
    letter-spacing: 0.02em;
    min-width: 2.5rem;
}

/* Фон страницы — фото: подпись и «<<» / «>>» не теряются на тёмном */
body.site-body--has-bg .cabinet-bookings-pager {
    color: #f8fafc;
}

body.site-body--has-bg .cabinet-history-toolbar {
    border-bottom-color: rgba(255, 255, 255, 0.22);
}

body.site-body--has-bg .cabinet-bookings-pager--bottom {
    border-top-color: rgba(255, 255, 255, 0.22);
}

body.site-body--has-bg .cabinet-bookings-pager__meta {
    background: rgba(15, 23, 42, 0.82);
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.14);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.45);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
}

body.site-body--has-bg .cabinet-bookings-pager__arrow.btn.btn-ghost {
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.38);
    background: rgba(15, 23, 42, 0.42);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.75);
}

body.site-body--has-bg .cabinet-bookings-pager__arrow.btn.btn-ghost:hover:not(:disabled) {
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.5);
    color: #fff;
}

.cabinet-form-inline-2 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px 12px;
    align-items: start;
    margin-bottom: 10px;
}

.cabinet-form-inline-2 .form-row {
    margin-bottom: 0;
}

.booking-form-car-inline-4 {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 9px 12px;
    align-items: start;
    margin-bottom: 10px;
}

.booking-form-car-inline-4 .form-row {
    margin-bottom: 0;
}

.booking-form-car-inline-4 .form-row select,
.booking-form-car-inline-4 .form-row input[type="text"] {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

@media (max-width: 900px) {
    .booking-form-car-inline-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 520px) {
    .cabinet-form-inline-2 {
        grid-template-columns: 1fr;
    }

    .booking-form-car-inline-4 {
        grid-template-columns: 1fr;
    }
}

/* Внутри карточки — иначе у .cabinet-cars-scroll (overflow) срезается outline слева и сверху/снизу у крайних */
.cabinet-car-card--filter-selected {
    outline: none;
    box-shadow: inset 0 0 0 2px rgba(14, 165, 233, 0.88);
    position: relative;
    z-index: 1;
}

.cabinet-car-card--orphan {
    border-style: dashed;
    border-color: rgba(14, 165, 233, 0.45);
}

.cabinet-orphan-badge {
    margin-bottom: 3px;
}

.cabinet-filter-hint-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px 8px;
    margin-bottom: 8px;
}

.cabinet-add-car-title {
    font-size: 1rem;
    margin-bottom: 6px;
}

/* Видимых строк ~5 (карточка выше 7.5rem — иначе влезало 6); дальше вертикальный скролл */
.cabinet-cars-scroll {
    max-height: calc(31.25rem + 25px);
    overflow-y: auto;
    /* auto: при достижении низа/верха списка колесо передаётся странице (не contain) */
    overscroll-behavior-y: auto;
    padding: 2px 4px 2px 2px;
}

.cabinet-car-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 9px;
    align-items: center;
    margin-top: 8px;
}

.cabinet-car-delete-form,
.cabinet-import-car-form {
    margin-top: 0;
    display: inline;
}

.cabinet-booking-filter-row {
    max-width: 315px;
    margin-bottom: 12px;
}

.cabinet-booking-headline {
    margin-bottom: 8px;
}

/* Фильтр по авто: гарантированно скрываем карточку (перебивает любые display у .card) */
.cabinet-booking-card[hidden] {
    display: none !important;
}

.cabinet-booking-venue {
    margin-top: 2px;
    margin-bottom: 4px;
    line-height: 1.45;
}

.cabinet-booking-phone-confirm {
    margin-top: 6px;
    margin-bottom: 2px;
}

.cabinet-booking-card__footer {
    margin-top: 9px;
    padding-top: 9px;
    border-top: 1px solid var(--border);
}

.cabinet-booking-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 0;
    margin-bottom: 0;
}

.cabinet-booking-reschedule-dates {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 6px;
}

.cabinet-booking-block {
    margin-top: 6px;
}

.cabinet-booking-label {
    display: block;
    font-weight: 700;
    font-size: 9px;
    margin-bottom: 3px;
    color: var(--muted);
}

.cabinet-booking-services {
    margin: 0;
    padding-left: 1.2em;
}

.cabinet-booking-total {
    margin-top: 9px;
}

.cabinet-booking-done-financial {
    margin-top: 9px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.cabinet-booking-done-financial .cabinet-booking-total--primary {
    margin-top: 0;
}

.cabinet-booking-bonus {
    margin-top: 6px;
}

.booking-form-contact-row {
    display: flex;
    flex-wrap: wrap;
    gap: 9px 12px;
    align-items: flex-start;
    margin-bottom: 10px;
}

.booking-form-contact-row > .form-row {
    flex: 1 1 min(100%, 165px);
    min-width: 0;
    margin-bottom: 0;
}

.booking-form-contact-pass {
    flex: 1 1 150px;
    max-width: min(100%, 240px);
}

.booking-form-contact-pass-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.booking-form-contact-pass-inner input[type="password"] {
    flex: 1 1 90px;
    min-width: 0;
}

.bk-employee-car-row--single {
    grid-template-columns: minmax(0, 1fr);
}

#bk-employee-row .bk-employee-combo input[type="text"] {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.booking-form-section-title {
    margin-top: 1.25rem;
    margin-bottom: 0.35rem;
}

.booking-form-inline-contact + .booking-form-section-title {
    margin-top: 0.75rem;
}

.booking-price-items-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding-left: 0;
    list-style: none;
}

.booking-price-item-check {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-weight: 400;
    cursor: pointer;
}

.booking-price-item-check input {
    margin-top: 3px;
    flex-shrink: 0;
}

.cabinet-booking-extra {
    margin-top: 6px;
}

.cabinet-edit-car-dialog.booking-modal {
    position: relative;
}

/* Узел для createPortal: внутри top layer dialog, иначе список уходит под модалку */
.cabinet-edit-car-dialog__catalog-portal {
    position: absolute;
    left: 0;
    top: 0;
    width: 0;
    height: 0;
    overflow: visible;
    pointer-events: none;
    /* Совпадает с #booking-info-modal / #booking-create-modal .booking-modal__inner — портал вне `.inner`, поэтому задаём здесь */
    font-size: 0.93rem;
    color: var(--text);
}

.cabinet-catalog-dropdown {
    pointer-events: auto;
}

.cabinet-edit-car-dialog .cabinet-catalog-dropdown {
    /* В кабинете меню позиционируется вручную (left/top/width), поэтому надо отключить right:0 из базового дропдауна. */
    right: auto !important;
    box-sizing: border-box;
    background: var(--card-bg, var(--card));
    border: 1px solid var(--border);
    border-radius: 9px;
    box-shadow: 0 9px 30px rgba(15, 23, 42, 0.14);
    padding: 4px 0;
    overflow-y: auto;
}

/* Те же параметры текста/полей, что «Информация о записи» / «Новая запись» */
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body {
    font-size: 0.93rem;
}

.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input:not([type]),
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="text"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="tel"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="email"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="password"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="number"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="date"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="time"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="datetime-local"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body input[type="search"],
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body select,
.cabinet-edit-car-dialog.booking-modal .cabinet-edit-car-dialog__body textarea {
    padding: 6px 7px;
}

.cabinet-edit-car-dialog.booking-modal .cabinet-catalog-dropdown.booking-service-dropdown {
    margin-top: 3px;
    font-size: 0.93rem;
}

.cabinet-edit-car-dialog.booking-modal .cabinet-catalog-dropdown.booking-service-dropdown .booking-service-dropdown__item {
    font: inherit;
    line-height: 1.35;
}

.cabinet-edit-car-dialog.booking-modal .cabinet-catalog-dropdown.booking-service-dropdown .booking-service-dropdown__empty {
    font-size: 10px;
}

.cabinet-edit-car-dialog.booking-modal .cabinet-catalog-dropdown.booking-service-dropdown .booking-service-dropdown__name {
    font-weight: 600;
    color: var(--text);
}

.cabinet-edit-car-dialog.booking-modal .cabinet-catalog-dropdown.booking-service-dropdown .booking-service-dropdown__item:hover,
.cabinet-edit-car-dialog.booking-modal .cabinet-catalog-dropdown.booking-service-dropdown .booking-service-dropdown__item.booking-service-dropdown__item--active {
    background: rgba(14, 165, 233, 0.08);
}

.cabinet-edit-car-dialog .booking-modal__inner,
.cabinet-edit-car-dialog.cabinet-page-dialog .booking-modal__inner {
    padding: 0;
    max-height: 85vh;
    max-height: 85dvh;
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
    box-sizing: border-box;
}

.cabinet-edit-car-dialog__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 9px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}

.cabinet-edit-car-dialog__title {
    margin: 0;
}

.cabinet-edit-car-dialog__body {
    padding: 12px 14px;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.cabinet-edit-car-dialog__footer {
    padding: 9px 14px 12px;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: flex-end;
    flex-shrink: 0;
    background: var(--card-bg, var(--card));
    box-shadow: 0 -4px 12px rgba(15, 23, 42, 0.06);
}

/* ——— Управление сайтом (суперпользователь) ——— */
.page--site-management .page-title {
    margin-bottom: 1rem;
}

.site-management-shell {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 1.25rem 1.75rem;
}

.site-management-sidebar {
    flex: 0 0 13.5rem;
    min-width: 11rem;
    position: sticky;
    top: calc(env(safe-area-inset-top, 0px) + var(--leader-sidebar-under-header));
    align-self: start;
    z-index: 8; /* Ниже sticky-шапки (z-index:10). */
    max-height: calc(
        100vh - env(safe-area-inset-top, 0px) - var(--leader-sidebar-under-header) - env(safe-area-inset-bottom, 0px)
    );
    max-height: calc(
        100dvh - env(safe-area-inset-top, 0px) - var(--leader-sidebar-under-header) - env(safe-area-inset-bottom, 0px)
    );
    overflow-y: auto;
    overscroll-behavior-y: contain;
}

.site-management-sidenav {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.site-management-content {
    flex: 1 1 210px;
    min-width: 0;
}

.site-management__tab {
    display: block;
    padding: 0.5rem 0.75rem;
    border-radius: 0.4rem;
    text-decoration: none;
    color: var(--text);
    font-weight: 500;
    border: 1px solid transparent;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.site-management__tab:hover {
    background: var(--leader-nav-secondary-hover);
    color: var(--primary-dark);
    text-decoration: none;
}

.site-management__tab--active {
    background: var(--leader-nav-active-bg);
    color: var(--primary-dark);
    border-color: var(--leader-nav-active-border);
}

/* На тёмном/фото-фоне делаем боковое меню контрастным и читаемым. */
body.site-body--has-bg .site-management-sidebar {
    background: var(--leader-nav-sidebar-bg);
    border: 1px solid var(--leader-nav-sidebar-border, var(--border));
    border-radius: 9px;
    padding: 0.55rem;
    backdrop-filter: blur(2px);
}

body.site-body--has-bg .site-management__tab {
    color: var(--text);
}

body.site-body--has-bg .site-management__tab:hover {
    background: var(--leader-nav-secondary-hover);
    color: var(--primary-dark);
}

body.site-body--has-bg .site-management__tab--active {
    background: var(--leader-nav-active-bg);
    color: var(--primary-dark);
    border-color: var(--leader-nav-active-border);
}

body.site-body--has-bg .site-management-content {
    background: color-mix(in srgb, var(--card-bg, var(--card)) 94%, transparent);
    border: 1px solid var(--border);
    border-radius: 9px;
    padding: 1rem;
    backdrop-filter: blur(2px);
}

body.site-body--has-bg .site-management-content .site-management-section-title,
body.site-body--has-bg .site-management-content .page-text,
body.site-body--has-bg .site-management-content .muted {
    color: var(--text);
}

.site-management-section-title {
    font-size: 1.2rem;
    font-weight: 600;
    margin: 0 0 0.75rem 0;
    color: var(--text);
}

.site-management-catalog-block__title {
    margin: 0 0 0.5rem 0;
    font-size: 1.1rem;
    font-weight: 600;
}

.site-management-catalog-block__text {
    margin: 0 0 0.75rem 0;
    font-size: 0.95rem;
    line-height: 1.45;
}

.site-management-catalog-block__text code {
    font-size: 0.88em;
}

.site-management-catalog-block__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
}

.site-management-catalog-block__msg {
    margin: 0.75rem 0 0 0;
}

.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;
}

@media (max-width: 900px) {
    .page--site-management .site-management-sidebar {
        display: none !important;
    }
}
