/* ========================================================================
   1. ГЛОБАЛЬНІ НАЛАШТУВАННЯ ТА STICKY FOOTER
   ======================================================================== */
html,
body {
    height: 100%;
}

body {
    display: flex;
    flex-direction: column;
}

.wrap {
    padding-top: 70px;
    flex-shrink: 0;
}

.map-layout main {
    padding-top: 56px; /* Висота фіксованого NavBar */
    min-height: calc(100dvh); /* Віднімаємо висоту футера */
}

/* ========================================================================
   2. ВЕРХНЄ МЕНЮ (NAVBAR)
   ======================================================================== */
.navbar {
    box-shadow: 0 2px 4px rgba(0,0,0,.1);
    /* z-index: 1030; */
}

.navbar.shadow-none {
    box-shadow: none !important;
}

/* ========================================================================
   4. ГОЛОВНИЙ КОНТЕНТ (MAIN CONTENT)
   ======================================================================== */
.main-content {
    background-color: #fff;
    flex-grow: 1;
    overflow-x: hidden;
}

.map-layout .main-content > div {
    padding: 0 !important;
}

.breadcrumb {
    background-color: transparent;
    padding: 0.75rem 0;
    margin-bottom: 1rem;
}

/* ========================================================================
   5. КАРТКИ ТА ВІДЖЕТИ (SITE INDEX)
   ======================================================================== */
.card {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    border: none;
    box-shadow: 0 0.125rem 0.25rem rgba(0,0,0,0.075);
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

/* ========================================================================
   6. ФУТЕР (FOOTER)
   ======================================================================== */
.footer {
    height: 40px;
    line-height: 24px;
    background-color: #f8f9fa;
    border-top: 1px solid #dee2e6;
    margin-top: auto;
    font-size: 0.85rem;
}

/* Стиль темного футера для акценту (якщо використовується bg-dark) */
.footer.bg-dark {
    background-color: #343a40 !important;
    color: #adb5bd;
    border-top: 3px solid #28a745;
}

.footer a {
    color: inherit;
    text-decoration: none;
}

.footer a:hover {
    color: #28a745;
}

/* 1. Скидання висоти та заборона скролу body */
html body.map-only-layout {
    height: 100% !important;
    margin: 0;
    padding: 0;
    overflow: hidden;
}

/* 2. Основний сайдбар */
.main-sidebar {
    width: 260px;
    min-width: 260px;
    background-color: #2d353c !important;
    height: 100dvh;
    display: flex;
    flex-direction: column;
    z-index: 1050;
    transition: transform 0.3s ease;
}
.main-sidebar .side-nav .nav-link {
    color: #a8afb7 !important;
    font-size: 14px;
    padding: 2px 1em;
}
/* Основний контейнер сайдбара */
.sidebar {
    height: 100vh; /* Сайдбар займає всю висоту в'юпорта */
    height: 100dvh; /* Для коректної висоти на iOS */
    display: flex;
    flex-direction: column;
    overflow: hidden; /* Забороняємо загальний скрол панелі */
}
/* Блок з меню та списком подій, який має скролитись */
.sidebar-scroll-content {
    flex-grow: 1; /* Займає весь доступний простір */
    overflow-y: auto; /* Додає вертикальний скрол, якщо контент не вміщується */
    
    /* Плавний скрол на iOS */
    -webkit-overflow-scrolling: touch;
}

/* Стилізація скролбару (опціонально, щоб він був тонким і охайним) */
.sidebar-scroll-content::-webkit-scrollbar {
    width: 6px;
}

.sidebar-scroll-content::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.1);
}

.sidebar-scroll-content::-webkit-scrollbar-thumb {
    background: #4b545c; /* колір під вашу темну тему */
    border-radius: 3px;
}
.nav-link.d-flex {
    width: 100%;
    display: flex !important;
    align-items: center;
    justify-content: space-between; /* Розносить текст вліво, а іконку вправо */
}

/* Робимо посилання гнучким контейнером */
.custom-nav-link {
    display: flex !important;
    align-items: center;
    width: 100%;
    white-space: nowrap; /* Забороняє перенос тексту на новий рядок */
    padding-right: 15px !important;
}

/* Змушуємо текст (span) займати весь вільний простір */
.custom-nav-link span {
    flex-grow: 1;
    margin-right: 10px;
}

/* Іконка зліва (коробочка) */
.custom-nav-link i.fa-inbox {
    min-width: 35px;
}

/* Стрілочка справа */
.caret-icon {
    transition: transform 0.2s ease-in-out;
    width: 10px;
    text-align: center;
}

/* Поворот стрілочки при розкритті */
.nav-link[aria-expanded="true"] .caret-icon {
    transform: rotate(-90deg);
}

/* 3. Карта займає все інше */
.main-map-area {
    height: 100dvh;
    overflow-y: auto; /* Додаємо вертикальний скрол */
    background: #e5e5e5;
    display: flex;
    flex-direction: column;
}

/* Контейнер всередині main-content, де лежить контент */
.main-content {
    flex-grow: 1;
    min-height: 0; /* Важливо для flex-контейнерів */
}

/* Стиль навігації */
.side-nav .nav-link {
    color: #a8afb7 !important;
    font-size: 14px;
}
.side-nav .nav-item.active > .nav-link, .side-nav .nav-link:hover {
    background: #242a30;
    color: #fff !important;
}

/* 4. МОБІЛЬНА ВЕРСІЯ */
@media (max-width: 767.98px) {
    .main-sidebar {
        position: fixed;
        left: 0;
        top: 0;
        transform: translateX(-100%); /* Ховаємо за екран */
    }

    /* Клас, який додається через JS при кліку */
    .sidebar-open .main-sidebar {
        transform: translateX(0);
        box-shadow: 5px 0 15px rgba(0,0,0,0.5);
    }

    /* Кнопка "Гамбургер" на карті */
    .btn-open-sidebar {
        position: absolute;
        top: 10px;
        right: 10px;
        z-index: 1000;
        background: #fff;
        border: none;
        box-shadow: 0 2px 5px rgba(0,0,0,0.2);
        border-radius: 4px;
        width: 40px;
        height: 40px;
    }
    #expand-btn {
        display: none; /* Приховуємо кнопку розгортання на мобільних пристроях */
    }    
    #gps-btn {
        position: absolute;
        top: 55px;
        right: 10px;
    }
    #maplayers {
        position: absolute;
        top: 100px;
        right: 10px;
    }    
    .btn-close-sidebar {
        position: absolute;
        right: 10px;
        top: 10px;
        background: transparent;
        border: none;
        color: #fff;
        font-size: 20px;
    }
}

/* Підменю (як на скрині) */
.sub-menu {
    background: #1a2229;
    padding-left: 20px;
}
.sub-menu .nav-link::before {
    content: '•';
    margin-right: 10px;
    color: #4b535a;
}

/* Затемнення фону при відкритому меню */
.sidebar-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1040; /* Нижче за сайдбар, але вище за карту */
}

/* Показуємо оверлей тільки коли додано клас sidebar-open */
.sidebar-open .sidebar-overlay {
    display: block;
}

/* Кнопка закриття (X) у самому сайдбарі */
.btn-close-sidebar {
    position: absolute;
    background: transparent;
    border: none;
    color: #fff;
    font-size: 24px;
    z-index: 1060;
}

/* Переконайтеся, що кнопка відкриття (гамбургер) має правильний z-index */
.btn-open-sidebar {
    z-index: 1000;
}

.navbar-nav {
    display: flex !important;
    flex-direction: row !important; /* Примусово в ряд */
    flex-wrap: wrap; /* Дозволяє переносити на інший рядок, якщо екран зовсім малий */
    align-items: center; /* Вирівнювання кнопок по висоті */
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

.navbar-nav > li {
    display: flex;
    align-items: center;
    margin-right: 10px; /* Відступ між пунктами */
}

/* Прибираємо зайві паддінги, які Bootstrap додає до посилань у navbar */
.navbar-nav > li > a {
    padding-top: 5px !important;
    padding-bottom: 5px !important;
}

/* Контейнер пейджинатора */
.pagination {
    display: flex;
    padding-left: 0;
    list-style: none;
    border-radius: 4px;
    margin: 20px 0;
}

/* Загальний стиль для всіх елементів списку */
.pagination li {
    margin: 0 2px;
}

/* Базовий стиль кнопок (посилань та спанів) */
.pagination li a, 
.pagination li span {
    position: relative;
    display: block;
    padding: 4px 8px;
    line-height: 1.42857143;
    color: #fcfdff; /* Колір як у сайдбарі */
    text-decoration: none;
    background-color: #55616b; /* Колір фону сайдбару */
    border: 1px solid #d1d6db;
    transition: all 0.2s ease-in-out;
    border-radius: 4px;
}

/* Ефект при наведенні */
.pagination li a:hover {
    z-index: 2;
    color: #fff;
    background-color: #242a30;
    border-color: #1a2229;
}

/* Активна сторінка (виділена) */
.pagination li.active a, 
.pagination li.active span {
    z-index: 3;
    color: #fff;
    background-color: #007bff; /* Можна змінити на #28a745 (зелений), якщо хочете під стиль ОКС */
    border-color: #007bff;
    cursor: default;
}

/* Неактивні кнопки (наприклад, "Назад" на першій сторінці) */
.pagination li.disabled span, 
.pagination li.disabled a {
    color: #6c757d;
    cursor: not-allowed;
    background-color: #2d353c;
    border-color: #d1d6db;
    opacity: 0.6;
}

/* Стилізація стрілок « та » */
.pagination li.prev a, 
.pagination li.next a {
    font-weight: bold;
}

/* Контейнер картки */
.map-popup-card {
    display: flex;
    gap: 12px;
    min-width: 300px;
    padding: 5px;
}

/* Блок з фото */
.popup-media {
    flex: 0 0 100px;
}

.popup-thumb {
    width: 100%;
    height: auto;
    border-radius: 4px;
    cursor: pointer;
    border: 1px solid #ddd;
    transition: transform 0.2s;
}

.popup-thumb:hover {
    transform: scale(1.05);
}

/* Блок з текстом */
.popup-info {
    flex: 1;
    font-size: 13px;
    line-height: 1.4;
}

.info-row {
    display: flex;
    margin-bottom: 3px;
    border-bottom: 1px solid #f0f0f0;
    padding-bottom: 2px;
}

.info-row b {
    flex: 0 0 50px; /* Фіксована ширина заголовків для рівності */
    color: #555;
}

.info-row span {
    color: #333;
}

/* Статус */
.status-label {
    font-weight: 600;
    color: #28a745; /* Зелений за замовчуванням */
}

/* Кнопка */
.popup-actions {
    margin-top: 8px;
}

.popup-actions .btn {
    border-radius: 4px;
    font-weight: bold;
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.5px;
}

/* Стилізація основної панелі інфо */
#infopanel {
    padding: 10px 5px;
}

/* Прибираємо важкі рамки bs-callout і робимо їх сучасними блоками */
.bs-callout {
    margin: 0 0 4px 0;
    padding: 5px;
    border: 1px solid #68acef;
    border-left-width: 5px;
    border-radius: 4px;
    background-color: #fcfcfc;
    box-shadow: 0 1px 2px rgba(0,0,0,0.03);
}

/* Кольорові акценти для різних типів блоків */
.bs-callout-success { border-left-color: #28a745; background-color: #f8fff9; }
.bs-callout-warning { border-left-color: #ffc107; background-color: #fffdf5; }
.bs-callout-info    { border-left-color: #17a2b8; background-color: #f0faff; }

/* Стилізація тексту всередині */
#infopanel b {
    color: #495057;
    font-weight: 600;
}

/* Заголовки в блоках (Тип, Опис) */
#infopanel h4 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #333;
}

/* Кнопка друку (іконка праворуч) */
#infopanel .btn-default.btn-lg {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 8px 12px;
    transition: all 0.2s;
}

#infopanel .btn-default.btn-lg:hover {
    background: #f0f0f0;
    border-color: #ccc;
}

#infopanel .glyphicon-print {
    color: #5a6268;
}

/* Група кнопок дій */
.btn-group-justified {
    display: flex !important;
    gap: 10px;
    border-collapse: separate;
}

.btn-group-justified .btn-group {
    flex: 1;
}

.btn-group-justified .btn {
    border-radius: 6px !important;
    padding: 12px;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 0.5px;
}
#revisionsgrid h5{
    color: #8295a9;
}
/* Стилізація таблиці історії */
#revisionsgrid .table {
    background-color: #f1f3f5;
    border: none;
    margin: 0; 
}

#revisionsgrid .table thead th {
    background-color: #f1f3f5;
    border: none;
    color: #666;
    font-weight: 500;
    font-size: 13px;
    padding: 4px;
}

#revisionsgrid .table tbody td, #revisionsgrid .table thead th {
    padding: 4px;
    vertical-align: middle;
    border-top: 1px solid #f1f3f5;
    font-size: 14px;
    word-break: break-word;
}
/* 1. Контейнер для зображення */
.carousel-inner > .item, 
.carousel-inner > .carousel-item {
    height: 250px; /* Фіксована висота, щоб верстка не "стрибала" */
    background-color: #577695;
    border-radius: 8px;
    overflow: hidden;
}

/* 2. Центрування посилання та зображення */
.carousel-inner > .item.active,
.carousel-inner > .carousel-item.active {
    display: flex !important;
    align-items: center;
    justify-content: center;
}

.carousel-inner > .item > a,
.carousel-inner > .carousel-item > a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

/* 3. Масштабування зображення */
.carousel-inner > .item img,
.carousel-inner > .carousel-item img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain; /* Зображення впишеться в блок без обрізки */
    display: block;
    box-shadow: 0 4px 15px rgba(0,0,0,0.1); /* Легка тінь для об'єму */
}

/* 4. Виправлення для кнопок навігації каруселі */
.carousel-control-prev, 
.carousel-control-next {
    width: 10%;
    background: none;
    z-index: 5;
}
.modal-content {
    font-size: 1rem;
}
.modal-header{
    padding: 0.5rem 0.5rem;
    background:#F5F5F5;
}
.modal-header .close {
    padding: 0.1rem 0.5rem 0.5rem 0.5rem;
    margin: 0rem 0rem 0rem auto;
}
.modal-header button{
	border:#720000 2px solid;
	border-radius:12px;
	background:#f00;
	color:#1E0000;
	padding:2px 6px;
}
.modal-body {
    padding: 0.2rem;
}
/* Фікс для іконок у кнопках, де раніше були гліфікони */
.btn i.fa {
    margin-right: 5px; /* щоб був відступ від тексту "Фото" */
    font-size: 14px;
    vertical-align: middle;
}

/* Специфічно для великої кнопки друку */
.btn-lg i.fa-print {
    font-size: 20px;
    margin-right: 0; /* тут тексту немає, тому відступ не потрібен */
}

.modal-content .row, .popup-content .row {
    margin-right: -2px;
    margin-left: -2px;
}
.modal-content .row > div, .popup-content .row > div {
    padding-right: 2px;
    padding-left: 2px;
    padding: 2px;
}
.modal-content form{
    padding: 8px;
}
.modal-content label{
    margin: 0;
}
.modal-content .form-group{
    margin: 0;
}
.glyphicon-trash:before {
    /* Підставляємо код іншої іконки. 
       Наприклад, \e014 - це хрестик (remove), \e107 - це архів */
    content: "\e0A4" !important; 
} 
.glyphicon-zoom-in:before {
    /* Підставляємо код іншої іконки. 
       Наприклад, \e014 - це хрестик (remove), \e107 - це архів */
    content: "\e094" !important; 
}
.file-thumbnail-footer {
    display: none; /* Приховуємо підпис під мініатюрою */
}
#findid, #findidz
{
    padding: 0;
    margin: 0;
    font-size: 0.87em;
}
.map-popup-card_maf .detailbutton,
.map-popup-card_zupinki .detailbutton,
.map-popup-card_maydan .detailbutton,
.map-popup-card_parking .detailbutton,
.map-popup-card_recreation .detailbutton,
.map-popup-card_green .detailbutton,
.map-popup-card_spirt .detailbutton
{
    display: none;
}
.map-popup-card_maf,
.map-popup-card_zupinki,
.map-popup-card_maydan,
.map-popup-card_parking,
.map-popup-card_recreation,
.map-popup-card_green,
.map-popup-card_spirt
{
    font-size: 0.8rem
}
.top-menu li > a.active{
	background-color:#44B5F6;
}
button.hidden, #findiddiv.hidden, .hidden{
    display: none;
}
#footeralertmessage {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 9999;
    min-width: 300px;
    display: none; /* початково приховано */
}

/* Клас для анімації появи (опціонально) */
.fade.in {
    opacity: 1;
    transition: opacity 0.15s linear;
}
/* Виправляємо відступи в елементах списку */
.dropdown-item {
    display: flex;
    align-items: center;
    padding: 0.2rem 0.2rem;
    color: #333;
}

/* Стилі для іконок статусів */
.status-img {
    width: 24px; /* підберіть під ваші іконки */
    height: auto;
    margin-right: 10px;
    display: inline-block;
    vertical-align: middle;
}

/* Якщо меню вилітає за межі або відображається збоку */
.dropdown-menu, .select2-dropdown, .select2-container {
    min-width: auto !important;   /* Скидаємо стандартну ширину Bootstrap */
    width: max-content !important; /* Встановлюємо ширину по контенту */
    max-width: 350px !important; /* Максимальна ширина для запобігання занадто широкому меню */
    margin-top: 0; /* Bootstrap 4 додає відступи через Popper */
}

.dropdown-menu.show {
    max-height: 350px;
    overflow: scroll;
}

/* Ефект при наведенні */
.dropdown-item:hover {
    background-color: #f8f9fa;
    color: #000;
    text-decoration: none;
}

/* Контейнер GridView */
main .grid-view {
    background: #ffffff;
    padding: 5px;
    border-radius: 8px;
    /* Яскрава синя зовнішня межа, як на вашому скріні */
    border: 2px solid #007bff; 
    box-shadow: 0 4px 6px rgba(0,0,0,0.05);
    margin-top: 4px;
}

/* Стилізація самої таблиці */
main .grid-view table {
    border-collapse: separate !important;
    border-spacing: 0;
    width: 100%;
}

/* Заголовки таблиці */
main .grid-view thead th {
    background-color: #f8f9fa; /* Дуже світлий сірий */
    color: #0062cc; /* Насичений синій як у вас на скріні */
    font-weight: 700;
    text-transform: none;
    border-bottom: 2px solid #dee2e6 !important;
    border-top: none !important;
    padding: 12px !important;
    vertical-align: middle;
}

/* Колір внутрішніх ліній (меж між клітинками) */
main .grid-view table.table-bordered td, 
main .grid-view table.table-bordered th {
    border: 1px solid #e0e6ed !important; /* М'який сіро-блакитний колір ліній */
}

/* Ефект "зебри" - чергування рядків */
main .grid-view table tbody tr:nth-of-type(odd) {
    background-color: #ffffff;
}

main .grid-view table tbody tr:nth-of-type(even) {
    background-color: #f1f4f8; /* Світлий відтінок під фон вашого сайту */
}

/* Підсвічування рядка при наведенні */
main .grid-view table tbody tr:hover {
    background-color: #e2e9f3 !important;
    transition: background-color 0.2s ease;
}

/* Стилізація тексту в клітинках */
main .grid-view td {
    padding: 2px 3px !important;
    color: #444;
    font-size: 14px;
    vertical-align: middle !important;
}

/* Стилізація посилань у таблиці */
main .grid-view td a {
    color: #007bff;
    text-decoration: none;
    font-weight: 500;
}

main .grid-view td a:hover {
    text-decoration: underline;
}
/* Основний контейнер */
.group-ul {
    border: none !important;
    border-radius: 6px !important;
    box-shadow: 0 8px 20px rgba(0,0,0,0.15) !important;
    padding: 4px 0 !important; /* Зменшено загальні відступи */
    min-width: 260px !important;
    background-color: #ffffff !important;
}

/* Кожен елемент списку */
.selectbygroup {
    list-style: none;
    position: relative;
    /* Ледь помітний бордер між елементами */
    border-bottom: 1px solid rgba(0, 0, 0, 0.05); 
}

.selectbygroup:last-child {
    border-bottom: none; /* Прибираємо лінію в останнього елемента */
}

/* Стиль посилання/тексту всередині */
.selectbygroup a, 
.selectbygroup {
    display: flex;
    align-items: center;
    padding: 6px 15px 6px 35px !important; /* Зменшено padding; зліва місце під стрілку */
    color: #444 !important;
    font-size: 13.5px;
    line-height: 1.3;
    text-decoration: none !important;
    transition: all 0.2s ease;
    cursor: pointer;
}

/* Стрілочка перед елементом */
.selectbygroup:before {
    content: '→'; /* Можна замінити на '›' для меншого вигляду */
    position: absolute;
    left: 15px;
    color: #ccc;
    font-size: 12px;
    transition: all 0.2s ease;
}

/* Ефект при наведенні */
.selectbygroup:hover {
    background-color: #f8fafd !important;
}

.selectbygroup:hover a,
.selectbygroup:hover {
    color: #007bff !important;
}

/* Анімація стрілочки при наведенні */
.selectbygroup:hover:before {
    color: #007bff;
    left: 18px; /* Стрілочка трохи зміщується вперед */
}

/* Виділення першого пункту "Показати всі" */
.selectbygroup:first-child {
    background-color: #fafafa;
}
.select2-container--krajee-bs3 .select2-selection--single{
    padding-right: 48px; /* Додаємо відступ для хрестика */
}
.select2-selection__clear {
    right: 24px; /* Додаємо відступ для хрестика */
}

.label-danger {
    padding: 2px 6px;
    border-radius: 4px;
    background: #ff5b57 ;
}
.label-warning {
    padding: 2px 6px;
    border-radius: 4px;
    background: #f59c1a ;
}
.help-block {
    font-size: 0.85em;
    color: #f37d5f;
    margin-top: 0px;
}
.ui-autocomplete {
        max-height: 200px;           /* Обмежуємо висоту списку (наприклад, 200px) */
        overflow-y: auto;            /* Вмикаємо вертикальний скролл */
        overflow-x: hidden;           /* Ховаємо горизонтальний скролл, щоб не ламався текст */
        background: #fff;            /* Білий фон для списку */
        border: 1px solid #ced4da;   /* Гарна рамка під стиль Bootstrap */
        border-radius: 4px;
        z-index: 1055 !important;    /* Щоб список точно перекривав елементи модалки */
    }

    /* Стиль для окремого елемента списку при наведенні */
    .ui-menu-item .ui-menu-item-wrapper.ui-state-active {
        background-color: #007bff !important; /* Синій колір Bootstrap при виборі */
        color: #5a5a5a !important;
        border: none !important;
    }
.filterrow > div{
padding: 2px;
}
@media print {
    /* Ховаємо непотрібні елементи: меню, кнопки, футер */
    .navbar, .btn, .footer, .sidebar {
        display: none !important;
    }

    /* Налаштовуємо контент */
    body {
        background: white;
        color: black;
        font-size: 12pt;
    }

    .modal-dialog {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }
}
