﻿/* Стили для вкладки Обзор */
.page-content {
    padding: 20px;
}

.controls-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 5px;
    /*    flex-wrap: wrap;*/
    
    /*    height: var(--footer-height);*/
}

.search-box {
    display: flex;
    gap: 10px;
}

.filters {
    display: flex;
    justify-content: space-between;
    align-items: center;
/*    gap: 15px;*/
    align-items: center;
    width: auto;
    padding: 0.5vh 0;
    /*    max-width: 20vw;*/
}
    .filters select {
        /*max-width: 200px;*/ /* или нужное вам значение */
        width: auto;
        max-width: 20vw;
    }
.devices-container {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-height: 710px; /* Фиксированная высота с учетом других элементов */
    position: relative;
    /*    background-color: var(--fon-color);*/
    /*border-radius: 2px;*/ /* ← И ЭТО */
}

.devices-table, .device-input-table {
    width: auto;
    max-width: 100%;
    margin: 0;
    table-layout: fixed;
    border-collapse: separate; /* ← ИЗМЕНИТЕ НА separate */
    border-spacing: 0;
    border: none; /* ← УБРАТЬ границу у таблицы */
    border-top: 2px solid #a4b0ba;
    border-spacing: 0;
    border-radius: 2px;
    overflow: clip;
    overflow-x: visible;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    /*    min-width: 100%;*/
}
/*    .devices-table th {
        border-right: 1px solid #a4b0ba;
    }*/
    .devices-table th,
    .devices-table td, .device-input-table th,
    .device-input-table td {
        font-weight: normal;
        padding: 0.2vh 0.5vw;
        text-align: left;
/*                border-left: 1px solid #a4b0ba;*/
        vertical-align: middle;
        font-size: clamp(10px, 1vw, 16px);
        color: black;
        word-break: normal; /* Перенос слов */
        white-space: normal; /* Изменяем nowrap на normal */
        overflow: visible; /* Изменяем hidden на visible */
        text-overflow: clip; /* Изменяем ellipsis на clip */
        height: 2.5vh;
       
    }
    .column-status {
        width: 3.5vw !important;
/*        min-width: 80px !important;
        max-width: 80px !important;*/
        word-break: normal !important;
        white-space: nowrap !important;
    }

.column-time {
    width: 7vw !important;
    word-break: normal !important;
    white-space: nowrap !important;
    /*    min-width: 180px !important;
    max-width: 180px !important;*/
}
.device-input-table th, .devices-table th {
    border-left: 1px solid #a4b0ba
}

/*.devices-table {
    table-layout: auto;
    width: auto;
    min-width: 100%;
    max-width: 100%;
}

    .devices-table th,
    .devices-table td {
        max-width: 100vw;*/ /* Не больше ширины viewport */
    /*overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }*/
    /* Градиентный переход для заголовков */
    /*.devices-table th,
    .device-input-table th {
        position: sticky;
        top: 0;
        z-index: 10;
        color: #2c3e50;*/ /* Более темный цвет текста */
    /*        border-top: 1px solid var(--second-color);*/
    /*text-shadow: 0 1px 1px rgba(255, 255, 255, 0.8);*/ /* Легкая тень текста */
    /*}*/

/*.devices-table th,
.device-input-table th {
 
    position: sticky;
    top: 0;
    z-index: 10;
}*/
    /* Четные строки */
    .devices-table tbody tr:nth-child(even), .device-input-table tbody tr:nth-child(even) {
        background: var(--fon-color)
    }

    /* Нечетные строки */
    .devices-table tbody tr:nth-child(odd), .device-input-table tbody tr:nth-child(odd) {
        background: white
    }

    /* Эффект при наведении на строку */
    .devices-table tbody tr:hover, .device-input-table tbody tr:hover {
        background: rgb(from var(--main-color) r g b / 20%);
        transform: translateY(-1px); /* Легкое поднятие */
        box-shadow: 0 2px 8px rgba(33, 150, 243, 0.2);
    }



    /* Убираем градиенты для заголовков, чтобы не конфликтовало */
 
/*    .device-input-table th:nth-child(even),
    .device-input-table th:nth-child(odd) {
        background: var(--fon-content-color) !important;
    }*/

    /*    .devices-table tbody tr:last-child td {
        border-bottom: 3px solid #ccd4da;
    }

    .devices-table td:last-child {
        border-right: 3px solid #ccd4da;
    }

    .devices-table th:last-child {
        border-right: 3px solid #ccd4da;
    }

    .devices-table tr {
        border-bottom: 3px solid #ccd4da;
    }*/

    /* Фикс для границ при прокрутке */
/*    .devices-table thead th, .device-input-table thead th {
        border: 2px solid #a4b0ba;
    }*/

    /* Фикс для дергания колонок */
    .devices-table colgroup, .device-input-table colgroup {
        display: table-column-group;
    }

    .devices-table td span {
        display: inline;
        line-height: 1;
        padding: 0;
        margin: 0;
        white-space: nowrap;
        overflow: hidden;
        max-height: 100%;
    }

/* Добавляем плавную анимацию для всей таблицы */
.devices-table, .device-input-table {
    transition: all 0.3s ease;
}

    /* Стиль для активной/выделенной строки */
    .devices-table tbody tr.active, .device-input-table tbody tr.active {
        background: linear-gradient(135deg, #2196f3 0%, #1976d2 100%) !important;
        color: white !important;
    }

        .devices-table tbody tr.active td, .device-input-table tbody tr.active td {
            color: white !important;
            border-color: rgba(255, 255, 255, 0.2) !important;
        }


    .hidden-column {
        display: none;
    }

    /* Стили для выпадающего списка */
    .dropdown {
        position: relative;
        display: inline-block;
    }

    .dropdown-toggle {
        background: none;
        border: none;
        color: var(--second-color);
        cursor: pointer;
        padding: 5px 10px;
        font-size: inherit;
    }

        .dropdown-toggle:hover {
            text-decoration: underline;
        }

    .dropdown-content {
        display: none;
        position: absolute;
        background-color: #f9f9f9;
        min-width: 200px;
        box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
        z-index: 1;
        border-radius: 4px;
        /* padding: 10px; */
        left: 0;
        top: 100%;
    }
    .dropdown:hover .dropdown-content {
        display: none; /* Отключаем реакцию на hover */
    }

    .dropdown:active .dropdown-content {
        display: block;
    }

    .hart-value {
        font-weight: bold;
        color: var(--second-color);
        margin-bottom: 5px;
    }

    .device-info {
        color: #555;
        font-size: 0.9em;
        margin: 3px 0;
    }

    /* Иконка статуса */
.devices-table td .status-icon,
.device-input-table td .status-icon {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-right: 6px;
    vertical-align: middle;
}
.devices-table table {
    width: 100%;
    table-layout: fixed;
    border-collapse: collapse; /* обычно добавляют для единого стиля границ */
}

/* Для всех ячеек кроме последних в строке */
.devices-table td:not(:last-child),
.devices-table th:not(:last-child) {
    width: auto;
/*    min-width: 50px;*/
    white-space: nowrap; /* предотвращает перенос текста */
}

/* Для последних ячеек в строке */
.devices-table td:last-child,
.devices-table th:last-child {
    width: 100%;
}
.status-icon.connected {
    background-color: #28a745;
    box-shadow: 0 0 4px rgba(40, 167, 69, 0.5);
}

.status-icon.middleConnect {
    background-color: #ffc107;
    box-shadow: 0 0 4px rgba(255, 193, 7, 0.5);
}

.status-icon.disconnected {
    background-color: #dc3545;
    box-shadow: 0 0 4px rgba(220, 53, 69, 0.5);
}

.status-icon.null {
    background-color: #6c757d;
    box-shadow: 0 0 4px rgba(108, 117, 125, 0.5);
}

/* Стили для выравнивания в таблице истории */
/*.device-input-table td {*/
    /* display: flex; ← УБРАТЬ ЭТУ СТРОЧКУ */
    /* align-items: center; ← УБРАТЬ ЭТУ СТРОЧКУ */
    /*padding: 8px 4px;
    vertical-align: middle;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}*/

    .device-input-table td .status-icon {
        flex-shrink: 0;
        margin-bottom: 3px;
        margin-left: 6px;
    }

/* Или альтернативный вариант без flex */


/* Стили для кнопок действий */
.action-btn {
    min-width: 90px;
    margin: 2px;
    padding: 6px 10px;
    font-size: 0.85em;
}

/* Полоса прокрутки (для вебкит-браузеров) */
.devices-container::-webkit-scrollbar {
    height: 8px;
}

.devices-container::-webkit-scrollbar-thumb {
    background-color: rgba(0,0,0,0.2);
    border-radius: 4px;
}
.devices-table td .status-icon {
    display: inline-flex;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-left: 6px;
    vertical-align: middle;
    flex-shrink: 0;
}

/* Для ячеек с индикатором */
/*.devices-table td[data-column="last_update"] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    white-space: nowrap;
    overflow: visible;*/ /* переопределяем ellipsis */
/*}*/

/* Альтернативный вариант - если flex не работает */
/*.devices-table td[data-column="last_update"] {
    vertical-align: middle;
    line-height: normal;
}

    .devices-table td[data-column="last_update"] .status-icon {
        display: inline-block;
        vertical-align: middle;

        margin-bottom: 3px;
    }*/

.stats-bar {
    display: flex;
    justify-content: space-around;
    align-items: center;
    gap: 0 0.5vw;

    border-radius: 5px;
}

.stat-item {
    display: flex;
/*    gap: 5px;*/
}

.stat-label {
    font-weight: bold;
}

#export-btn {
    background-color: var(--second-color);
    color: white;
    border: none;
    padding: 8px 15px;
    border-radius: 4px;
    cursor: pointer;
}

    #export-btn:hover {
        background-color: var(--main-color);
    }

.highlight {
    background-color: yellow;
    font-weight: bold;
}

/* Зеленая подсветка для обновленных данных */
.updated-highlight {
    animation: greenFlash 1s ease-out;
}

@keyframes greenFlash {
    0% {
        background-color: #4CAF50;
        color: white;
    }
    100% {
        background-color: transparent;
        color: inherit;
    }
}

/* Стили для формы добавления датчика начало */
.device-form {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: white;
    padding: 1vh 1vw;
    border-radius: 8px;
    box-shadow: 0 0 20px rgba(0,0,0,0.2);
    z-index: 1000;
    width: auto;
    max-width: clamp(500px, 70vw, 1000px);
    min-width: clamp(400px, 40vw, 600px);
    
    /*    max-height: calc(95vh - var(--header-height) - var(--footer-height)) ;*/
    overflow-y: auto;
}
.table-container {
    width: 100%;
    min-width: 80%;
    overflow-y: auto;
    max-height: calc(80vh - var(--header-height) - var(--footer-height));
}

.device-input-table {
    /*    width: 100%;*/
    /*    margin: 20px 0;*/
    border-collapse: collapse;
    min-width: 100%;
}

/*    .device-input-table th, .device-input-table td {
        padding:0.3vh 0.3vw;
        border: 1px solid #ddd;
        text-align: left;
    }*/

.form-input {
    width: 100%;
    padding: clamp(5px, 0.5vh, 10px) 2px;
    box-sizing: border-box;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.status-message {
/*    margin-top: 15px;
    padding: 10px;*/
margin-top: 1vh;
padding: 0.5vh 0.5vw;
    border-radius: 4px;
}

.status-processing {
    background-color: #fff3cd;
    color: #856404;
}

.status-success {
    background-color: #d4edda;
    color: #155724;
}

.status-error {
    background-color: #f8d7da;
    color: #721c24;
}
.View-table tr {
    transition: all 0.3s ease;
}
/*.View-table td:empty {
    background-color: #f9f9f9;
}*/

/* Стили для primary параметров */
/*.primary-param td {
    border-top: 2px solid #ddd;
}*/

/* Стили для secondary параметров */
/*.secondary-param td {
    background-color: #f5f5f5;
}*/

/* Стили для формы добавления датчика конец*/

/* Стили для ячейки статуса */
td[data-column="connection_status"] {
    position: relative;
    /* Скрываем текст */
    font-size: 0;
    color: transparent;
    /* Центрируем содержимое */
    text-align: left;
/*    padding: 4px;*/
    padding-left: 1vw;
}

    td[data-column="connection_status"].connected::before, td[data-column="polling_period"].connected::after, td[data-column="location"].connected::after {
        content: "";
        display: inline-block;
        width: 12px;
        height: 12px;
        border-radius: 50%;
        background-color: #4CAF50;
        box-shadow: 0 0 4px rgba(76, 175, 80, 0.7);
    }

    td[data-column="connection_status"].disconnected::before, td[data-column="polling_period"].disconnected::after, td[data-column="location"].disconnected::after {
        content: "";
        display: inline-block;
        width: 12px;
        height: 12px;
        border-radius: 50%;
        background-color: #F44336;
        box-shadow: 0 0 4px rgba(244, 67, 54, 0.5);
    }

    #ip_aside.connected::after, #ip_aside.disconnected::after {
        content: "";
        display: inline-block;
        width: 12px;
        height: 12px;
        border-radius: 50%;
        margin-left: 8px;
    }

    #ip_aside.connected::after {
        background-color: #4CAF50;
        box-shadow: 0 0 4px rgba(76, 175, 80, 0.7);
    }

    #ip_aside.disconnected::after {
        background-color: #F44336;
        box-shadow: 0 0 4px rgba(244, 67, 54, 0.5);
    }
    td[data-column="connection_status"].middleConnect::before, td[data-column="polling_period"].middleConnect::after, td[data-column="location"].middleConnect::after {
        content: "";
        display: inline-block;
        width: 12px;
        height: 12px;
        border-radius: 50%;
        background-color: yellow;
        box-shadow: 0 0 4px rgba(244, 67, 54, 0.5);
    }
td[data-column="polling_period"].connected::after, td[data-column="location"].connected::after {
    margin-left: 5px;
    margin-top: 3px;
}

td[data-column="polling_period"].disconnected::after, td[data-column="location"].disconnected::after {
    margin-left: 5px;
    margin-top: 3px;
}

td[data-column="polling_period"].middleConnect::after, td[data-column="location"].middleConnect::after {
    margin-left: 5px;
    margin-top: 3px;
}


.btn {
    background-color: var(--second-color);
    color: white;
    border: none;
    padding: 0.5vh 0.5vw;
    border-radius: 4px;
    cursor: pointer;
}
.Click {
    transition: all 0.2s ease; /* Плавные анимации */
    content: "▼";
    font-size: 0.9em;
    margin-right: 5px;
}

    .Click:hover {
        color: var(--main-color);
        cursor: pointer;
        content: "▶";

    }

        /* Треугольник вниз перед текстом при наведении */



    .Click:active {
        transform: scale(0.98);
    }