/* Стили для плагина карты заведений Сургута */

:root {

    --primary: #2563eb;

    --primary-2: #1d4ed8;

    --accent: #22d3ee;

    --success: #22c55e;

    --danger: #ef4444;



    --text: #0f172a;

    --text-muted: #64748b;



    --surface: #ffffff;

    --surface-2: #f8fafc;

    --glass: rgba(255, 255, 255, 0.6);

    --glass-strong: rgba(255, 255, 255, 0.8);



    --radius: 14px;

    --radius-sm: 10px;



    --shadow-soft: 0 10px 30px rgba(2, 6, 23, 0.08);

    --shadow-strong: 0 20px 50px rgba(2, 6, 23, 0.12);

}



* {

    margin: 0;

    padding: 0;

    box-sizing: border-box;

    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;

}



/* Технологичный фон (градиентная сетка) */

body {

    min-height: 100vh;

    color: var(--text);

    overflow-x: hidden;

    margin: 0;

    padding: 0;

    background:

        radial-gradient(800px 800px at 10% 10%, rgba(34, 211, 238, 0.25), transparent 40%),

        radial-gradient(800px 800px at 90% 0%, rgba(37, 99, 235, 0.25), transparent 40%),

        linear-gradient(135deg, #eef2ff, #f0f9ff 60%, #eff6ff);

}



/* Авто тёмная тема при HotelMap.setTheme('dark') */

body.theme-dark {

    --text: #e5e7eb;

    --text-muted: #94a3b8;



    --surface: #0f172a;

    --surface-2: #0b1220;

    --glass: rgba(17, 24, 39, 0.55);

    --glass-strong: rgba(17, 24, 39, 0.7);



    background:

        radial-gradient(900px 900px at 10% 10%, rgba(34, 211, 238, 0.18), transparent 40%),

        radial-gradient(900px 900px at 90% 0%, rgba(37, 99, 235, 0.22), transparent 40%),

        linear-gradient(135deg, #0b1220, #0f172a 60%, #111827);

    color: var(--text);

}



/* Контейнер-«стекло» */

.surgut-map-container {

    display: flex;

    flex-direction: column;

    height: 100vh;

    width: 100vw;

    max-width: 1800px;

    min-height: 120vh;

    margin: 0 auto;

    background: var(--glass);

    border: 1px solid rgba(2, 6, 23, 0.06);

    border-radius: 0;

    backdrop-filter: blur(14px);

    -webkit-backdrop-filter: blur(14px);

    box-shadow: var(--shadow-soft);

    overflow: hidden;

}

body.theme-dark .surgut-map-container {

    background: var(--glass);

    border-color: rgba(255, 255, 255, 0.06);

}



/* Хедер — стекло + мягкая тень */

.surgut-map-header {

    background: linear-gradient(180deg, rgba(255,255,255,0.75), rgba(255,255,255,0.55));

    padding: 14px 16px;

    border-bottom: 1px solid rgba(2, 6, 23, 0.06);

    backdrop-filter: blur(10px);

    -webkit-backdrop-filter: blur(10px);

    box-shadow: 0 6px 20px rgba(2, 6, 23, 0.06);

    z-index: 100;

}

body.theme-dark .surgut-map-header,

body.theme-dark .surgut-mobile-header {

    background: linear-gradient(180deg, rgba(15,23,42,0.75), rgba(15,23,42,0.55));

    border-bottom: 1px solid rgba(255,255,255,0.06);

}



.surgut-map-header-content {

    display: flex;

    flex-direction: column;

    justify-content: center;

    align-items: center;

    max-width: 1400px;

    margin: 0 auto;

    gap: 16px;

}



.surgut-map-search-filter {

    display: flex;

    flex-direction: column;

    gap: 12px;

    align-items: center;

}



.surgut-map-logo {

    display: flex;

    align-items: center;

    gap: 10px;

}

.surgut-map-logo i { 

    font-size: 1.6rem; 

    color: var(--primary); 

    display: flex;

    align-items: center;

    line-height: 1;

}

body.theme-dark .surgut-map-logo i { color: var(--accent); }

.surgut-map-logo h2 {

    font-size: 1.2rem;

    font-weight: 700;

    letter-spacing: 0.2px;

    color: var(--text);

    line-height: 1.2;

    margin: 0;

}



/* Поиск + фильтры (чипы) */

.surgut-map-search-filter {

    display: flex;

    gap: 12px;

    align-items: center;

}



.surgut-map-search-box {

    display: flex;

    align-items: center;

    gap: 8px;

    width: 260px;

    padding: 8px 12px;

    background: var(--glass-strong);

    border: 1px solid rgba(2, 6, 23, 0.08);

    border-radius: 999px;

    backdrop-filter: blur(10px);

    -webkit-backdrop-filter: blur(10px);

}

.surgut-map-search-box i { color: var(--primary); }

.surgut-map-search-box input {

    background: transparent;

    border: none;

    color: var(--text);

    width: 100%;

    outline: none;

    font-weight: 600;

    white-space: pre-wrap;

    word-spacing: normal;

    text-indent: 0;

    text-rendering: auto;

    letter-spacing: normal;

    word-break: normal;

    text-transform: none;

    text-shadow: none;

    display: inline-block;

    text-align: left;

    direction: ltr;

    cursor: text;

    margin: 0;

    padding: 0;

    border: 0;

    outline: 0;

    -webkit-appearance: none;

    -moz-appearance: none;

    appearance: none;

    font-family: inherit;

    font-size: inherit;

    line-height: inherit;

    box-sizing: border-box;

    resize: none;

    overflow: visible;

    /* Принудительно отключаем все возможные вмешательства */

    -webkit-user-select: text;

    -moz-user-select: text;

    -ms-user-select: text;

    user-select: text;

    -webkit-touch-callout: default;

    -webkit-tap-highlight-color: transparent;

    /* Принудительно устанавливаем курсор */

    caret-color: var(--text);

    /* Отключаем автозаполнение браузера */

    autocomplete: "off";

    autocorrect: "off";

    autocapitalize: "off";

    spellcheck: false;

    /* Принудительно отключаем любые возможные вмешательства Leaflet */

    pointer-events: auto !important;

    z-index: 9999 !important;

    position: relative !important;

}

.surgut-map-search-box input::placeholder { color: rgba(15, 23, 42, 0.45); }

body.theme-dark .surgut-map-search-box input::placeholder { color: rgba(229, 231, 235, 0.55); }



/* Принудительно отключаем все возможные стили Leaflet для поля поиска */

.surgut-map-search-box input[data-leaflet-ignore="true"],

.surgut-map-search-box input[data-leaflet-ignore="true"]:focus,

.surgut-map-search-box input[data-leaflet-ignore="true"]:active,

.surgut-map-search-box input[data-leaflet-ignore="true"]:hover {

    /* Принудительно отключаем все возможные стили Leaflet */

    background: transparent !important;

    border: none !important;

    outline: none !important;

    box-shadow: none !important;

    /* Принудительно устанавливаем курсор */

    caret-color: var(--text) !important;

    /* Принудительно отключаем все возможные вмешательства */

    pointer-events: auto !important;

    z-index: 9999 !important;

    position: relative !important;

    /* Принудительно устанавливаем размеры */

    width: 100% !important;

    height: auto !important;

    min-height: 0 !important;

    max-height: none !important;

    /* Принудительно отключаем все возможные трансформации */

    transform: none !important;

    transition: none !important;

    animation: none !important;

    /* Принудительно отключаем все возможные стили браузера */

    -webkit-appearance: none !important;

    -moz-appearance: none !important;

    appearance: none !important;

    /* Принудительно отключаем все возможные стили Leaflet */

    -webkit-user-select: text !important;

    -moz-user-select: text !important;

    -ms-user-select: text !important;

    user-select: text !important;

    /* Принудительно отключаем все возможные стили Leaflet */

    -webkit-touch-callout: default !important;

    -webkit-tap-highlight-color: transparent !important;

    /* Принудительно отключаем все возможные стили Leaflet */

    -webkit-text-size-adjust: 100% !important;

    -moz-text-size-adjust: 100% !important;

    -ms-text-size-adjust: 100% !important;

    text-size-adjust: 100% !important;

}



/* Принудительно отключаем любые стили Leaflet для поля поиска */

.surgut-map-search-box input,

.surgut-map-search-box input:focus,

.surgut-map-search-box input:active,

.surgut-map-search-box input:hover {

    /* Принудительно отключаем все возможные стили Leaflet */

    background: transparent !important;

    border: none !important;

    outline: none !important;

    box-shadow: none !important;

    /* Принудительно устанавливаем курсор */

    caret-color: var(--text) !important;

    /* Принудительно отключаем любые возможные вмешательства */

    pointer-events: auto !important;

    z-index: 9999 !important;

    position: relative !important;

    /* Принудительно устанавливаем размеры */

    width: 100% !important;

    height: auto !important;

    min-height: 0 !important;

    max-height: none !important;

    /* Принудительно отключаем любые возможные трансформации */

    transform: none !important;

    transition: none !important;

    animation: none !important;

    /* Принудительно отключаем все возможные стили браузера */

    -webkit-appearance: none !important;

    -moz-appearance: none !important;

    appearance: none !important;

    /* Принудительно отключаем все возможные стили Leaflet */

    -webkit-user-select: text !important;

    -moz-user-select: text !important;

    -ms-user-select: text !important;

    user-select: text !important;

    /* Принудительно отключаем все возможные стили Leaflet */

    -webkit-touch-callout: default !important;

    -webkit-tap-highlight-color: transparent !important;

    /* Принудительно отключаем все возможные стили Leaflet */

    -webkit-text-size-adjust: 100% !important;

    -moz-text-size-adjust: 100% !important;

    -ms-text-size-adjust: 100% !important;

    text-size-adjust: 100% !important;

}



.surgut-map-filter-section {

    display: flex;

    gap: 8px;

    padding: 4px;

    background: var(--glass-strong);

    border: 1px solid rgba(2, 6, 23, 0.08);

    border-radius: 999px;

}

.surgut-filter-btn {

    background: transparent;

    border: none;

    color: var(--text);

    padding: 8px 12px;

    border-radius: 999px;

    cursor: pointer;

    font-weight: 700;

    font-size: 0.9rem;

    transition: all 0.2s ease;

}

.surgut-filter-btn:hover { background: rgba(2, 6, 23, 0.06); }

.surgut-filter-btn.active {

    background: var(--surface);

    color: var(--primary);

    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.18);

}

body.theme-dark .surgut-filter-btn.active {

    background: rgba(255,255,255,0.08);

    color: var(--accent);

}



/* Цветовая дифференциация чипов по категориям */

.surgut-filter-btn[data-category="hotel"].active { color: var(--primary); box-shadow: 0 4px 12px rgba(37, 99, 235, 0.18); }

.surgut-filter-btn[data-category="sauna"].active { color: var(--danger); box-shadow: 0 4px 12px rgba(239, 68, 68, 0.18); }

.surgut-filter-btn[data-category="restaurant"].active { color: var(--success); box-shadow: 0 4px 12px rgba(34, 197, 94, 0.18); }

.surgut-filter-btn[data-category="guest_house"].active { color: var(--accent); box-shadow: 0 4px 12px rgba(34, 211, 238, 0.18); }

.surgut-filter-btn[data-category="resort"].active { color: #059669; box-shadow: 0 4px 12px rgba(5, 150, 105, 0.18); }

.surgut-filter-btn[data-category="camping"].active { color: #7c3aed; box-shadow: 0 4px 12px rgba(124, 58, 237, 0.18); }



.surgut-map-main-content {

    display: flex;

    flex: 1;

    overflow: hidden;

    min-height: calc(100vh - 120px); /* Учитываем высоту хедера */

}



#surgut-map {

    flex: 1;

    height: 100%;

    min-height: calc(100vh - 120px); /* Учитываем высоту хедера */

    position: relative;

    z-index: 10;

}



/* No results overlay */

.no-results-overlay {

    position: absolute;

    top: 50%;

    left: 50%;

    transform: translate(-50%, -50%);

    background: var(--surface);

    color: var(--primary);

    display: flex;

    align-items: center;

    gap: 10px;

    padding: 10px 14px;

    border-radius: var(--radius-sm);

    border: 1px solid rgba(2, 6, 23, 0.06);

    box-shadow: var(--shadow-soft);

    font-weight: 700;

    pointer-events: none;

    z-index: 1000;

}

.no-results-overlay.hidden { display: none; }



.surgut-no-results-overlay {

    position: absolute;

    top: 50%;

    left: 50%;

    transform: translate(-50%, -50%);

    background: var(--surface);

    color: var(--primary);

    display: flex;

    align-items: center;

    gap: 10px;

    padding: 10px 14px;

    border-radius: var(--radius-sm);

    border: 1px solid rgba(2, 6, 23, 0.06);

    box-shadow: var(--shadow-soft);

    font-weight: 700;

    pointer-events: none;

}

.surgut-no-results-overlay.hidden { display: none; }



/* Боковая панель подробностей (полуглянец) */

.surgut-map-info-sidebar {

    width: 380px;

    background: var(--glass-strong);

    backdrop-filter: blur(12px);

    -webkit-backdrop-filter: blur(12px);

    padding: 18px;

    border-left: 1px solid rgba(2, 6, 23, 0.06);

    box-shadow: -10px 0 30px rgba(2, 6, 23, 0.06);

    overflow-y: auto;

    z-index: 1200;

}



/* ===== LEAFLET СТИЛИ ===== */



/* Базовые стили Leaflet - копируем из рабочей версии */

.leaflet-container {

    font: 12px/1.5 "Helvetica Neue", Arial, Helvetica, sans-serif;

}



.leaflet-popup-content-wrapper {

    background: #fff;

    border-radius: 8px;

    box-shadow: 0 3px 14px rgba(0,0,0,0.4);

}



.leaflet-popup-content {

    margin: 8px 12px;

    line-height: 1.4;

}



.leaflet-popup-tip {

    background: #fff;

    box-shadow: 0 3px 14px rgba(0,0,0,0.4);

}



/* Маркеры - точно как в рабочей версии */

.map-marker {

    position: relative;

    width: 40px;

    height: 40px;

    background: #fff;

    border-radius: 50% 50% 50% 0;

    transform: rotate(-45deg);

    box-shadow: 0 6px 18px rgba(2, 6, 23, 0.25);

    display: flex;

    align-items: center;

    justify-content: center;

    transition: transform 0.15s ease, box-shadow 0.15s ease;

    border: 2px solid rgba(37, 99, 235, 0.25);

}



.map-marker:hover {

    transform: rotate(-45deg) scale(1.08);

    z-index: 1000;

    box-shadow: 0 12px 26px rgba(2, 6, 23, 0.35);

}



.marker-inner {

    position: relative;

    width: 100%;

    height: 100%;

    transform: rotate(45deg);

    text-align: center;

    font-weight: 800;

    font-size: 0.8rem;

    color: var(--primary);

    display: flex;

    flex-direction: column;

    align-items: center;

    justify-content: center;

}



.marker-title {

    position: absolute;

    bottom: -22px;

    left: 50%;

    transform: translateX(-50%);

    background: #fff;

    padding: 2px 6px;

    border-radius: 6px;

    font-size: 0.62rem;

    font-weight: 800;

    line-height: 1.1;

    box-shadow: 0 1px 3px rgba(2,6,23,0.2);

    max-width: 140px;

    overflow: hidden;

    text-overflow: ellipsis;

    white-space: nowrap;

}



.marker-label {

    position: absolute;

    top: -24px;

    left: 50%;

    transform: translateX(-50%);

    background: #fff;

    padding: 2px 8px;

    border-radius: 6px;

    font-size: 0.7rem;

    font-weight: 800;

    line-height: 1.1;

    white-space: nowrap;

    box-shadow: 0 2px 6px rgba(2,6,23,0.2);

}



/* Цветовые акценты для маркеров по категориям */

.hotel .marker-inner { color: var(--primary); }

.sauna .marker-inner { color: var(--danger); }

.restaurant .marker-inner { color: var(--success); }

.guest_house .marker-inner { color: var(--accent); }

.resort .marker-inner { color: #059669; }

.camping .marker-inner { color: #7c3aed; }

.apartment .marker-inner { color: #3b82f6; }

.spa .marker-inner { color: #ec4899; }

.job .marker-inner { color: #f59e0b; }

.other .marker-inner { color: #6b7280; }



/* Кластеры - точно как в рабочей версии */

.custom-cluster {

    background: linear-gradient(135deg, var(--primary), var(--primary-2));

    color: white;

    border-radius: 50%;

    display: flex;

    align-items: center;

    justify-content: center;

    font-size: 0.95rem;

    font-weight: 900;

    box-shadow: 0 8px 22px rgba(37,99,235,0.35);

    width: 42px;

    height: 42px;

    border: 3px solid rgba(255,255,255,0.95);

    position: relative;

    overflow: hidden;

    transition: all 0.3s ease;

}



.custom-cluster::before {

    content: '';

    position: absolute;

    top: 0;

    left: 0;

    right: 0;

    bottom: 0;

    background: linear-gradient(135deg, rgba(255,255,255,0.2), transparent);

    border-radius: 50%;

    pointer-events: none;

}



.custom-cluster:hover {

    transform: scale(1.1);

    box-shadow: 0 12px 28px rgba(37,99,235,0.45);

    border-color: rgba(255,255,255,1);

}



.custom-cluster .cluster-icon {

    display: flex;

    align-items: center;

    justify-content: center;

    width: 100%;

    height: 100%;

    font-size: 0.9rem;

    font-weight: 900;

    line-height: 1;

    text-shadow: 0 1px 2px rgba(0,0,0,0.3);

    z-index: 1;

    position: relative;

}



/* Убираем старые стили кластеров */

.marker-cluster-small,

.marker-cluster-medium,

.marker-cluster-large {

    display: none !important;

}



/* Анимации для Leaflet */

.leaflet-zoom-animated {

    transition: transform 0.25s ease-out !important;

}



.leaflet-interactive {

    cursor: pointer !important;

}



/* Контролы карты */

.leaflet-control-zoom, .leaflet-control-layers {

    background: var(--glass-strong) !important;

    backdrop-filter: blur(12px) !important;

    -webkit-backdrop-filter: blur(12px) !important;

    border: 1px solid rgba(2, 6, 23, 0.06) !important;

    border-radius: 8px !important;

    box-shadow: 0 4px 12px rgba(2, 6, 23, 0.08) !important;

}



.leaflet-control-zoom a,

.leaflet-control-layers-toggle {

    background: var(--glass-strong) !important;

    backdrop-filter: blur(12px) !important;

    -webkit-backdrop-filter: blur(12px) !important;

    border: 1px solid rgba(2, 6, 23, 0.06) !important;

    color: var(--text-primary) !important;

    transition: all 0.15s ease !important;

}



.leaflet-control-zoom a:hover,

.leaflet-control-layers-toggle:hover {

    background: var(--glass-hover) !important;

    transform: scale(1.05) !important;

}



.leaflet-control-layers-expanded {

    background: var(--glass-strong) !important;

    backdrop-filter: blur(12px) !important;

    -webkit-backdrop-filter: blur(12px) !important;

    border: 1px solid rgba(2, 6, 23, 0.06) !important;

    border-radius: 8px !important;

    padding: 8px !important;

}



/* Темная тема для Leaflet элементов */

body.theme-dark .leaflet-control-zoom,

body.theme-dark .leaflet-control-layers {

    background: var(--glass-dark-strong) !important;

    border-color: rgba(255, 255, 255, 0.1) !important;

}



body.theme-dark .leaflet-popup-content-wrapper {

    background: var(--glass-dark-strong) !important;

    border-color: rgba(255, 255, 255, 0.1) !important;

}



/* Адаптивность */

@media (max-width: 768px) {

    .leaflet-control-zoom,

    .leaflet-control-layers {

        transform: scale(0.9) !important;

    }

    

    .leaflet-popup-content {

        min-width: 240px !important;

    }

}



/* ===== POPUP СТИЛИ ===== */



/* CSS переменные для popup'ов */

:root {

    --primary: #2563eb;

    --primary-2: #1d4ed8;

    --accent: #22d3ee;

    --success: #22c55e;

    --danger: #ef4444;

    --text: #0f172a;

    --text-muted: #64748b;

    --surface: #ffffff;

    --glass-strong: rgba(255, 255, 255, 0.8);

    --radius: 14px;

    --shadow-strong: 0 20px 50px rgba(2, 6, 23, 0.12);

}



/* Основные стили Leaflet popup - точно как в рабочей версии */

.leaflet-popup-content-wrapper {

    border-radius: var(--radius) !important;

    padding: 0 !important;

    overflow: hidden;

    box-shadow: var(--shadow-strong) !important;

    border: 1px solid rgba(2, 6, 23, 0.06);

    background: var(--surface);

    color: var(--text);

}



.leaflet-popup-content {

    margin: 0 !important;

    padding: 0 !important;

    width: 280px !important;

}



.leaflet-popup-tip {

    background: var(--surface);

    border: 1px solid rgba(2, 6, 23, 0.06);

}



/* Стили для содержимого popup - точно как в рабочей версии */

.popup-content { 

    padding: 16px; 

}



.popup-header {

    display: flex;

    justify-content: space-between;

    align-items: flex-start;

    margin: 16px 0 12px 0;

    gap: 12px;

}



.popup-title {

    font-size: 1.05rem;

    font-weight: 800;

    color: var(--text);

    flex: 1;

    line-height: 1.3;

    margin: 0;

}



.popup-price {

    background: linear-gradient(135deg, var(--primary), var(--primary-2));

    color: white;

    padding: 6px 14px;

    border-radius: 999px;

    font-size: 0.85rem;

    font-weight: 800;

    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);

    white-space: nowrap;

    flex-shrink: 0;

    border: 1px solid rgba(255, 255, 255, 0.2);

}



.popup-rating {

    display: flex;

    align-items: center;

    gap: 8px;

    margin-bottom: 12px;

    color: #f59e0b;

    font-size: 0.9rem;

}



.popup-description {

    color: var(--text-muted);

    font-size: 0.9rem;

    line-height: 1.5;

    margin-bottom: 16px;

    padding: 12px;

    background: rgba(2, 6, 23, 0.03);

    border-radius: 8px;

    border-left: 3px solid var(--primary);

}



.popup-button {

    display: block;

    width: 100%;

    background: linear-gradient(135deg, var(--primary), var(--primary-2));

    color: white;

    border: none;

    padding: 12px;

    border-radius: 10px;

    cursor: pointer;

    font-weight: 800;

    text-align: center;

    transition: all 0.2s ease;

    box-shadow: 0 6px 16px rgba(37,99,235,0.25);

    border: 1px solid rgba(255, 255, 255, 0.2);

}



.popup-button:hover {

    transform: translateY(-2px);

    box-shadow: 0 10px 24px rgba(37, 99, 235, 0.35);

    background: linear-gradient(135deg, var(--primary-2), var(--primary));

}



/* Стили для изображений в popup - изображение на всю ширину popup'а */

.popup-image-container {

    position: relative;

    width: 100%;

    height: 160px;

    overflow: hidden;

    border-radius: 8px 8px 0 0;

    /* Увеличиваем отрицательные отступы, чтобы изображение покрыло всю ширину popup'а */

    margin: -16px -32px 0 -16px;

    /* Увеличиваем ширину контейнера */

    width: calc(100% + 32px);

}



.popup-image {

    width: 100%;

    height: 100%;

    object-fit: cover;

    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);

    opacity: 1;

    transform: scale(1);

}



.popup-image:hover {

    transform: scale(1.08);

}



/* Позиционируем кнопку закрытия поверх изображения */

.leaflet-popup-close-button {

    position: absolute !important;

    top: 8px !important;

    right: 8px !important;

    z-index: 1000 !important;

    background: rgba(0, 0, 0, 0.5) !important;

    color: white !important;

    border: none !important;

    border-radius: 50% !important;

    width: 24px !important;

    height: 24px !important;

    font-size: 16px !important;

    line-height: 1 !important;

    display: flex !important;

    align-items: center !important;

    justify-content: center !important;

    cursor: pointer !important;

    transition: all 0.2s ease !important;

}



.leaflet-popup-close-button:hover {

    background: rgba(0, 0, 0, 0.7) !important;

    transform: scale(1.1) !important;

}



/* Анимации для popup изображений */

.popup-image.fade-out {

    opacity: 0;

    transform: scale(1.1);

}



.popup-image.fade-in {

    opacity: 1;

    transform: scale(1);

}



/* Индикатор загрузки для popup */

.popup-image-container::after {

    content: '';

    position: absolute;

    top: 0;

    left: 0;

    right: 0;

    bottom: 0;

    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);

    transform: translateX(-100%);

    animation: shimmer 2s infinite;

    pointer-events: none;

}



@keyframes shimmer {

    0% { transform: translateX(-100%); }

    100% { transform: translateX(100%); }

}



/* Заглушка для отсутствующих изображений */

.no-image-placeholder {

    display: flex;

    flex-direction: column;

    align-items: center;

    justify-content: center;

    height: 100%;

    background: linear-gradient(135deg, #f1f5f9, #e2e8f0);

    color: #64748b;

    gap: 8px;

}



/* Стили для popup по категориям */

.popup-content.c-apartment .popup-price {

    background: linear-gradient(135deg, #3b82f6, #2563eb);

    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.25);

}



.popup-content.c-spa .popup-price {

    background: linear-gradient(135deg, #ec4899, #db2777);

    box-shadow: 0 4px 12px rgba(236, 72, 153, 0.25);

}



.popup-content.c-job .popup-price {

    background: linear-gradient(135deg, #f59e0b, #d97706);

    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.25);

}



.popup-content.c-apartment .popup-description {

    border-left-color: #3b82f6;

}



.popup-content.c-spa .popup-description {

    border-left-color: #ec4899;

}



.popup-content.c-job .popup-description {

    border-left-color: #f59e0b;

}



.no-image-placeholder i {

    font-size: 2rem;

    opacity: 0.6;

}



.no-image-placeholder span {

    font-size: 0.9rem;

    font-weight: 500;

}



/* Одиночное изображение */

.single-image {

    width: 100%;

    height: 100%;

}



.single-image img {

    width: 100%;

    height: 100%;

    object-fit: cover;

    transition: transform 0.5s ease;

}



.single-image:hover img {

    transform: scale(1.05);

}



/* ===== БОКОВАЯ ПАНЕЛЬ СТИЛИ ===== */



/* Боковая панель подробностей (полуглянец) - точно как в рабочей версии */

.surgut-map-info-sidebar {

    width: 420px;

    background: var(--glass-strong);

    backdrop-filter: blur(12px);

    -webkit-backdrop-filter: blur(12px);

    padding: 18px;

    border-left: 1px solid rgba(2, 6, 23, 0.06);

    box-shadow: -10px 0 30px rgba(2, 6, 23, 0.06);

    overflow-y: auto;

    z-index: 1200;

    min-height: calc(100vh - 120px); /* Учитываем высоту хедера */

}



/* Шапка панели */

.surgut-map-info-header {

    position: static;

    display: flex;

    justify-content: space-between;

    align-items: center;

    padding: 12px 0 14px;

    margin-bottom: 12px;

    background: var(--glass-strong);

    z-index: 1;

    border-bottom: 1px solid rgba(2, 6, 23, 0.08);

    backdrop-filter: blur(12px);

    -webkit-backdrop-filter: blur(12px);

}



.surgut-map-info-header h3 {

    color: var(--primary);

    font-size: 1.15rem;

    line-height: 1.2;

    letter-spacing: 0.2px;

    margin: 0;

    flex: 1;

}



/* Карточка подробностей */

.establishment-card {

    background: var(--surface);

    border: 1px solid rgba(2, 6, 23, 0.08);

    border-radius: var(--radius);

    overflow: hidden;

    box-shadow: var(--shadow-soft);

    margin-bottom: 18px;

    transition: all 0.3s ease;

}



.establishment-card:hover {

    transform: translateY(-3px);

    box-shadow: var(--shadow-strong);

    border-color: rgba(37, 99, 235, 0.2);

}



.card-image { 

    height: 210px; 

    overflow: hidden; 

    position: relative;

}



.card-image img {

    width: 100%;

    height: 100%;

    object-fit: cover;

    transition: transform 0.5s ease;

}



.establishment-card:hover .card-image img { 

    transform: scale(1.05); 

}



.card-content { 

    padding: 20px; 

    background: linear-gradient(180deg, var(--surface) 0%, rgba(248, 250, 252, 0.8) 100%);

}



.card-header {

    display: flex;

    justify-content: space-between;

    align-items: flex-start;

    margin-bottom: 16px;

    gap: 12px;

    min-width: 0;

}



.card-title {

    font-size: 1.25rem;

    font-weight: 800;

    color: var(--text);

    letter-spacing: 0.3px;

    line-height: 1.3;

    flex: 1;

    margin: 0;

    overflow: hidden;

    white-space: nowrap;

    text-overflow: ellipsis;

}



.card-price {

    background: linear-gradient(135deg, var(--primary), var(--primary-2));

    color: #fff;

    padding: 8px 16px;

    border-radius: 999px;

    font-size: 0.9rem;

    font-weight: 700;

    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);

    white-space: nowrap;

    flex-shrink: 0;

    border: 2px solid rgba(255, 255, 255, 0.2);

}



.card-rating {

    display: flex;

    align-items: center;

    gap: 8px;

    margin-bottom: 16px;

    padding: 8px 12px;

    background: rgba(245, 158, 11, 0.1);

    border-radius: 8px;

    border: 1px solid rgba(245, 158, 11, 0.2);

}



.stars { 

    color: #f59e0b; 

    font-size: 1.1rem;

}



.card-rating span {

    color: var(--text);

    font-weight: 600;

    font-size: 0.9rem;

}



.card-description {

    color: var(--text-muted);

    font-size: 0.95rem;

    line-height: 1.6;

    margin-bottom: 20px;

    padding: 16px;

    background: rgba(2, 6, 23, 0.03);

    border-radius: 8px;

    border-left: 4px solid var(--primary);

}



.card-footer {

    display: flex;

    flex-direction: column;

    gap: 16px;

    padding-top: 16px;

    border-top: 1px solid rgba(2, 6, 23, 0.08);

}



.card-info {

    display: flex;

    flex-direction: column;

    gap: 12px;

}



.card-address, .card-phone {

    display: flex;

    align-items: center;

    gap: 10px;

    color: var(--text-muted);

    font-size: 0.92rem;

    padding: 8px 12px;

    background: rgba(2, 6, 23, 0.03);

    border-radius: 6px;

    transition: all 0.2s ease;

}



.card-address:hover, .card-phone:hover {

    background: rgba(2, 6, 23, 0.06);

    color: var(--text);

}



.card-address i, .card-phone i {

    color: var(--primary);

    font-size: 1rem;

    width: 16px;

    text-align: center;

}



.details-btn {

    background: linear-gradient(135deg, var(--primary), var(--primary-2));

    color: white;

    border: none;

    padding: 14px 24px;

    border-radius: 999px;

    cursor: pointer;

    font-weight: 800;

    font-size: 1rem;

    transition: all 0.3s ease;

    box-shadow: 0 8px 20px rgba(37, 99, 235, 0.25);

    width: 100%;

    text-transform: uppercase;

    letter-spacing: 0.5px;

    border: 2px solid rgba(255, 255, 255, 0.2);

}



.details-btn:hover {

    transform: translateY(-2px);

    box-shadow: 0 12px 28px rgba(37, 99, 235, 0.35);

    background: linear-gradient(135deg, var(--primary-2), var(--primary));

}



.details-btn:active {

    transform: translateY(0);

}



/* Категории для карточек */

.establishment-card.hotel .card-description {

    border-left-color: var(--primary);

}



.establishment-card.sauna .card-description {

    border-left-color: var(--danger);

}



.establishment-card.restaurant .card-description {

    border-left-color: var(--success);

}



.establishment-card.guest_house .card-description {

    border-left-color: var(--accent);

}



.establishment-card.resort .card-description {

    border-left-color: #059669;

}



.establishment-card.camping .card-description {

    border-left-color: #7c3aed;

}



.establishment-card.apartment .card-description {

    border-left-color: #3b82f6;

}



.establishment-card.spa .card-description {

    border-left-color: #ec4899;

}



.establishment-card.job .card-description {

    border-left-color: #f59e0b;

}



.establishment-card.other .card-description {

    border-left-color: #6b7280;

}



/* Адаптивность для мобильных устройств */

@media (max-width: 992px) {

    .surgut-map-info-sidebar {

        position: fixed;

        top: 0;

        right: 0;

        height: 100%;

        width: 85%;

        max-width: 480px;

        transform: translateX(100%);

        transition: transform 0.3s ease;

    }

    

    .surgut-map-info-sidebar.active {

        transform: translateX(0);

    }

}



/* ===== СЛАЙДЕР ИЗОБРАЖЕНИЙ ===== */



/* Слайдер изображений - точно как в рабочей версии */

.image-slider {

  position: relative;

  width: 100%;

  height: 210px;

  overflow: hidden;

  border-radius: var(--radius) var(--radius) 0 0;

}



.slider-container {

  position: relative;

  width: 100%;

  height: 100%;

}



.slider-image {

  width: 100%;

  height: 100%;

  object-fit: cover;

  transition: opacity 0.3s ease;

}



/* Slider controls - точно как в рабочей версии */

.slider-controls {

  position: absolute;

  bottom: 10px;

  left: 50%;

  transform: translateX(-50%);

  display: flex;

  align-items: center;

  gap: 10px;

  background: rgba(0, 0, 0, 0.7);

  padding: 8px 12px;

  border-radius: 20px;

  backdrop-filter: blur(10px);

}



.slider-btn {

  background: rgba(255, 255, 255, 0.2);

  border: none;

  color: white;

  width: 28px;

  height: 28px;

  border-radius: 50%;

  cursor: pointer;

  display: flex;

  align-items: center;

  justify-content: center;

  transition: all 0.2s ease;

}



.slider-btn:hover {

  background: rgba(255, 255, 255, 0.3);

  transform: scale(1.1);

}



.slider-btn i {

  font-size: 14px;

}



/* Slider dots - исправляем размеры */

.slider-dots {

  display: flex;

  gap: 6px;

}



.dot {

  width: 8px !important;

  height: 8px !important;

  border-radius: 50% !important;

  background: rgba(255, 255, 255, 0.5) !important;

  cursor: pointer !important;

  transition: all 0.2s ease !important;

  /* Убираем любые возможные padding и margin */

  padding: 0 !important;

  margin: 0 !important;

  /* Принудительно устанавливаем размер */

  min-width: 8px !important;

  min-height: 8px !important;

  max-width: 8px !important;

  max-height: 8px !important;

  /* Убираем border */

  border: none !important;

  /* Убираем outline */

  outline: none !important;

}



.dot.active {

  background: white !important;

  transform: scale(1.2) !important;

}



.slider-counter {

  position: absolute;

  top: 10px;

  right: 10px;

  background: rgba(0, 0, 0, 0.7);

  color: white;

  padding: 4px 8px;

  border-radius: 12px;

  font-size: 0.8rem;

  font-weight: 600;

  backdrop-filter: blur(10px);

}



/* Более специфичные селекторы для dots */

.image-slider .slider-dots .dot {

  width: 8px !important;

  height: 8px !important;

  border-radius: 50% !important;

  background: rgba(255, 255, 255, 0.5) !important;

  cursor: pointer !important;

  transition: all 0.2s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 8px !important;

  min-height: 8px !important;

  max-width: 8px !important;

  max-height: 8px !important;

  border: none !important;

  outline: none !important;

}



.image-slider .slider-dots .dot.active {

  background: white !important;

  transform: scale(1.2) !important;

}



/* ===== СЛАЙДЕР ИЗОБРАЖЕНИЙ - ПРИНУДИТЕЛЬНОЕ ПЕРЕОПРЕДЕЛЕНИЕ ===== */



/* Слайдер изображений - принудительно переопределяем все стили */

.surgut-map-container .image-slider {

  position: relative !important;

  width: 100% !important;

  height: 210px !important;

  overflow: hidden !important;

  border-radius: 14px 14px 0 0 !important;

}



.surgut-map-container .slider-container {

  position: relative !important;

  width: 100% !important;

  height: 100% !important;

}



.surgut-map-container .slider-image {

  width: 100% !important;

  height: 100% !important;

  object-fit: cover !important;

  transition: opacity 0.3s ease !important;

}



/* Slider controls - принудительно переопределяем все стили */

.surgut-map-container .slider-controls {

  position: absolute !important;

  bottom: 10px !important;

  left: 50% !important;

  transform: translateX(-50%) !important;

  display: flex !important;

  align-items: center !important;

  gap: 10px !important;

  background: rgba(0, 0, 0, 0.7) !important;

  padding: 8px 12px !important;

  border-radius: 20px !important;

  backdrop-filter: blur(10px) !important;

  -webkit-backdrop-filter: blur(10px) !important;

}



.surgut-map-container .slider-btn {

  background: rgba(255, 255, 255, 0.2) !important;

  border: none !important;

  color: white !important;

  width: 28px !important;

  height: 28px !important;

  border-radius: 50% !important;

  cursor: pointer !important;

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  transition: all 0.2s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 28px !important;

  min-height: 28px !important;

  max-width: 28px !important;

  max-height: 28px !important;

}



.surgut-map-container .slider-btn:hover {

  background: rgba(255, 255, 255, 0.3) !important;

  transform: scale(1.1) !important;

}



.surgut-map-container .slider-btn i {

  font-size: 14px !important;

  color: white !important;

}



/* Slider dots - принудительно переопределяем размеры */

.surgut-map-container .slider-dots {

  display: flex !important;

  gap: 6px !important;

}



.surgut-map-container .slider-dots .dot {

  width: 8px !important;

  height: 8px !important;

  border-radius: 50% !important;

  background: rgba(255, 255, 255, 0.5) !important;

  cursor: pointer !important;

  transition: all 0.2s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 8px !important;

  min-height: 8px !important;

  max-width: 8px !important;

  max-height: 8px !important;

  border: none !important;

  outline: none !important;

  box-sizing: border-box !important;

}



.surgut-map-container .slider-dots .dot.active {

  background: white !important;

  transform: scale(1.2) !important;

}



.surgut-map-container .slider-counter {

  position: absolute !important;

  top: 10px !important;

  right: 10px !important;

  background: rgba(0, 0, 0, 0.7) !important;

  color: white !important;

  padding: 4px 8px !important;

  border-radius: 12px !important;

  font-size: 0.8rem !important;

  font-weight: 600 !important;

  backdrop-filter: blur(10px) !important;

  -webkit-backdrop-filter: blur(10px) !important;

}



/* ===== СЛАЙДЕР ИЗОБРАЖЕНИЙ - ИСПРАВЛЕНИЕ DOTS И РАСШИРЕНИЕ ===== */



/* Слайдер изображений - расширяем и исправляем dots */

.surgut-map-container .image-slider {

  position: relative !important;

  width: 100% !important;

  height: 250px !important; /* Увеличили высоту */

  overflow: hidden !important;

  border-radius: 14px 14px 0 0 !important;

}



.surgut-map-container .slider-container {

  position: relative !important;

  width: 100% !important;

  height: 100% !important;

}



.surgut-map-container .slider-image {

  width: 100% !important;

  height: 100% !important;

  object-fit: cover !important;

  transition: opacity 0.3s ease !important;

}



/* Slider controls - исправляем позиционирование dots */

.surgut-map-container .slider-controls {

  position: absolute !important;

  bottom: 15px !important; /* Немного подняли */

  left: 50% !important;

  transform: translateX(-50%) !important;

  display: flex !important;

  align-items: center !important;

  gap: 15px !important; /* Увеличили gap между элементами */

  background: rgba(0, 0, 0, 0.7) !important;

  padding: 10px 16px !important; /* Увеличили padding */

  border-radius: 25px !important; /* Увеличили радиус */

  backdrop-filter: blur(10px) !important;

  -webkit-backdrop-filter: blur(10px) !important;

}



.surgut-map-container .slider-btn {

  background: rgba(255, 255, 255, 0.2) !important;

  border: none !important;

  color: white !important;

  width: 32px !important; /* Увеличили размер кнопок */

  height: 32px !important;

  border-radius: 50% !important;

  cursor: pointer !important;

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  transition: all 0.2s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 32px !important;

  min-height: 32px !important;

  max-width: 32px !important;

  max-height: 32px !important;

}



.surgut-map-container .slider-btn:hover {

  background: rgba(255, 255, 255, 0.3) !important;

  transform: scale(1.1) !important;

}



.surgut-map-container .slider-btn i {

  font-size: 16px !important; /* Увеличили размер иконок */

  color: white !important;

}



/* Slider dots - исправляем позиционирование и размеры */

.surgut-map-container .slider-dots {

  display: flex !important;

  gap: 8px !important; /* Увеличили gap между dots */

  align-items: center !important;

  justify-content: center !important;

}



.surgut-map-container .slider-dots .dot {

  width: 10px !important; /* Немного увеличили размер */

  height: 10px !important;

  border-radius: 50% !important;

  background: rgba(255, 255, 255, 0.5) !important;

  cursor: pointer !important;

  transition: all 0.2s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 10px !important;

  min-height: 10px !important;

  max-width: 10px !important;

  max-height: 10px !important;

  border: none !important;

  outline: none !important;

  box-sizing: border-box !important;

  flex-shrink: 0 !important; /* Предотвращаем сжатие */

}



.surgut-map-container .slider-dots .dot.active {

  background: white !important;

  transform: scale(1.2) !important;

}



.surgut-map-container .slider-counter {

  position: absolute !important;

  top: 15px !important; /* Немного опустили */

  right: 15px !important;

  background: rgba(0, 0, 0, 0.7) !important;

  color: white !important;

  padding: 6px 10px !important; /* Увеличили padding */

  border-radius: 15px !important;

  font-size: 0.85rem !important; /* Немного увеличили шрифт */

  font-weight: 600 !important;

  backdrop-filter: blur(10px) !important;

  -webkit-backdrop-filter: blur(10px) !important;

}



/* ===== СЛАЙДЕР ИЗОБРАЖЕНИЙ - ПОЛНОЕ ИСПРАВЛЕНИЕ ===== */



/* Слайдер изображений - исправляем обрезку */

.surgut-map-container .image-slider {

  position: relative !important;

  width: 100% !important;

  height: 250px !important;

  overflow: visible !important; /* Убираем обрезку */

  border-radius: 14px 14px 0 0 !important;

}



.surgut-map-container .slider-container {

  position: relative !important;

  width: 100% !important;

  height: 100% !important;

  overflow: hidden !important; /* Обрезка только для изображений */

  border-radius: 14px 14px 0 0 !important;

}



.surgut-map-container .slider-image {

  width: 100% !important;

  height: 100% !important;

  object-fit: cover !important;

  transition: opacity 0.3s ease !important;

}



/* Slider controls - полностью переопределяем позиционирование */

.surgut-map-container .slider-controls {

  position: absolute !important;

  bottom: 15px !important;

  left: 50% !important;

  transform: translateX(-50%) !important;

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  gap: 20px !important; /* Увеличили gap еще больше */

  background: rgba(0, 0, 0, 0.8) !important;

  padding: 12px 20px !important;

  border-radius: 30px !important;

  backdrop-filter: blur(15px) !important;

  -webkit-backdrop-filter: blur(15px) !important;

  z-index: 1000 !important; /* Принудительно поднимаем */

}



.surgut-map-container .slider-btn {

  background: rgba(255, 255, 255, 0.25) !important;

  border: none !important;

  color: white !important;

  width: 36px !important;

  height: 36px !important;

  border-radius: 50% !important;

  cursor: pointer !important;

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  transition: all 0.3s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 36px !important;

  min-height: 36px !important;

  max-width: 36px !important;

  max-height: 36px !important;

  flex-shrink: 0 !important;

}



.surgut-map-container .slider-btn:hover {

  background: rgba(255, 255, 255, 0.4) !important;

  transform: scale(1.15) !important;

}



.surgut-map-container .slider-btn i {

  font-size: 18px !important;

  color: white !important;

  line-height: 1 !important;

}



/* Slider dots - принудительно исправляем позиционирование */

.surgut-map-container .slider-dots {

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  gap: 12px !important; /* Еще больше увеличили gap */

  flex-shrink: 0 !important;

  margin: 0 10px !important; /* Добавили отступы */

}



.surgut-map-container .slider-dots .dot {

  display: inline-block !important;

  width: 12px !important;

  height: 12px !important;

  border-radius: 50% !important;

  background: rgba(255, 255, 255, 0.6) !important;

  cursor: pointer !important;

  transition: all 0.3s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 12px !important;

  min-height: 12px !important;

  max-width: 12px !important;

  max-height: 12px !important;

  border: none !important;

  outline: none !important;

  box-sizing: border-box !important;

  flex-shrink: 0 !important;

  position: relative !important; /* Добавили position */

}



.surgut-map-container .slider-dots .dot.active {

  background: white !important;

  transform: scale(1.3) !important;

  box-shadow: 0 0 10px rgba(255, 255, 255, 0.5) !important;

}



.surgut-map-container .slider-counter {

  position: absolute !important;

  top: 15px !important;

  right: 15px !important;

  background: rgba(0, 0, 0, 0.8) !important;

  color: white !important;

  padding: 8px 12px !important;

  border-radius: 18px !important;

  font-size: 0.9rem !important;

  font-weight: 600 !important;

  backdrop-filter: blur(15px) !important;

  -webkit-backdrop-filter: blur(15px) !important;

  z-index: 1000 !important;

}



/* ===== СЛАЙДЕР ИЗОБРАЖЕНИЙ - КОМПАКТНЫЙ ВАРИАНТ ===== */



/* Слайдер изображений - компактный размер */

.surgut-map-container .image-slider {

  position: relative !important;

  width: 100% !important;

  height: 200px !important; /* Уменьшили высоту */

  overflow: visible !important;

  border-radius: 14px 14px 0 0 !important;

}



.surgut-map-container .slider-container {

  position: relative !important;

  width: 100% !important;

  height: 100% !important;

  overflow: hidden !important;

  border-radius: 14px 14px 0 0 !important;

}



.surgut-map-container .slider-image {

  width: 100% !important;

  height: 100% !important;

  object-fit: cover !important;

  transition: opacity 0.3s ease !important;

}



/* Slider controls - компактный размер */

.surgut-map-container .slider-controls {

  position: absolute !important;

  bottom: 8px !important; /* Подняли ближе к изображению */

  left: 50% !important;

  transform: translateX(-50%) !important;

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  gap: 15px !important; /* Уменьшили gap */

  background: rgba(0, 0, 0, 0.75) !important;

  padding: 8px 16px !important; /* Уменьшили padding */

  border-radius: 20px !important; /* Уменьшили радиус */

  backdrop-filter: blur(10px) !important;

  -webkit-backdrop-filter: blur(10px) !important;

  z-index: 1000 !important;

}



.surgut-map-container .slider-btn {

  background: rgba(255, 255, 255, 0.2) !important;

  border: none !important;

  color: white !important;

  width: 28px !important; /* Уменьшили размер кнопок */

  height: 28px !important;

  border-radius: 50% !important;

  cursor: pointer !important;

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  transition: all 0.3s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 28px !important;

  min-height: 28px !important;

  max-width: 28px !important;

  max-height: 28px !important;

  flex-shrink: 0 !important;

}



.surgut-map-container .slider-btn:hover {

  background: rgba(255, 255, 255, 0.3) !important;

  transform: scale(1.1) !important;

}



.surgut-map-container .slider-btn i {

  font-size: 14px !important; /* Уменьшили размер иконок */

  color: white !important;

  line-height: 1 !important;

}



/* Slider dots - компактный размер */

.surgut-map-container .slider-dots {

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  gap: 8px !important; /* Уменьшили gap */

  flex-shrink: 0 !important;

  margin: 0 8px !important; /* Уменьшили отступы */

}



.surgut-map-container .slider-dots .dot {

  display: inline-block !important;

  width: 8px !important; /* Уменьшили размер dots */

  height: 8px !important;

  border-radius: 50% !important;

  background: rgba(255, 255, 255, 0.6) !important;

  cursor: pointer !important;

  transition: all 0.3s ease !important;

  padding: 0 !important;

  margin: 0 !important;

  min-width: 8px !important;

  min-height: 8px !important;

  max-width: 8px !important;

  max-height: 8px !important;

  border: none !important;

  outline: none !important;

  box-sizing: border-box !important;

  flex-shrink: 0 !important;

  position: relative !important;

}



.surgut-map-container .slider-dots .dot.active {

  background: white !important;

  transform: scale(1.2) !important;

  box-shadow: 0 0 8px rgba(255, 255, 255, 0.4) !important;

}



.surgut-map-container .slider-counter {

  position: absolute !important;

  top: 8px !important; /* Подняли ближе к краю */

  right: 8px !important;

  background: rgba(0, 0, 0, 0.75) !important;

  color: white !important;

  padding: 6px 10px !important; /* Уменьшили padding */

  border-radius: 15px !important;

  font-size: 0.8rem !important; /* Уменьшили шрифт */

  font-weight: 600 !important;

  backdrop-filter: blur(10px) !important;

  -webkit-backdrop-filter: blur(10px) !important;

  z-index: 1000 !important;

}



/* Скрываем стандартную атрибуцию Leaflet */

.leaflet-control-attribution {

  display: none !important;

}



.leaflet-control-attribution.leaflet-control {

  display: none !important;

}



/* Дополнительно скрываем все элементы атрибуции */

.leaflet-control-attribution a,

.leaflet-control-attribution span,

.leaflet-control-attribution div {

  display: none !important;

}



/* Скрываем флаг Украины и текст Leaflet */

.leaflet-attribution-flag,

.leaflet-control-attribution:contains("Leaflet") {

  display: none !important;

}



/* Красивые стили для переключателя карт */

.leaflet-control-layers {

  background: var(--glass-strong) !important;

  border: 1px solid rgba(255, 255, 255, 0.2) !important;

  border-radius: var(--radius) !important;

  backdrop-filter: blur(10px) !important;

  -webkit-backdrop-filter: blur(10px) !important;

  box-shadow: var(--shadow-soft) !important;

  transition: all 0.3s ease !important;

}



.leaflet-control-layers:hover {

  background: var(--glass) !important;

  transform: translateY(-2px) !important;

  box-shadow: var(--shadow-strong) !important;

}



/* Иконка переключателя карт */

.leaflet-control-layers-toggle {

  width: 36px !important;

  height: 36px !important;

  background: linear-gradient(135deg, var(--primary), var(--primary-2)) !important;

  border: none !important;

  border-radius: 50% !important;

  color: white !important;

  font-size: 18px !important;

  display: flex !important;

  align-items: center !important;

  justify-content: center !important;

  cursor: pointer !important;

  transition: all 0.3s ease !important;

  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3) !important;

}



.leaflet-control-layers-toggle:hover {

  background: linear-gradient(135deg, var(--primary-2), var(--primary)) !important;

  transform: scale(1.1) !important;

  box-shadow: 0 6px 20px rgba(37, 99, 235, 0.4) !important;

}



/* Панель выбора карт */

.leaflet-control-layers-expanded {

  padding: 16px !important;

  min-width: 200px !important;

  background: var(--glass-strong) !important;

  border: 1px solid rgba(255, 255, 255, 0.2) !important;

  border-radius: var(--radius) !important;

  backdrop-filter: blur(15px) !important;

  -webkit-backdrop-filter: blur(15px) !important;

  box-shadow: var(--shadow-strong) !important;

}



/* Заголовок панели */

.leaflet-control-layers-expanded h4 {

  margin: 0 0 12px 0 !important;

  color: var(--text) !important;

  font-size: 14px !important;

  font-weight: 600 !important;

  text-align: center !important;

  padding-bottom: 8px !important;

  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;

}



/* Радиокнопки выбора карт */

.leaflet-control-layers-expanded input[type="radio"] {

  margin-right: 8px !important;

  accent-color: var(--primary) !important;

}



/* Лейблы для карт */

.leaflet-control-layers-expanded label {

  display: flex !important;

  align-items: center !important;

  margin: 8px 0 !important;

  color: var(--text) !important;

  font-size: 13px !important;

  cursor: pointer !important;

  transition: color 0.2s ease !important;

  padding: 6px 8px !important;

  border-radius: var(--radius-sm) !important;

}



.leaflet-control-layers-expanded label:hover {

  color: var(--primary) !important;

  background: rgba(37, 99, 235, 0.1) !important;

}



/* Темная тема */

body.theme-dark .leaflet-control-layers {

  background: var(--glass-strong) !important;

  border-color: rgba(255, 255, 255, 0.1) !important;

}



body.theme-dark .leaflet-control-layers-expanded {

  background: var(--glass-strong) !important;

  border-color: rgba(255, 255, 255, 0.1) !important;

}



body.theme-dark .leaflet-control-layers-expanded h4 {

  color: var(--text) !important;

  border-bottom-color: rgba(255, 255, 255, 0.1) !important;

}



body.theme-dark .leaflet-control-layers-expanded label {

  color: var(--text) !important;

}



body.theme-dark .leaflet-control-layers-expanded label:hover {

  background: rgba(34, 211, 238, 0.1) !important;

}



/* Стили для рейтинга с отзывами */

.popup-rating,

.card-rating {

    display: flex;

    align-items: center;

    gap: 8px;

    margin: 12px 0;

    flex-wrap: wrap;

}



.popup-rating .stars,

.card-rating .stars {

    display: flex;

    align-items: center;

    gap: 2px;

}



.popup-rating .stars i,

.card-rating .stars i {

    color: #fbbf24;

    font-size: 14px;

}



.popup-rating span,

.card-rating span {

    font-size: 14px;

    color: var(--text-secondary);

    font-weight: 500;

}



.review-count {

    color: var(--text-muted) !important;

    font-size: 12px !important;

    font-weight: 400 !important;

}



.reviews-link {

    color: var(--primary);

    text-decoration: none;

    font-size: 12px;

    font-weight: 500;

    padding: 4px 8px;

    background: rgba(59, 130, 246, 0.1);

    border-radius: 4px;

    transition: all 0.2s ease;

}



.reviews-link:hover {

    background: rgba(59, 130, 246, 0.2);

    color: var(--primary);

    text-decoration: underline;

}



/* Стили для рейтинга в popup */

.popup-rating {

    padding: 8px 0;

    border-bottom: 1px solid rgba(0, 0, 0, 0.1);

}



/* Стили для рейтинга в карточке */

.card-rating {

    padding: 12px 0;

    border-bottom: 1px solid rgba(0, 0, 0, 0.05);

}



/* Адаптивность для мобильных устройств */

@media (max-width: 768px) {

    .popup-rating,

    .card-rating {

        flex-direction: column;

        align-items: flex-start;

        gap: 6px;

    }

    

    .reviews-link {

        align-self: flex-start;

    }

}



/* ===== КНОПКИ УПРАВЛЕНИЯ САЙДБАРОМ ===== */



/* Кнопка закрытия в хедере сайдбара */

.sidebar-toggle-btn {

    background: rgba(255, 255, 255, 0.1);

    border: 1px solid rgba(255, 255, 255, 0.2);

    border-radius: 8px;

    width: 32px;

    height: 32px;

    display: flex;

    align-items: center;

    justify-content: center;

    cursor: pointer;

    transition: all 0.3s ease;

    backdrop-filter: blur(10px);

    -webkit-backdrop-filter: blur(10px);

    color: var(--text);

}



.sidebar-toggle-btn:hover {

    background: rgba(255, 255, 255, 0.2);

    border-color: var(--primary);

    color: var(--primary);

    transform: scale(1.05);

}



.sidebar-toggle-btn i {

    font-size: 14px;

    line-height: 1;

}



/* Кнопка открытия сайдбара (плавающая) */

.sidebar-open-btn {

    position: fixed;

    top: 50%;

    right: 20px;

    transform: translateY(-50%);

    z-index: 1300;

    width: 48px;

    height: 48px;

    border-radius: 50%;

    background: linear-gradient(135deg, var(--primary), var(--primary-2));

    color: white;

    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.3);

    border: 2px solid rgba(255, 255, 255, 0.2);

}



.sidebar-open-btn:hover {

    background: linear-gradient(135deg, var(--primary-2), var(--primary));

    transform: translateY(-50%) scale(1.1);

    box-shadow: 0 12px 32px rgba(37, 99, 235, 0.4);

}



.sidebar-open-btn i {

    font-size: 18px;

}



/* ===== СКРЫТОЕ СОСТОЯНИЕ САЙДБАРА ===== */



/* Скрытие сайдбара на десктопе */

@media (min-width: 993px) {

    .surgut-map-info-sidebar.is-hidden {

        transform: translateX(100%);

        transition: transform 0.3s ease;

    }

    

    .surgut-map-info-sidebar {

        transition: transform 0.3s ease;

    }

}



/* Обновляем хедер сайдбара для размещения кнопки */

.surgut-map-info-header {

    display: flex;

    justify-content: space-between;

    align-items: center;

    padding: 12px 0 14px;

    margin-bottom: 12px;

    background: var(--glass-strong);

    z-index: 1;

    border-bottom: 1px solid rgba(2, 6, 23, 0.08);

    backdrop-filter: blur(12px);

    -webkit-backdrop-filter: blur(12px);

}



.surgut-map-info-header h3 {

    color: var(--primary);

    font-size: 1.15rem;

    line-height: 1.2;

    letter-spacing: 0.2px;

    margin: 0;

    flex: 1;

}



/* Темная тема для кнопок */

body.theme-dark .sidebar-toggle-btn {

    background: rgba(17, 24, 39, 0.6);

    border-color: rgba(255, 255, 255, 0.1);

    color: var(--text);

}



body.theme-dark .sidebar-toggle-btn:hover {

    background: rgba(17, 24, 39, 0.8);

    border-color: var(--accent);

    color: var(--accent);

}



body.theme-dark .sidebar-open-btn {

    background: linear-gradient(135deg, var(--accent), #0891b2);

    box-shadow: 0 8px 24px rgba(34, 211, 238, 0.3);

}



body.theme-dark .sidebar-open-btn:hover {

    background: linear-gradient(135deg, #0891b2, var(--accent));

    box-shadow: 0 12px 32px rgba(34, 211, 238, 0.4);

}



/* Мобильные устройства - обновляем кнопку закрытия для мобильного сайдбара */

@media (max-width: 992px) {

    .sidebar-open-btn {

        display: none !important; /* На мобильных используем существующую логику */

    }

    

    .surgut-map-info-sidebar .sidebar-toggle-btn {

        background: rgba(0, 0, 0, 0.1);

        border-color: rgba(255, 255, 255, 0.3);

        color: white;

    }

    

    .surgut-map-info-sidebar .sidebar-toggle-btn:hover {

        background: rgba(0, 0, 0, 0.2);

        color: white;

    }

}



/* ===== ОВЕРЛЕЙ ДЛЯ МОБИЛЬНЫХ УСТРОЙСТВ ===== */



.sidebar-overlay {

    position: fixed;

    top: 0;

    left: 0;

    right: 0;

    bottom: 0;

    background: rgba(0, 0, 0, 0.5);

    z-index: 1100;

    backdrop-filter: blur(2px);

    -webkit-backdrop-filter: blur(2px);

    transition: opacity 0.3s ease;

}



/* ===== УЛУЧШЕННЫЕ МОБИЛЬНЫЕ СТИЛИ ===== */



@media (max-width: 992px) {

    .surgut-map-info-sidebar {

        position: fixed;

        top: 0;

        right: 0;

        height: 100vh;

        width: 90%;

        max-width: 400px;

        transform: translateX(100%);

        transition: transform 0.3s ease;

        z-index: 1200;

        box-shadow: -10px 0 40px rgba(0, 0, 0, 0.3);

    }

    

    .surgut-map-info-sidebar.active {

        transform: translateX(0);

    }

    

    /* Кнопка открытия на мобильных - показывается только когда сайдбар скрыт */

    .sidebar-open-btn {

        position: fixed !important;

        bottom: 20px !important;

        right: 20px !important;

        top: auto !important;

        transform: none !important;

        width: 56px !important;

        height: 56px !important;

        z-index: 1000;

    }

    

    .sidebar-open-btn i {

        font-size: 20px !important;

    }

    

    /* Стили кнопки закрытия для мобильных */

    .surgut-map-info-sidebar .sidebar-toggle-btn {

        background: rgba(255, 255, 255, 0.1);

        border-color: rgba(255, 255, 255, 0.2);

        color: var(--text);

    }

    

    .surgut-map-info-sidebar .sidebar-toggle-btn:hover {

        background: rgba(255, 255, 255, 0.2);

        color: var(--primary);

    }

}



/* Скрываем плавающую кнопку на десктопе, когда сайдбар открыт */

@media (min-width: 993px) {

    .surgut-map-info-sidebar:not(.is-hidden) ~ .sidebar-open-btn {

        display: none !important;

    }

}



/* ===== ЛЕГЕНДА КАРТЫ ===== */

.legend-control {

    background: rgba(255, 255, 255, 0.95);

    backdrop-filter: blur(10px);

    border-radius: 8px;

    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);

    border: 1px solid rgba(0, 0, 0, 0.1);

    max-width: 200px;

    min-width: 160px;

    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;

    font-size: 12px;

    overflow: hidden;

}



.legend-header {

    background: #2c3e50;

    color: white;

    padding: 8px 12px;

    font-weight: 600;

    font-size: 13px;

    text-align: center;

    border-bottom: 1px solid rgba(255, 255, 255, 0.2);

}



.legend-items {

    padding: 8px;

}



.legend-item {

    display: flex;

    align-items: center;

    margin-bottom: 6px;

    gap: 8px;

}



.legend-item:last-child {

    margin-bottom: 0;

}



.legend-color {

    width: 16px;

    height: 16px;

    border-radius: 50%;

    border: 2px solid rgba(255, 255, 255, 0.5);

    flex-shrink: 0;

    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);

}



.legend-text {

    color: #333;

    font-weight: 500;

    white-space: nowrap;

}



/* Темная тема для легенды */

body.theme-dark .legend-control {

    background: rgba(33, 37, 41, 0.95);

    border-color: rgba(255, 255, 255, 0.1);

}



body.theme-dark .legend-header {

    background: #495057;

}



body.theme-dark .legend-text {

    color: #e9ecef;

}



/* ===== ПОДПИСЬ С ЛОГОТИПОМ ===== */

.signature-control {

    background: rgba(255, 255, 255, 0.9);

    backdrop-filter: blur(8px);

    border-radius: 8px;

    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);

    border: 1px solid rgba(0, 0, 0, 0.1);

    padding: 8px;

    min-width: 80px;

    text-align: center;

}



.signature-content {

    display: flex;

    flex-direction: column;

    align-items: center;

    gap: 4px;

}



.signature-logo {

    width: 32px;

    height: 32px;

    border-radius: 50%;

    overflow: hidden;

    background: white;

    padding: 2px;

    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);

}



.signature-icon {

    width: 100%;

    height: 100%;

    object-fit: cover;

    border-radius: 50%;

}



.signature-text {

    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;

    font-size: 10px;

    font-weight: 600;

    color: #2c3e50;

    line-height: 1.2;

    text-transform: uppercase;

    letter-spacing: 0.5px;

}



/* Темная тема для подписи */

body.theme-dark .signature-control {

    background: rgba(33, 37, 41, 0.9);

    border-color: rgba(255, 255, 255, 0.1);

}



body.theme-dark .signature-logo {

    background: #495057;

}



body.theme-dark .signature-text {

    color: #e9ecef;

}



/* Адаптивность для мобильных устройств */

@media (max-width: 768px) {

    .legend-control {

        max-width: 180px;

        min-width: 140px;

        font-size: 11px;

    }



    .legend-header {

        padding: 6px 10px;

        font-size: 12px;

    }



    .legend-items {

        padding: 6px;

    }



    .legend-item {

        margin-bottom: 4px;

        gap: 6px;

    }



    .legend-color {

        width: 14px;

        height: 14px;

    }



    .signature-control {

        padding: 6px;

        min-width: 70px;

    }



    .signature-logo {

        width: 28px;

        height: 28px;

    }



    .signature-text {

        font-size: 9px;

    }

}



/* Анимация появления */

.legend-control,

.signature-control {

    animation: fadeInUp 0.3s ease-out;

}



@keyframes fadeInUp {

    from {

        opacity: 0;

        transform: translateY(10px);

    }

    to {

        opacity: 1;

        transform: translateY(0);

    }

}