
.log-container[data-v-b067ec67] {
    position: fixed;
    bottom: 20px;
    left: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    z-index: 2;
}
.log[data-v-b067ec67] {
    padding: 12px 20px;
    border-radius: 8px;
    background: #333;
    color: white;
    font-family: Arial, sans-serif;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
    min-width: 220px;
    opacity: 0.95;
}
.log.debug[data-v-b067ec67] {
    background: #c2c6c8;
}
.log.info[data-v-b067ec67] {
    background: #2ecc71;
}
.log.error[data-v-b067ec67] {
    background: #e74c3c;
}

.activeFilter {
    font-weight: bold;
    color: #27ae60;
    border: 2px solid #27ae60;
    padding: 5px 10px;
    border-radius: 5px;
    box-shadow: 0 0 5px #27ae60;
}
.deactiveFilter {
    font-weight: normal;
    color: grey;
    border: 2px solid grey;
    padding: 5px 10px;
    border-radius: 5px;
    box-shadow: 0 0 5px lightgrey;
}
.tooltipParent{position:relative;cursor:pointer}.tooltip{visibility:hidden;background-color:#555;color:#fff;text-align:center;border-radius:5px;padding:5px;position:absolute;bottom:100%;left:50%;transform:translate(-50%);z-index:1;opacity:0;transition:opacity .3s;max-width:400px;min-width:200px;word-wrap:break-word}.tooltipParent:hover .tooltip{visibility:visible;opacity:1}
/* Часть иконок взяты отсюда https://fontawesomeicons.com/ и дополнительно подключены в index.html ссылкой */
.slider-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    max-height: 100vh; /* ограничиваем высоту 100% от высоты экрана */
    max-width: 100vw; /* Ограничиваем ширину в 100% от ширины экрана */
    /* justify-content: center;
    align-items: center; */
    overflow-y: auto; /*если слайдер длиннее окна */
    padding: 5px; /* отступ для предотвращения прилипания к краям окна */
}
.slider-content {
    position: relative;
    background: #fff;
    padding: 5px 5px 5px 5px;
    border-radius: 5px;
    max-height: 100%; /* ограничиваем высоту 99% от высоты экрана */
    /*max-width: 100vw;  Ограничиваем ширину в 99% от ширины экрана */
    /*min-width: 300px;  Минимальная ширина слайдера */
    width: 100vw; /*Минимальная ширина слайдера */
    max-width: 390px;
    /*max-width: 700px; Ограничиваем ширину в 99% от ширины экрана */
    overflow-y: auto; /* добавляем прокрутку */
}
.slider-content2 {
    position: relative;
    background: #fff;
    padding: 5px;
    border-radius: 2px;
    max-height: 99%; /* ограничиваем высоту 99% от высоты экрана */
    min-width: 300px; /* Минимальная ширина слайдера */
    /* overflow-y: auto; добавляем прокрутку */
}
.slider-content-over {
    z-index: 2;
}
.slider-enter-active,
.slider-leave-active {
    transition: opacity 0.5s;
}
.slider-enter,
.slider-leave-to {
    opacity: 0;
}
.modal-modal {
    position: fixed; /* фиксированное позиционирование относительно окна браузера */
    top: 0; /* отступ сверху равен 0 - модальное окно начинается с верха экрана */
    left: 0; /* отступ слева равен 0 - модальное окно начинается с левого края экрана */
    right: 0; /* растягивает блок до правого края экрана */
    bottom: 0; /* растягивает блок до нижнего края экрана */
    background: #f5f7fa; /* затемнение фона (закомментировано) */
    display: flex; /* включает flex-контейнер для удобного центрирования содержимого */
    justify-content: center; /* горизонтальное центрирование содержимого */
    /*  align-items: center; вертикальное центрирование содержимого */
    /*overflow-y: auto;  если слайдер длиннее окна */ /* позволяет прокручивать содержимое, если оно выходит за пределы окна (закомментировано) */
    padding: 20px; /* внутренний отступ, предотвращающий прилипание содержимого к краям окна */
}
.modal-content {
    position: relative; /* относительно позиционированный контейнер для внутренних элементов */
    /* background: #625f59;  фоновый цвет модального окна */
    padding: 20px; /* внутренний отступ для содержимого модального окна */
    border-radius: 5px; /* скругление углов модального окна */
    /* height: 250px;  высота модального окна */
    width: 500px; /* ширина модального окна */
    max-height: 15vh; /* ограничение максимальной высоты модального окна относительно высоты экрана */
    overflow-y: auto; /* добавление вертикальной прокрутки при переполнении содержимого */
    border: 4px solid #27ae60; /* добавлена граница: 2px шириной, сплошная, с золотым цветом */
}
.modal-text {
    justify-content: center; /* горизонтальное центрирование содержимого */
    align-items: center; /* вертикальное центрирование содержимого */
    font-weight: bold; /* Жирный */
    padding-top: 40px; /* внутренний отступ для текста */
}
.modal-yes {
    background-color: #27ae60; /* цвет фона кнопки */
    color: #fff; /* цвет текста кнопки */
    border: none; /* убираем границу у кнопки */
    padding: 10px 20px; /* внутренний отступ кнопки */
    margin-top: 20px; /* отступ сверху для кнопки */
    cursor: pointer; /* изменение формы курсора при наведении на кнопку */
}
.modal-no {
    background-color: #e77164; /* цвет фона кнопки */
    color: #fff; /* цвет текста кнопки */
    border: none; /* убираем границу у кнопки */
    padding: 10px 20px; /* внутренний отступ кнопки */
    margin-top: 20px; /* отступ сверху для кнопки */
    cursor: pointer; /* изменение формы курсора при наведении на кнопку */
}
.modal-no:hover {
    background-color: #ea5b4b; /* цвет фона кнопки */
}
.modal-enter-active,
.modal-leave-active {
    transition: opacity 0.5s; /* плавное изменение прозрачности при появлении и скрытии модального окна */
}
.modal-enter,
.modal-leave-to {
    opacity: 0; /* начальное и конечное состояние прозрачности для анимации */
}
.close-button {
    position: absolute; /* абсолютное позиционирование относительно родительского элемента */
    top: 5px; /* отступ сверху для кнопки закрытия */
    right: 5px; /* отступ справа для кнопки закрытия */
    z-index: 1; /* установка приоритета по слоям для отображения кнопки над другими элементами */
}
/* Кнопки переключения. Используются в смарт процессах, при выборе полей и т.д*/
.switch {
    position: relative;
    display: inline-block;
    width: 60px;
    height: 34px;
}
/* Версия маленького переключателя */
.switch.small {
    width: 30px;
    height: 17px;
}
/* Hide default HTML checkbox */
.switch input {
    display: none;
}
/* The slider */
.slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #ccc;
    -webkit-transition: 0.4s;
    transition: 0.4s;
}
.sliderNotGrey {
    background-color: #27ae60;
}
/* Slider для маленького переключателя */
.switch.small .slider {
    /* размеры наследуются от контейнера .switch.small */
}
/* Кнопка до (ползунок) */
.slider:before {
    position: absolute;
    content: "";
    height: 26px;
    width: 26px;
    left: 4px;
    bottom: 4px;
    background-color: white;
    -webkit-transition: 0.4s;
    transition: 0.4s;
}
/* Ползунок для маленького переключателя */
.switch.small .slider:before {
    height: 13px; /* 26px/2 */
    width: 13px; /* 26px/2 */
    left: 2px; /* 4px/2 */
    bottom: 2px; /* 4px/2 */
}
/* При активном состоянии переключателя */
input:checked + .slider {
    background-color: #27ae60;
}
input:focus + .slider {
    box-shadow: 0 0 1px #27ae60;
}
input:checked + .slider:before {
    -webkit-transform: translateX(26px);
    -ms-transform: translateX(26px);
    transform: translateX(26px);
}
/* Смарт для маленького переключателя */
.switch.small input:checked + .slider:before {
    -webkit-transform: translateX(13px); /* 26px/2 */
    -ms-transform: translateX(13px);
    transform: translateX(13px);
}
/* Rounded sliders */
.slider.round {
    border-radius: 34px;
}
.slider.round:before {
    border-radius: 50%;
}
/* Rounded для маленького переключателя */
.switch.small .slider.round {
    border-radius: 17px; /* высота маленького переключателя */
}
.switch.small .slider.round:before {
    border-radius: 50%;
}
.loader {
    width: 35px;
    height: 16px;
    /* display: block; */
    margin: 5px;
    padding: 5px;
    background-image: radial-gradient(circle 25px at 25px 25px, #fff 100%, transparent 0), radial-gradient(circle 50px at 50px 50px, #fff 100%, transparent 0), radial-gradient(circle 25px at 25px 25px, #fff 100%, transparent 0), linear-gradient(#fff 50px, transparent 0);
    background-size: 50px 50px, 100px 76px, 50px 50px, 120px 40px;
    background-position: 0px 30px, 37px 0px, 122px 30px, 25px 40px;
    background-repeat: no-repeat;
    position: relative;
    box-sizing: border-box;
}
.loader::before {
    content: "";
    left: 5px;
    bottom: 0px;
    position: absolute;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: #27ae60;
    background-image: radial-gradient(circle 8px at 18px 18px, #fff 100%, transparent 0), radial-gradient(circle 4px at 18px 0px, #fff 100%, transparent 0), radial-gradient(circle 4px at 0px 18px, #fff 100%, transparent 0), radial-gradient(circle 4px at 36px 18px, #fff 100%, transparent 0),
        radial-gradient(circle 4px at 18px 36px, #fff 100%, transparent 0), radial-gradient(circle 4px at 30px 5px, #fff 100%, transparent 0), radial-gradient(circle 4px at 30px 5px, #fff 100%, transparent 0), radial-gradient(circle 4px at 30px 30px, #fff 100%, transparent 0),
        radial-gradient(circle 4px at 5px 30px, #fff 100%, transparent 0), radial-gradient(circle 4px at 5px 5px, #fff 100%, transparent 0);
    background-repeat: no-repeat;
    box-sizing: border-box;
    animation: rotationBack 3s linear infinite;
}
.loader::after {
    content: "";
    left: 39px;
    bottom: 0px;
    position: absolute;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background-color: #27ae60;
    background-image: radial-gradient(circle 5px at 12px 12px, #fff 100%, transparent 0), radial-gradient(circle 2.5px at 12px 0px, #fff 100%, transparent 0), radial-gradient(circle 2.5px at 0px 12px, #fff 100%, transparent 0), radial-gradient(circle 2.5px at 24px 12px, #fff 100%, transparent 0),
        radial-gradient(circle 2.5px at 12px 24px, #fff 100%, transparent 0), radial-gradient(circle 2.5px at 20px 3px, #fff 100%, transparent 0), radial-gradient(circle 2.5px at 20px 3px, #fff 100%, transparent 0), radial-gradient(circle 2.5px at 20px 20px, #fff 100%, transparent 0),
        radial-gradient(circle 2.5px at 3px 20px, #fff 100%, transparent 0), radial-gradient(circle 2.5px at 3px 3px, #fff 100%, transparent 0);
    background-repeat: no-repeat;
    box-sizing: border-box;
    animation: rotationBack 4s linear infinite reverse;
}
@keyframes rotationBack {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(-360deg);
    }
}
/* HTML: <div class="loader"></div> */
.loader2 {
    width: fit-content;
    font-weight: bold;
    font-family: sans-serif;
    font-size: 30px;
    padding-bottom: 8px;
    color: #27ae60;
    background: linear-gradient(currentColor 0 0) 0 100%/0% 3px no-repeat;
    animation: l2 2s linear infinite;
}
.loader2:before {
    content: "Загрузка...";
}
@keyframes l2 {
    to {
        background-size: 100% 3px;
    }
}
.multiselect {
    /* width: 500px; */
    min-width: 300px;
    max-width: 80%;
    white-space: pre-wrap;
    /* margin: 0 auto; */
    /* position: relative; */
}
.multiselect_active {
    width: 500px;
    max-width: 80%;
    height: 200px;
}
/* Настройка контейнера выпадающего списка */
.multiselect__content {
    /*background-color: #00000080; /* Цвет фона */
    /*border: 1px solid #bdc3c7; /* Цвет границы */
    /*border-radius: 8px; /* Скругление углов */
    /*box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* Тень */
    max-height: 200px; /* Максимальная высота */
    overflow-y: auto; /* Прокрутка, если список длинный */
}
/* Настройка опций в выпадающем списке */
.multiselect__option {
    /*padding: 10px; /* Внутренние отступы */
    /*font-size: 14px;  Размер текста */
    /*color: #ffffff; /* Цвет текста */
    /* cursor: pointer; Указатель мыши при наведении */
    /* transition: background-color 0.3s;  Плавный переход цвета фона */
}
/* Стилизация опции при наведении */
.multiselect__option:hover {
    /*background-color: #00000080; /* Цвет фона при наведении */
}
/* Стилизация выделенной опции */
.multiselect__option--highlight {
    /*background-color: #00000080; /* Цвет фона выделенной опции */
    /* color: #fff; /* Цвет текста выделенной опции */
}
/* Настройка текста внутри выпадающего списка */
.multiselect__single {
    /* font-weight: bold; /* Жирный текст */
    /* color: #2c3e50; /* Цвет текста */
    /*background-color: #00000080; /* Цвет фона выделенной опции */
}
/* Стилизация выбранного элемента */
.multiselect__option--selected {
    /*background-color: #00000080; /* Синий фон */
    /*color: #ffffff; /* Белый текст */
    /*font-weight: bold; /* Жирный текст */
}
/* Стилизация повторно выбранного элемента */
.multiselect__option--reselected {
    /*background-color: #00000080; /* Темно-синий фон */
    /*color: #ffffff; /* Белый текст */
    /*font-style: italic; /* Курсивный текст */
}
/* Кнопки */
button {
    display: inline-block;
    background-color: #27ae60;
    color: #fff;
    border: none;
    padding: 10px 20px;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s;
    margin: 10px;
}
button.big {
    font-size: 25px;
    padding: 5px 10px;
    margin: 1px 1px;
}
button.small {
    font-size: 15px;
    padding: 5px 10px;
    margin: 1px 1px;
}
button.add-product {
    margin: 3px 10px 0px 3px;
}
button:hover {
    background-color: #2ecc71;
}
/* Стили для активной (отмеченной) кнопки */
button.active {
    background-color: #f39c12; /* изменённый цвет для выделенной кнопки */
}
button.disabled {
    background-color: #bdc3c7; /* изменённый цвет для выделенной кнопки */
}
button.disabled:hover {
    background-color: #bdc3c7; /* Оставляем цвет без изменений */
    cursor: not-allowed; /* Указываем, что кнопка недоступна */
}
button.cancel,
button.delete {
    background-color: #a30c0c; /* изменённый цвет для выделенной кнопки */
}
button.close {
    position: absolute;
    top: 5px;
    right: 5px;
    z-index: 1;
    background-color: #a30c0c;
}
/* Кнопка "Переменные" начало */
.variables-button {
    position: fixed;
    margin: 10px;
    top: 50px;
    right: 10px;
    background-color: #007bff;
    color: white;
    border: none;
    padding: 10px 15px;
    border-radius: 5px;
    cursor: pointer;
    z-index: 1;
}
.variables-container {
    position: fixed;
    margin: 5px;
    top: 50px;
    right: 10px;
    color: white;
    border: none;
    padding: 5px;
    border-radius: 5px;
    cursor: pointer;
    z-index: 1;
}
.variables-button:hover {
    background-color: #0056b3;
}
/* Кнопка "Переменные" конец */
/* новый input начало */
.input-main {
    position: relative;
    /* margin: 20px 0; */
    font-family: sans-serif;
    margin-top: 20px;
}
.input-main label {
    position: absolute;
    top: 0;
    left: 10px;
    background: white;
    padding: 0 5px;
    font-size: 12px;
    color: #666;
    transform: translateY(-50%);
    max-width: 90%;
}
.input-main input,
.input-main select,
.input-main textarea {
    padding: 12px 10px 8px;
    font-size: 16px;
    border: 1px solid #ccc;
    border-radius: 4px;
    outline: none;
    box-sizing: border-box;
    max-width: 60%;
    min-width: 500px;
    font-family: sans-serif;
    background-color: white;
    cursor: pointer;
}
.input-main input:focus,
.input-main select:focus {
    border-color: #000;
}
.input-main select:hover {
    border-color: #999;
}
.input-main select option {
    padding: 8px;
    font-size: 16px;
}
/* новый input конец */
.input-main .multiselect {
    padding-top: 14px; /* чтобы label не налезал на текст */
    box-sizing: border-box;
}
.input-main .multiselect__tags {
    padding: 12px 10px 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    min-height: 42px;
}
.input-main .multiselect--active .multiselect__tags {
    border-color: #000;
}
/* Сообщение при наведении на элемент начало  */
.tooltipParent {
    position: relative; /* Чтобы подсказка позиционировалась относительно родителя */
    cursor: pointer;
}
.tooltip {
    font-size: 12px;
    visibility: hidden;
    background-color: #555;
    color: #fff;
    text-align: center;
    border-radius: 5px;
    padding: 6px 8px;
    position: absolute;
    bottom: calc(100% + 6px); /* Расположить подсказку над элементом */
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
    opacity: 0;
    transition: opacity 0.18s ease;
    box-sizing: border-box;

    /* предотвращаем выход за viewport */
    max-width: calc(100vw - 32px); /* не шире окна с отступом */
    min-width: 120px; /* минимально читабельная ширина */
    overflow-wrap: anywhere; /* переносит длинные слова/URL */
    word-break: break-word;
    white-space: normal;

    /* если текст большой — даём скролл внутри подсказки */
    max-height: 40vh;
    overflow: auto;
}
/* .switch:hover .tooltip, */
.tooltipParent:hover .tooltip {
    visibility: visible;
    opacity: 1;
}
/* Сообщение при наведении на элемент конец */
/* Сброс базовых стилей */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
/* Основной стиль для body */
body {
    font-family: "Open Sans", sans-serif;
    /* background-color: #f5f7fa; */
    color: #333;
    line-height: 1.6;
    padding: 20px;
    /* display: flex; добавлено для выравнивания по центру */
    /* flex-direction: column; элементы располагаются в колонку */
    align-items: center; /* центрирование по горизонтали */
    justify-content: center; /* центрирование по вертикали */
    /* min-height: 100vh; минимальная высота экрана */
    /* min-width: 100vh; минимальная ширина экрана */
    width: 100%; /* Гарантирует, что body занимает всю ширину */
    max-width: 100vw; /* Предотвращает горизонтальную прокрутку */
}
/* Класс чтобы при открытии слайдеров, прокрутка работала только у слайдеров. */
body.no-scroll {
    overflow: hidden;
}
/* Заголовки */
h1,
h2,
h3,
h4,
h5,
h6 {
    color: #2c3e50;
    margin-bottom: 15px;
}
/* Ссылки */
a {
    color: #2980b9;
    text-decoration: none;
    transition: color 0.3s;
}
a:hover {
    color: #3498db;
}
.rounded-border {
    border: 2px solid #bdc3c7; /* серый цвет границы */
    border-radius: 2px; /* скругление углов */
    padding: 10px; /* внутренние отступы для содержимого */
}
.big-text {
    font-size: 20px; /* размер текста */
    font-weight: bold; /* жирный текст */
}
.small-text {
    font-size: 12px; /* размер текста */
    font-weight: normal; /* обычный текст */
}
/* Списки */
ul {
    list-style-type: disc;
    padding-left: 20px;
    margin-bottom: 15px;
}
/* Текстовые блоки и абзацы */
p {
    margin-bottom: 15px;
}
/* Навигация */
nav {
    /* background-color: #f5f7fa; */
    padding: 10px 20px;
    border-radius: 4px;
    margin-bottom: 20px;
    align-items: center; /* центрирование по горизонтали */
}
nav a {
    color: #ecf0f1;
    margin-right: 15px;
}
nav a:hover {
    color: #bdc3c7;
}
/* Таблицы */
table.main {
    width: auto;
    padding: 10px;
    border-spacing: 0;
    border-collapse: collapse;
    margin-bottom: 20px;
    line-height: 1;
    /* white-space: nowrap; */
}
.main tr {
    border: none; /* Убираем границы у строк */
}
.main td,
.main th {
    border: 2px solid #e1e8ed; /* Границы только у ячеек */
    padding: 10px 15px;
}
/* Только для строк первого уровня в .main */
table.main > tbody > tr:hover > td,
table.main > tr:hover > td {
    border-bottom: 2px solid #27ae60;
}
/* Стили для таблиц с переносом слов */
table.word-wrap td.word-wrap {
    word-wrap: break-word; /* Перенос слов */
    word-break: break-word; /* Перенос слов */
    white-space: normal; /* Убирает запрет на перенос строк */
}
select {
    min-width: 500px;
}
