/* --- ГЛОБАЛЬНЫЕ НАСТРОЙКИ И ПЕРЕМЕННЫЕ --- */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700;800&display=swap');

:root {
    --font-main: 'Manrope', sans-serif;
    --color-bg-light: #F9FAFB;
    --color-bg-white: #FFFFFF;
    --color-text-primary: #111827;
    --color-text-secondary: #6B7280;
    --color-text-tertiary: #9CA3AF;
    --color-border: #E5E7EB;
    --color-accent: #F97316;
    --color-accent-hover: #EA580C;
    --color-accent-light: #FFF7ED;
    --color-verified: #10B981;
    --shadow-soft: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
    --border-radius: 12px;
}

html {
    font-family: var(--font-main);
    color: var(--color-text-primary);
    background-color: var(--color-bg-light);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transition: background-color 0.3s ease, color 0.3s ease;
}
/* static/css/dashboard-catalog.css */

/* --- Стили для скелетонов (заглушек) --- */
.skeleton {
    background-color: var(--skeleton-bg, #e5e7eb);
    border-radius: 4px;
    animation: pulse 1.5s cubic-bezier(0.4, 0, 0.6, 1) infinite;
    color: transparent; /* Скрываем текст, если он есть */
    user-select: none;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* Применяем стили к карточке в состоянии загрузки */
.service-card.is-loading .card-image,
.service-card.is-loading .skeleton-text {
    background-color: var(--skeleton-bg, #e5e7eb);
    border-radius: 4px;
    animation: pulse 1.5s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

.service-card.is-loading .card-image {
    height: 150px; /* Фиксированная высота для заглушки */
    background-image: none !important; /* Убираем фоновое изображение */
}
.service-card.is-loading .skeleton-text {
    height: 1em;
    margin-bottom: 0.5em;
    border-radius: 4px;
    color: transparent; /* Скрываем текст */
}

/* Переменные для тем */
:root {
    --skeleton-bg: #e5e7eb; /* Цвет для светлой темы */
}
.dark-theme {
    --skeleton-bg: #374151; /* Цвет для темной темы */
}

/* Скрываем реальные элементы внутри карточки во время загрузки */
.results-grid.is-loading .service-card:not(.is-skeleton-template) > * {
    visibility: hidden;
}
.results-grid.is-loading .service-card:not(.is-skeleton-template) {
    border-color: transparent;
    box-shadow: none;
}

body {
    background-color: var(--color-bg-light); /* Синхронизируем с html */
}

.container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
}


.main-nav .auth-buttons {
    display: flex;
    align-items: center;
    gap: 12px;
}

.main-nav .auth-buttons button {
    padding: 8px 18px;
    border-radius: 8px;
    font-weight: 700;
    font-size: 0.95rem;
    cursor: pointer;
    border: none;
    transition: all 0.2s ease;
}

.main-nav .btn-primary {
    background-color: var(--color-accent);
    color: white;
}
.main-nav .btn-primary:hover {
    background-color: var(--color-accent-hover);
}

.main-nav .btn-secondary {
    background-color: transparent;
    color: var(--color-text-primary);
    border: 1px solid var(--color-border);
}
.main-nav .btn-secondary:hover {
    background-color: var(--color-bg-light);
    border-color: var(--color-text-secondary);
}


/* Эффект для кнопок */
.btn-apply, .btn-chat, .category-button, .category-tile, .view-switcher button, .bottom-bar-item {
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-apply:active, .btn-chat:active, .category-button:active, .category-tile:active, .view-switcher button:active {
    transform: scale(0.97);
    transition-duration: 0.1s;
}

/* --- ОСНОВНАЯ ШАПКА --- */
.main-header { background-color: var(--color-bg-white); border-bottom: 1px solid var(--color-border); padding: 15px 0; position: sticky; top: 0; z-index: 1000; transition: background-color 0.3s ease, border-color 0.3s ease; }
.header-inner { display: flex; align-items: center; justify-content: space-between; }

.header-logo {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 1.8rem;
    font-weight: 800;
    text-decoration: none;
    color: var(--color-text-primary);
    flex-shrink: 0;
}

.logo-dot {
    display: inline-block;
    width: 0.5em;
    height: 0.5em;
    background-color: var(--color-accent);
    border-radius: 50%;
    transform: translateY(0.1em);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);

}
.logo-dot {
      var(--color-accent);
}

.header-search { position: relative; width: 40%; }
.header-search i { position: absolute; left: 15px; top: 50%; transform: translateY(-50%); color: var(--color-text-secondary); }
.header-search input { width: 100%; padding: 12px 12px 12px 40px; border: 1px solid var(--color-border); border-radius: 8px; font-size: 1rem; background-color: transparent; color: var(--color-text-primary); }
.main-nav { display: flex; align-items: center; gap: 15px; } /* Уменьшил gap для кнопки темы */
.main-nav a { display: flex; align-items: center; gap: 8px; text-decoration: none; color: var(--color-text-secondary); font-weight: 600; transition: color 0.2s ease; }
.main-nav a:hover { color: var(--color-accent); }
.main-nav svg { width: 22px; height: 22px; stroke: currentColor; stroke-width: 2; transition: all 0.2s ease; }
.main-nav a:hover svg { transform: scale(1.1); }
.user-profile { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.user-profile img { width: 36px; height: 36px; border-radius: 50%; }

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

/* --- СТИЛИ КАТЕГОРИЙ --- */
.category-showcase { padding: 20px 0; }
.category-grid-mobile { display: none; }
.category-selector { display: grid; grid-template-columns: 1fr 2fr; gap: 30px; align-items: stretch; }

.featured-category {
    background: linear-gradient(45deg, #F97316, #FBBF24);
    color: white;
    border-radius: 20px;
    padding: 30px;
    box-shadow: 0 10px 25px -5px rgba(249, 115, 22, 0.4);
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition: all 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.featured-category.changing { opacity: 0.7; transform: scale(0.98); }
.featured-category-content { display: flex; align-items: center; gap: 25px; }
.featured-category-text .subtitle { display: block; font-size: 0.9rem; opacity: 0.8; margin-bottom: 4px; }
.featured-category-text .title { display: block; font-size: 2.2rem; font-weight: 800; line-height: 1.1; }
.featured-category .icon-wrapper {
    width: 80px; height: 80px; background-color: rgba(255,255,255,0.2); border-radius: 24px;
    flex-shrink: 0; display: flex; align-items: center; justify-content: center;
}
.featured-category .icon-wrapper svg { width: 44px; height: 44px; stroke: white; stroke-width: 2; }

#other-categories-grid {
    display: grid;
    /*
     Создаем колонки:
     - auto-fill: заполнить все доступное пространство
     - minmax(180px, 1fr): каждая колонка будет минимум 180px,
       а если есть место, то растянется, чтобы занять его поровну.
     Это создает идеальную адаптивную сетку.
    */
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px; /* Расстояние между кнопками */
    padding: 16px;
    background-color: var(--color-background-secondary);
    border-radius: 16px;
    margin-top: -10px; /* Небольшой трюк, чтобы блок красиво "заходил" под баннер */
}

/* Стили для самих кнопок остаются почти такими же, но убедимся, что все на месте */
.category-button {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 12px;
    background-color: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-secondary);
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
    text-decoration: none;
    position: relative; /* Для счетчика */
}

.category-button:hover {
    background-color: var(--color-background-tertiary);
    border-color: var(--color-border-hover);
    color: var(--color-text-primary);
}

.category-button.active {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-text-on-primary);
    box-shadow: 0 4px 15px -5px var(--color-primary);
}

.category-button .icon-wrapper {
    width: 24px;
    height: 24px;
}
.category-button .icon-wrapper svg {
    width: 100%;
    height: 100%;
    stroke: var(--color-text-secondary);
    transition: stroke 0.2s ease-in-out;
}

.category-button:hover .icon-wrapper svg {
    stroke: var(--color-text-primary);
}

.category-button.active .icon-wrapper svg {
    stroke: var(--color-text-primary);
}

.category-count {
    /* Эти стили для счетчика уже должны быть у вас, просто проверьте */
    position: absolute;
    top: -5px;
    right: -5px;
    background-color: var(--color-accent);
    color: var(--color-text-on-primary);
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    line-height: 1;
    border: 1px solid var(--color-background-secondary);
}

.category-button.active .category-count {
    background-color: #fff;
    color: var(--color-primary);
    border-color: var(--color-primary);
}

/* 1. Основной контейнер для баннеров */
.category-selector {
    display: flex; /* Включаем Flexbox для выравнивания в ряд */
    gap: 24px;     /* Пространство между баннерами */
    min-height: 220px; /* Минимальная высота, чтобы контейнер не схлопывался */
}

/* 2. Стили для левого (главного) баннера */
.site-banner-link {
    flex: 1; /* Растягивается на доступное место */
    display: block;
    min-width: 0; /* Обязательно для правильной работы flex-элементов */
    border-radius: 16px;
    overflow: hidden;
    background-color: var(--color-surface-secondary);
    transition: transform 0.2s ease-in-out;
}
.site-banner-link:hover {
    transform: scale(1.02);
}

.site-banner {
    width: 100%;
    height: 100%;
    position: relative;
}

.site-banner-media {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Картинка или видео всегда заполняют блок */
    background-size: cover;
    background-position: center;
}

/* 3. Стили для правого (рекламного) баннера-слайдера */
.promo-banner-slider {
    flex: 2.5; /* Также растягивается на доступное место */
    min-width: 0;
    border-radius: 16px;
    overflow: hidden;
}

/* 4. Когда на странице только один баннер, он должен занимать всю ширину */
.category-selector.single-column-layout {
    flex-direction: column; /* Элементы встанут друг под друга (но т.к. один скрыт, будет виден только один) */
}
.category-selector.single-column-layout .site-banner-link,
.category-selector.single-column-layout .promo-banner-slider {
    flex-basis: 100%; /* Занимает 100% ширины родителя */
}

.category-button:hover { color: var(--color-accent); border-color: var(--color-accent); transform: translateY(-3px); box-shadow: var(--shadow-soft); }
.category-button:hover .icon-wrapper svg { stroke: var(--color-accent); }
.category-button.active { background-color: var(--color-accent-light); border-color: var(--color-accent); color: var(--color-accent); }
.category-button.active .icon-wrapper svg { stroke: var(--color-accent); }


/*
   ЗАМЕНИТЕ ВАШИ СТАРЫЕ СТИЛИ ДЛЯ КНОПОК КАТЕГОРИЙ НА ЭТОТ БЛОК
*/

/* --- Контейнер для кнопок --- */
.other-categories-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

/* --- Общий стиль кнопки --- */
.category-button {
    display: flex;
    align-items: center;
    padding: 16px 20px;
    border-radius: 12px;
    border: 1px solid var(--color-border);
    background-color: var(--color-surface-secondary);
    cursor: pointer;
    transition: all 0.2s ease-in-out;
    text-decoration: none;
    color: var(--color-primary); /* Оранжевый цвет для всего текста по умолчанию */
}
.page-wrapper.no-filters .container {
    display: block; /* или grid-template-columns: 1fr; */
}

.page-wrapper.no-filters .results-content {
    grid-column: 1 / -1; /* Занимает все доступное пространство */
}

/* --- Контейнер для текста --- */
.category-text-wrapper {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

/* --- Верхняя строка (Название + Число) --- */
.category-button-top-line {
    display: flex;
    align-items: baseline; /* Выравниваем по базовой линии текста */
    gap: 8px; /* Расстояние между названием и числом */
}

/* Название категории */
.category-button-main-text {
    font-size: 16px;
    font-weight: 600;
}

/* Число (счетчик) */
.category-button-count {
    font-size: 16px;
    font-weight: 700;
}

/* --- Нижняя строка (слово "поставщиков") --- */
.category-button-sub-text {
    font-size: 10px; /* Уменьшаем шрифт */
    font-weight: 500;
    color: var(--color-text-secondary); /* Делаем его более бледным */
    margin-top: 2px;
    transition: color 0.2s ease-in-out;
    text-transform: lowercase; /* <<-- ВОТ ЭТО ДЕЛАЕТ БУКВЫ МАЛЕНЬКИМИ */
}

/* Старый счетчик, который был кружочком, теперь не нужен */
.category-count {
    display: none;
}

/* --- СТРУКТУРА СТРАНИЦЫ --- */
.page-wrapper { padding: 40px 0; }
.page-wrapper .container { display: grid; grid-template-columns: 320px 1fr; gap: 30px; align-items: flex-start; }
.mobile-filter-btn, .bottom-bar { display: none; }

/* --- ПАНЕЛЬ ФИЛЬТРОВ --- */
.filters-panel { background-color: var(--color-bg-white); border-radius: var(--border-radius); padding: 25px; border: 1px solid var(--color-border); position: sticky; top: 100px; overflow: visible; transition: background-color 0.3s ease, border-color 0.3s ease;}
.mobile-filters-header { display: none; }
.filter-block { margin-bottom: 25px; }
.filter-block h4 { font-size: 1.1rem; margin-bottom: 15px; }
.custom-select, .filter-group input[type="text"] { width: 100%; padding: 12px; border-radius: 8px; border: 1px solid var(--color-border); background-color: var(--color-bg-light); color: var(--color-text-primary); font-size: 1rem; box-sizing: border-box; }
.location-input-wrapper { position: relative; }
.location-input-wrapper > i { position: absolute; left: 15px; top: 14px; color: var(--color-text-secondary); z-index: 2; }
#location-input { padding: 12px 12px 12px 40px; border-radius: 8px; border: 1px solid var(--color-border); background-color: var(--color-bg-light); font-size: 1rem; color: var(--color-text-primary);}
#location-input:focus { border-color: var(--color-accent); outline: none; box-shadow: 0 0 0 3px var(--color-accent-light); }
.suggestions-container { display: none; position: absolute; top: calc(100% + 5px); left: 0; right: 0; background-color: var(--color-bg-white); border: 1px solid var(--color-border); border-radius: 8px; box-shadow: 0 10px 20px rgba(0,0,0,0.1); z-index: 1010; max-height: 250px; overflow-y: auto; }
.suggestions-container.visible { display: block; }
.suggestion-item { padding: 12px 15px; cursor: pointer; transition: background-color 0.2s; color: var(--color-text-primary); }
.suggestion-item:hover { background-color: var(--color-accent-light); }
.filter-block label { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; cursor: pointer; font-size: 0.95rem; }
.filter-block input[type="checkbox"] { -webkit-appearance: none; appearance: none; background-color: var(--color-bg-light); margin: 0; font: inherit; color: currentColor; width: 1.15em; height: 1.15em; border: 0.1em solid var(--color-border); border-radius: 0.25em; transform: translateY(-0.075em); display: grid; place-content: center; cursor: pointer; flex-shrink: 0; transition: background-color 0.3s ease, border-color 0.3s ease; }
.filter-block input[type="checkbox"]::before { content: ""; width: 0.65em; height: 0.65em; transform: scale(0); transition: 120ms transform ease-in-out; box-shadow: inset 1em 1em var(--color-accent); transform-origin: bottom left; clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%); }
.filter-block input[type="checkbox"]:checked::before { transform: scale(1); }
.filter-block .fa-shield-alt { color: var(--color-verified); }
.filter-block .fa-certificate { color: #f59e0b; }
.filter-actions { margin-top: 30px; }
.btn-apply { width: 100%; padding: 14px; background-color: var(--color-accent); color: white; border: none; border-radius: 8px; font-weight: 700; cursor: pointer; margin-bottom: 10px; }
.btn-apply:disabled { background-color: var(--color-text-secondary); cursor: not-allowed; }
.btn-reset { width: 100%; background: none; border: none; color: var(--color-text-secondary); cursor: pointer; }

/* --- ДИНАМИЧЕСКИЕ ФИЛЬТРЫ --- */
.dynamic-filters-container { border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); margin: 25px -25px; padding: 0 25px; position: relative; min-height: 150px; transition: border-color 0.3s ease; }
.filter-group { opacity: 0; visibility: hidden; position: absolute; transform: translateY(10px); transition: opacity 0.4s ease, transform 0.4s ease, visibility 0.4s; width: calc(100% - 50px); }
.filter-group.active { opacity: 1; visibility: visible; position: relative; transform: translateY(0); padding-top: 25px; }
.interactive-rating { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }
.rating-value { font-size: 1rem; font-weight: 600; color: var(--color-text-primary); }
.stars-wrapper { position: relative; font-size: 1.4rem; color: #e0e2e7; cursor: pointer; line-height: 1; }
.stars-overlay { position: absolute; top: 0; left: 0; white-space: nowrap; overflow: hidden; color: #f59e0b; width: 0%; transition: width 0.1s ease-out; }
.custom-slider-container { position: relative; width: 100%; height: 16px; display: flex; align-items: center; }
.rating-slider-input { position: absolute; top: 0; left: 0; width: 100%; height: 100%; margin: 0; -webkit-appearance: none; appearance: none; background: transparent; cursor: pointer; z-index: 5; }
.rating-slider-input::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 16px; height: 16px; }
.slider-track { position: absolute; top: 50%; transform: translateY(-50%); width: 100%; height: 4px; background-color: var(--color-border); border-radius: 2px; }
.slider-progress { position: absolute; top: 50%; transform: translateY(-50%); height: 4px; background-color: var(--color-accent); border-radius: 2px; width: 0; }
.slider-thumb { position: absolute; top: 50%; left: 0; width: 16px; height: 16px; background-color: var(--color-accent); border-radius: 50%; border: 3px solid var(--color-bg-white); box-shadow: 0 1px 3px rgba(0,0,0,0.2); transform: translate(-50%, -50%); transition: left 0.1s ease-out, border-color 0.3s ease; z-index: 10; }

/* РЕЗУЛЬТАТЫ ПОИСКА И КАРТА */
main.results-content { position: relative; }
.results-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 30px; position: relative; z-index: 2;
}
.results-header h1 { font-size: 2rem; }
.view-switcher button { background: none; border: 1px solid var(--color-border); padding: 10px 15px; border-radius: 8px; margin-left: 10px; cursor: pointer; font-weight: 600; color: var(--color-text-primary); }
.view-switcher button.active { background-color: var(--color-accent); color: white; border-color: var(--color-accent); }
.results-grid, .no-results { transition: opacity 0.4s ease, transform 0.4s ease; }
.results-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 25px; }
.results-map { display: block; position: absolute; top: 90px; left: 0; right: 0; bottom: 0; opacity: 0; transform: scale(0.98); pointer-events: none; transition: opacity 0.4s ease, transform 0.4s ease; border-radius: var(--border-radius); overflow: hidden; }
main.view-map-active .results-map { opacity: 1; transform: scale(1); pointer-events: auto; }
main.view-map-active .results-grid, main.view-map-active .no-results { opacity: 0; pointer-events: none; }
.service-card { background: var(--color-bg-white); border-radius: var(--border-radius); border: 1px solid var(--color-border); display: flex; flex-direction: column; transition: all 0.3s ease; cursor: pointer; }
.service-card:hover {
    transform: translateY(-5px);
    border-color: var(--color-accent-light); /* Появляется тонкая рамка */
    /* Добавляем красивое оранжевое свечение к основной тени */
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1), 0 0 20px -5px var(--color-accent);
}

.service-card:hover .btn-chat {
    background-color: var(--color-accent);
    color: white;
    box-shadow: 0 4px 12px -2px var(--color-accent); /* Добавляем тень самой кнопке для объема */
}
.card-image { height: 180px; background-size: cover; background-position: center; border-radius: var(--border-radius) var(--border-radius) 0 0; position: relative; }
.card-badge { position: absolute; top: 12px; left: 12px; font-size: 0.8rem; padding: 5px 10px; border-radius: 20px; font-weight: 600; color: white; backdrop-filter: blur(5px); background: rgba(0,0,0,0.3); }
.card-badge.verified { background-color: var(--color-verified); }
.card-body { padding: 20px; flex-grow: 1; display: flex; flex-direction: column; }
.card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.card-rating i { color: #f59e0b; }
.card-title { font-size: 1.25rem; margin-bottom: 8px; color: var(--color-text-primary); }
.card-location { color: var(--color-text-secondary); margin-bottom: 15px; font-size: 0.9rem; }
.card-description { flex-grow: 1; font-size: 0.9rem; line-height: 1.5; color: var(--color-text-secondary); }
.card-footer { margin-top: 20px; display: flex; justify-content: space-between; align-items: center; border-top: 1px solid var(--color-border); padding-top: 15px; transition: border-color 0.3s ease;}
.card-price { font-size: 1.3rem; font-weight: 800; color: var(--color-text-primary); }
.card-actions { display: flex; gap: 10px; }
.btn-icon { background: none; border: 1px solid var(--color-border); width: 36px; height: 36px; border-radius: 50%; cursor: pointer; color: var(--color-text-secondary); transition: all 0.2s ease;}
.btn-icon:hover { background-color: var(--color-bg-light); color: var(--color-text-primary); }
.btn-chat { background: var(--color-accent-light); color: var(--color-accent); border: none; padding: 0 15px; height: 36px; border-radius: 8px; font-weight: 700; cursor: pointer; }

.no-results { text-align: center; padding: 60px 20px; border: 1px dashed var(--color-border); border-radius: 12px; margin-top: 20px; }
.no-results i { font-size: 2.5rem; color: var(--color-text-tertiary); margin-bottom: 20px; }
.no-results h3 { font-size: 1.5rem; margin-bottom: 10px; }
.no-results p { color: var(--color-text-secondary); max-width: 450px; margin: 0 auto; line-height: 1.6; }


/*
 *  --- ТЕМНАЯ ТЕМА ---
 */
html.dark-theme {
    --color-bg-light: #111827;
    --color-bg-white: #1F2937;
    --color-text-primary: #F9FAFB;
    --color-text-secondary: #9CA3AF;
    --color-text-tertiary: #6B7280;
    --color-border: #374151;
    --color-accent-light: rgba(249, 115, 22, 0.15);
    --shadow-soft: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.25);
}

html.dark-theme .featured-category {
    background: linear-gradient(45deg, #4A240C, #B45309);
    box-shadow: 0 10px 25px -5px rgba(249, 115, 22, 0.2);
}
html.dark-theme .stars-wrapper { color: #374151; }
html.dark-theme .category-tile .icon-wrapper { background-color: #374151; }
html.dark-theme .bottom-bar { background-color: rgba(31, 41, 55, 0.85); }

/* Стили для балуна Яндекс.Карты в темной теме */
html.dark-theme .ymaps-2-1-79-balloon__layout,
html.dark-theme .ymaps-2-1-79-balloon__content {
    background: var(--color-bg-white) !important;
}
html.dark-theme .ymaps-2-1-79-balloon__layout { border-radius: var(--border-radius) !important; box-shadow: var(--shadow-soft) !important; }
html.dark-theme .ymaps-2-1-79-balloon__content { padding: 15px !important; margin: 0 !important; }
html.dark-theme .ymaps-2-1-79-balloon__close-button { color: var(--color-text-secondary) !important; opacity: 0.7; }
html.dark-theme .ymaps-2-1-79-balloon__content h3, html.dark-theme .ymaps-2-1-79-balloon__content strong { color: var(--color-text-primary) !important; }
html.dark-theme .ymaps-2-1-79-balloon__content p { color: var(--color-text-secondary) !important; margin: 5px 0 0 !important; }
html.dark-theme .ymaps-2-1-79-balloon__tail { display: none !important; }

/*
 *  --- СТИЛИ ПЕРЕКЛЮЧАТЕЛЯ ТЕМЫ ---
 */
.theme-toggle-btn svg, .theme-switch svg {
    width: 22px; height: 22px; stroke: currentColor;
    transition: transform 0.3s ease, color 0.3s ease;
}
.theme-toggle-btn:hover svg { transform: scale(1.1) rotate(15deg); }

.sun-icon { display: block; }
.moon-icon { display: none; }
html.dark-theme .sun-icon { display: none; }
html.dark-theme .moon-icon { display: block; }

.theme-toggle-btn {
    background: none; border: none; padding: 5px; cursor: pointer; color: var(--color-text-secondary);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
}
.theme-toggle-btn:hover { color: var(--color-accent); background-color: var(--color-bg-light); }

.theme-toggle-mobile-wrapper {
    border-top: 1px solid var(--color-border); padding-top: 25px; margin-top: 25px;
    transition: border-color 0.3s ease;
}


.theme-switch { display: flex; align-items: center; gap: 12px; cursor: pointer; }
.theme-switch .switch-label-text { font-weight: 600; }
.theme-switch input[type="checkbox"] { position: absolute; opacity: 0; width: 0; height: 0; }

.switch-slider {
    position: relative; display: flex; align-items: center; justify-content: center;
    width: 52px; height: 28px; background-color: var(--color-border);
    border-radius: 14px; transition: background-color 0.3s ease;
}
.switch-slider::before {
    content: ''; position: absolute; left: 3px; width: 22px; height: 22px;
    background-color: white; border-radius: 50%;
    transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94); z-index: 1;
}
.theme-switch input:checked + .switch-slider { background-color: var(--color-accent); }
.theme-switch input:checked + .switch-slider::before { transform: translateX(24px); }

.switch-slider .sun-icon, .switch-slider .moon-icon {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 16px; height: 16px; pointer-events: none; z-index: 0;
}
.switch-slider .sun-icon { right: 7px; color: #FBBF24; }
.switch-slider .moon-icon { left: 7px; color: #a6c5f7; }

/* --- МОДАЛЬНОЕ ОКНО АВТОРИЗАЦИИ --- */
.auth-modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(17, 24, 39, 0.6); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); z-index: 3000; display: flex; align-items: center; justify-content: center; padding: 20px; opacity: 0; pointer-events: none; transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1); }
.auth-modal-overlay.is-visible { opacity: 1; pointer-events: auto; }
.auth-modal { position: relative; background-color: var(--color-bg-white); border-radius: 20px; padding: 40px; width: 100%; max-width: 440px; box-shadow: 0 20px 40px -10px rgba(0, 0, 0, 0.3); border: 1px solid var(--color-border); transform: scale(0.95); transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); overflow: hidden; }
.auth-modal-overlay.is-visible .auth-modal { transform: scale(1); }
.auth-modal-content { position: relative; width: 100%; display: flex; }
.modal-step { width: 100%; flex-shrink: 0; opacity: 1; transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease; }
.modal-step:not(.active) { opacity: 0; position: absolute; top:0; left:0; pointer-events: none; transform: translateX(30px); }
.modal-step.exit-to-left { transform: translateX(-30px); }
.modal-close-btn, .modal-back-btn { position: absolute; top: 15px; width: 32px; height: 32px; background-color: var(--color-bg-light); border: 1px solid var(--color-border); border-radius: 50%; color: var(--color-text-secondary); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 14px; transition: all 0.2s ease; z-index: 10; }
.modal-close-btn { right: 15px; }
.modal-close-btn:hover { background-color: var(--color-accent-light); color: var(--color-accent); transform: rotate(90deg); }
.modal-back-btn { left: 15px; opacity: 0; pointer-events: none; transform: scale(0.8); }
.modal-back-btn.is-visible { opacity: 1; pointer-events: auto; transform: scale(1); }
.modal-back-btn:hover { background-color: var(--color-bg-light); color: var(--color-text-primary); }
.modal-header { text-align: center; margin-bottom: 25px; }
.modal-title { font-size: 1.8rem; font-weight: 800; margin-bottom: 8px; color: var(--color-text-primary); }
.modal-subtitle { font-size: 0.95rem; color: var(--color-text-secondary); line-height: 1.5; }
.modal-actions { display: flex; flex-direction: column; gap: 12px; margin-top: 25px; margin-bottom: 20px; }
.btn-secondary { width: 100%; padding: 14px; background-color: var(--color-bg-light); color: var(--color-text-primary); border: 1px solid var(--color-border); border-radius: 8px; font-weight: 700; cursor: pointer; transition: all 0.2s ease; }
.btn-secondary:hover { border-color: var(--color-text-secondary); }
.modal-submit-btn { width: 100%; padding: 14px; font-size: 1rem; margin-top: 20px; }
.input-group { margin-bottom: 18px; }
.input-group label { display: block; font-weight: 600; font-size: 0.9rem; margin-bottom: 6px; }
.input-group input, .input-group select { width: 100%; box-sizing: border-box; padding: 12px; font-size: 1rem; background-color: var(--color-bg-light); border: 1px solid var(--color-border); border-radius: 8px; color: var(--color-text-primary); }
.input-group input:focus, .input-group select:focus { border-color: var(--color-accent); box-shadow: 0 0 0 3px var(--color-accent-light); outline: none; }
.modal-link { color: var(--color-accent); text-decoration: none; font-weight: 600; font-size: 0.9rem; display: inline-block; margin-top: 10px; }
.modal-link:hover { text-decoration: underline; }
.modal-separator { display: flex; align-items: center; text-align: center; color: var(--color-text-tertiary); margin: 25px 0; }
.modal-separator::before, .modal-separator::after { content: ''; flex: 1; border-bottom: 1px solid var(--color-border); }
.modal-separator:not(:empty)::before { margin-right: 1em; }
.modal-separator:not(:empty)::after { margin-left: 1em; }
.social-auth { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.social-btn { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px; border: 1px solid var(--color-border); border-radius: 8px; text-decoration: none; color: var(--color-text-primary); font-weight: 600; transition: all 0.2s ease; }
.social-btn:hover { border-color: var(--color-text-primary); background-color: var(--color-bg-light); }
.social-btn .fab { font-size: 1.2rem; }
.fa-google { color: #DB4437; }
.fa-telegram-plane { color: #0088cc; }
.role-selector { display: flex; flex-direction: column; gap: 15px; }
.role-option { display: flex; align-items: center; text-align: left; width: 100%; padding: 20px; border: 1px solid var(--color-border); border-radius: 12px; background-color: var(--color-bg-light); cursor: pointer; transition: all 0.2s ease; }
.role-option:hover { border-color: var(--color-accent); transform: translateY(-2px); box-shadow: 0 4px 10px -2px rgba(0,0,0,0.05); }
.role-icon { width: 48px; height: 48px; font-size: 1.5rem; border-radius: 12px; background-color: var(--color-bg-white); color: var(--color-accent); display: flex; align-items: center; justify-content: center; margin-right: 15px; flex-shrink: 0; }
.role-text strong { display: block; font-size: 1.1rem; font-weight: 700; color: var(--color-text-primary); }
.role-text span { font-size: 0.9rem; color: var(--color-text-secondary); }

/* dashboard-catalog.css */
.captcha-group .captcha-wrapper {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    background-color: var(--color-bg-light);
    padding: 5px;
    border-radius: 8px;
}
.captcha-group .captcha-image {
    border-radius: 6px;
    flex-grow: 1;
    height: 40px;
    object-fit: cover;
}
.captcha-group .btn-refresh-captcha {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-text-secondary);
    padding: 5px;
}
.captcha-group .btn-refresh-captcha:hover svg {
    transform: rotate(90deg);
    transition: transform 0.3s ease;
}
.form-errors {
    margin-top: 15px;
    padding: 10px;
    background-color: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
    border-radius: 8px;
    font-size: 0.9rem;
    display: none;
}
html.dark-theme .form-errors {
    background-color: #2b1f1f;
    color: #fca5a5;
    border-color: #4b2424;
}

.profile-menu-wrapper {
    position: relative; /* Критически важно для позиционирования дропдауна */
    display: none; /* JS будет менять на 'block' при логине */
}

/* Делаем сам блок профиля кликабельным */
.user-profile {
    cursor: pointer;
    padding: 5px;
    border-radius: 20px;
    transition: background-color 0.2s ease;
}

.user-profile:hover {
    background-color: var(--color-bg-light);
}

/* Анимация стрелочки */
.user-profile i {
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.user-profile.is-open i {
    transform: rotate(180deg);
}

/* Сам дропдаун */
.profile-dropdown {
    position: absolute;
    top: calc(100% + 10px); /* Появляется под кнопкой с отступом */
    right: 0;
    width: 240px;
    background-color: var(--color-bg-white);
    border-radius: var(--border-radius);
    border: 1px solid var(--color-border);
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
    z-index: 1010;
    padding: 8px 0;

    /* Состояние "скрыто" для анимации */
    opacity: 0;
    transform: translateY(-10px);
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

/* Состояние "видимо" */
.profile-dropdown.is-active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.profile-dropdown hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: 8px 0;
}

.dropdown-header {
    padding: 8px 16px;
}
.dropdown-header .user-name {
    display: block;
    font-weight: 700;
    color: var(--color-text-primary);
}
.dropdown-header .user-role {
    font-size: 0.8rem;
    color: var(--color-text-secondary);
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    text-decoration: none;
    color: var(--color-text-secondary);
    font-weight: 600;
    transition: all 0.2s ease;
}

.dropdown-item i {
    width: 16px;
    text-align: center;
    color: var(--color-text-tertiary);
}

.dropdown-item:hover {
    background-color: var(--color-bg-light);
    color: var(--color-text-primary);
}
.dropdown-item:hover i {
    color: var(--color-accent);
}

.dropdown-item--logout:hover {
    color: #EF4444; /* Красный цвет для опасного действия */
}
.dropdown-item--logout:hover i {
    color: #EF4444;
}

/* --- СИСТЕМА УВЕДОМЛЕНИЙ (ТОСТОВ) --- */
#notification-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 12px;
    pointer-events: none;
}
.notification-toast {
    position: relative;
    min-width: 320px;
    background-color: var(--color-bg-white);
    border-radius: var(--border-radius);
    border: 1px solid var(--color-border);
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
    padding: 16px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    pointer-events: auto;
    border-left-width: 5px;
    animation: slideIn 0.4s cubic-bezier(0.21, 1.02, 0.73, 1) forwards;
}
.notification-toast.exiting {
    animation: slideOut 0.4s ease-out forwards;
}
@keyframes slideIn { from { opacity: 0; transform: translateX(100%); } to { opacity: 1; transform: translateX(0); } }
@keyframes slideOut { from { opacity: 1; transform: translateX(0); } to { opacity: 0; transform: translateX(100%); } }
.notification-icon { font-size: 1.5rem; flex-shrink: 0; }
.notification-message { font-weight: 600; color: var(--color-text-primary); }
.notification-close { position: absolute; top: 8px; right: 8px; background: none; border: none; color: var(--color-text-tertiary); cursor: pointer; font-size: 1.2rem; opacity: 0.7; }
/* Типы */
.notification-toast.success { border-left-color: #10B981; }
.notification-toast.success .notification-icon { color: #10B981; }
.notification-toast.error { border-left-color: #EF4444; }
.notification-toast.error .notification-icon { color: #EF4444; }

.verification-code-group .code-inputs-wrapper {
    position: relative;
    display: flex;
    justify-content: center;
}

/* Визуальные ячейки */
.verification-code-group .code-boxes {
    display: flex;
    gap: 10px;
    cursor: text; /* Курсор как у текста, чтобы было понятно, что сюда можно вводить */
}

.verification-code-group .code-boxes span {
    display: block;
    width: 48px;
    height: 56px;
    border: 2px solid var(--color-border);
    border-radius: var(--border-radius);
    background-color: var(--color-bg-light);
    text-align: center;
    line-height: 52px;
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--color-text-primary);
    transition: all 0.2s ease;
}

/* Стиль для активной ячейки или ячейки с символом */
.verification-code-group .code-boxes span.active {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px var(--color-accent-light);
}

/* Стиль для уже заполненной ячейки */
.verification-code-group .code-boxes span.has-char {
    border-color: var(--color-accent);
}

/* Настоящее поле ввода, которое мы прячем, но оставляем функциональным */
.verification-code-group #verify-code-input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;

    /* Делаем его невидимым, но кликабельным */
    opacity: 0;

    /* Для отладки можно временно убрать opacity и посмотреть, где оно */
    background: transparent;
    border: none;

    /* Убираем стандартный вид текста, чтобы не мешал */
    color: transparent;
    caret-color: transparent; /* Прячем мигающий курсор */

    /* Важно для мобильных: позволяет вводить только цифры и открывает цифровую клавиатуру */
    inputmode: "numeric";
    pattern: "[0-9]*";
}

.modal-footer-links {
    margin-top: 20px;
    text-align: center;
    font-size: 0.9rem;
    color: var(--color-text-secondary);
}
.modal-footer-links a {
    color: var(--color-accent);
    font-weight: 600;
    text-decoration: none;
}
.modal-footer-links a:hover {
    text-decoration: underline;
}

@media(max-width: 480px) {
    .verification-code-group .code-boxes span {
        width: 40px;
        height: 48px;
        line-height: 44px;
        font-size: 1.5rem;
    }
}

/* dashboard-catalog.css */

/* Стили для аккордеона */
.filter-accordion {
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 1rem;
}

.filter-accordion summary {
    font-size: 1.1rem;
    font-weight: 700;
    padding: 1rem 0;
    cursor: pointer;
    list-style: none; /* Убираем стандартный маркер */
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.filter-accordion summary::-webkit-details-marker {
    display: none; /* Убираем маркер в Chrome/Safari */
}

/* Анимация стрелочки для аккордеона */
.filter-accordion summary::after {
    content: '\\f078'; /* Иконка FontAwesome "шеврон вниз" */
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    transition: transform 0.2s ease-in-out;
    font-size: 0.8em;
}

.filter-accordion[open] > summary::after {
    transform: rotate(180deg);
}

.filter-group-content {
    padding-bottom: 1rem;
}

/* Поле для поиска внутри фильтра */
.filter-search-input {
    width: 100%;
    padding: 8px 12px;
    border-radius: 6px;
    border: 1px solid var(--color-border);
    background-color: var(--color-background-secondary);
    color: var(--color-text-primary);
    margin-bottom: 10px;
    box-sizing: border-box; /* Важно для корректного расчета ширины */
}

/* Контейнер для чекбоксов с прокруткой */
.filter-options-list {
    max-height: 200px; /* Ограничиваем высоту */
    overflow-y: auto;  /* Добавляем вертикальную прокрутку */
    padding-right: 5px; /* Небольшой отступ для скроллбара */
}

/* Стилизация скроллбара (опционально, но красиво) */
.filter-options-list::-webkit-scrollbar {
    width: 6px;
}
.filter-options-list::-webkit-scrollbar-track {
    background: transparent;
}
.filter-options-list::-webkit-scrollbar-thumb {
    background-color: var(--color-border-hover);
    border-radius: 10px;
}

/* Чекбоксы внутри списка */
.filter-options-list label {
    display: block; /* Каждый чекбокс на новой строке */
    margin-bottom: 8px;
    transition: background-color 0.15s;
    padding: 4px;
    border-radius: 4px;
}
.filter-options-list label:hover {
    background-color: var(--color-background-hover);
}


/* АДАПТИВНЫЙ ДИЗАЙН */
@media (max-width: 1024px) {
    .header-logo { margin-right: 0; }
    .header-inner { gap: 15px; }
    .desktop-only, .category-selector { display: none !important; }
    .mobile-only-flex {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        margin-left: auto; /* Прижимаем к правому краю */
    }
    .main-nav { display: none; }


    .mobile-header-controls { display: flex; flex-grow: 1; gap: 10px; align-items: center; padding:10px 20px; }
    .search-bar-mobile { position: relative; flex-grow: 1; }
    .search-bar-mobile i { position: absolute; left: 15px; top: 50%; transform: translateY(-50%); color: var(--color-text-secondary); }
    .search-bar-mobile input { width: 100%; box-sizing: border-box; padding: 10px 10px 10px 40px; border-radius: 8px; border: 2px solid var(--color-border); background-color: var(--color-bg-light); font-size: 1rem; color: var(--color-text-primary); transition: background-color 0.3s ease, border-color 0.3s ease; }

    .page-wrapper { padding: 0 0 80px 0; }
    .page-wrapper .container {
        grid-template-columns: 1fr;
        padding: 0 20px; /* ВОЗВРАЩАЕМ БОКОВЫЕ ОТСТУПЫ */
    }
    .results-content {
        padding: 0;
    }
    .bottom-bar, .category-grid-mobile { display: flex; }

    .category-showcase {
        padding: 0; /* Убираем лишние отступы */
        background-color: transparent; /* Фон на родителе */
        border-bottom: none; /* Убираем границу */
    }

    .category-showcase .container {
        padding: 0;
    }
    .category-grid-mobile { overflow-x: auto; gap: 10px; padding: 0 20px; -ms-overflow-style: none; scrollbar-width: none; }
    .category-grid-mobile::-webkit-scrollbar { display: none; }
    .category-tile { flex-shrink: 0; flex-direction: row; align-items: center; gap: 8px; padding: 10px 18px; background-color: var(--color-bg-light); border: 1px solid var(--color-border); border-radius: 25px; text-decoration: none; color: var(--color-text-primary); font-weight: 600; }
    .category-tile .icon-wrapper { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background-color: var(--color-border); transition: all 0.2s ease; }
    .category-tile .icon-wrapper svg { width: 18px; height: 18px; stroke-width: 2; stroke: var(--color-text-secondary); }
    .category-tile.active { background-color: var(--color-accent); color: white; border-color: var(--color-accent); }
    .category-tile.active .icon-wrapper { background: white; }
    .category-tile.active .icon-wrapper svg { stroke: var(--color-accent); }

    .results-header { padding-top: 20px; justify-content: space-between; gap: 15px; }
    .results-header h1 { font-size: 1.5rem; }
    .results-header-controls { display: flex; align-items: center; gap: 8px; }
    .view-switcher { display: flex; gap: 8px; }
    .view-switcher button { margin-left: 0; width: 40px; height: 40px; padding: 0; font-size: 1rem; display: flex; align-items: center; justify-content: center; }
    .view-switcher button span { display: none; }
    .mobile-filter-btn { display: flex; align-items: center; justify-content: center; padding: 0; background-color: transparent; color: var(--color-text-primary); border-radius: 8px; font-weight: 700; flex-shrink: 0; width: 40px; height: 40px; border: 1px solid var(--color-border); }
    .mobile-filter-btn span { display: none; }

    .filters-panel { position: fixed; top: 0; left: 0; width: 90%; max-width: 350px; height: 100%; z-index: 2000; transform: translateX(-100%); transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1); overflow-y: auto; border-radius: 0; border-right: 1px solid var(--color-border); }
    .filters-panel.is-open { transform: translateX(0); }
    .mobile-filters-header { display: flex; justify-content: space-between; align-items: center; padding: 0 25px; margin: 0 -25px 20px -25px; height: 60px; border-bottom: 1px solid var(--color-border); transition: border-color 0.3s ease; }
    .close-filters-btn { background: none; border: none; font-size: 1.5rem; color: var(--color-text-secondary); }

    .filter-overlay { display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.5); z-index: 1999; opacity: 0; visibility: hidden; transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.4s cubic-bezier(0.4, 0, 0.2, 1); }
    .filter-overlay.is-visible { opacity: 1; visibility: visible; }

    .bottom-bar { position: fixed; bottom: 0; left: 0; width: 100%; height: 65px; background-color: rgba(255, 255, 255, 0.85); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-top: 1px solid var(--color-border); z-index: 1001; justify-content: space-around; align-items: flex-start; padding-top: 8px; transition: background-color 0.3s ease, border-color 0.3s ease; }
    .bottom-bar-item { display: flex; flex-direction: column; align-items: center; justify-content: center; text-decoration: none; color: var(--color-text-tertiary); font-size: 0.7rem; font-weight: 500; gap: 4px; height: 100%; }
    .bottom-bar-item svg { width: 24px; height: 24px; stroke: currentColor; stroke-width: 1.5; }
    .bottom-bar-item.active { color: var(--color-accent); }
    .bottom-bar-item.active svg { stroke-width: 2; }


}


@media (max-width: 768px) {
    .results-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
    .results-header { flex-direction: row; align-items: center; }
    .results-header h1 { flex-grow: 1; font-size: 1.2rem; }
    .card-image { height: 120px; }
    .service-card .card-body {
        padding: 12px;
    }
    .card-header .card-rating {
        font-size: 0.8rem; /* Уменьшаем общий размер шрифта для рейтинга */
        font-weight: 700;  /* Делаем его жирным, но компактным */
    }
    .card-header {
        margin-bottom: 6px; /* Было 10px по умолчанию, это основное исправление */
    }
    .service-card .card-footer {
        margin-top: auto;  /* Прижимаем футер к низу карточки */
        padding-top: 12px; /* Было 8px, даем чуть больше воздуха от линии */
    }
    .service-card .card-body { padding: 12px; }
    .service-card .card-title { font-size: 0.9rem; line-height: 1.2; margin-bottom: 4px; }
    .card-header .card-category { display: none; }
    .card-location { font-size: 0.8rem; margin-bottom: 8px; }
    .card-description { display: none; }
    .service-card .card-footer { padding-top: 8px; margin-top: 8px; flex-direction: column; align-items: flex-start; gap: 8px; }
    .service-card .card-price { font-size: 0.95rem; }
    .card-actions { width: 100%; justify-content: space-between; }
    .btn-chat { flex-grow: 1; text-align: center; }


    .auth-modal-overlay { padding: 0; align-items: flex-end; }
    .auth-modal { width: 100%; max-width: 100%; height: auto; max-height: 90vh; border-radius: 20px 20px 0 0; padding: 20px; padding-top: 50px; transform: translateY(100%); }
    .auth-modal-overlay.is-visible .auth-modal { transform: translateY(0); }
    .modal-close-btn { top: 12px; right: 12px; }
    .modal-back-btn { top: 12px; left: 12px; }
    .modal-title { font-size: 1.6rem; }
}
/* dashboard-catalog.css */

/* --- СТИЛИ ДЛЯ ПРОДВИГАЕМОЙ КАРТОЧКИ --- */

.service-card--promoted {
    /* Выделяем рамкой в цвет акцента */
    border: 2px solid var(--color-accent);
    /* Добавляем легкий градиентный фон, чтобы она выделялась */
    background: linear-gradient(180deg, var(--color-bg-white) 0%, var(--color-accent-light) 150%);
    box-shadow: 0 8px 25px -10px var(--color-accent);
}

.service-card--promoted:hover {
    /* Усиливаем эффект при наведении */
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 12px 30px -8px var(--color-accent);
}

/* Стили для нового значка "Реклама" */
.card-badge.promoted {
    background-color: var(--color-accent);
    color: white;
    /* Размещаем его справа, чтобы не конфликтовал с "Проверен" */
    right: 12px;
    left: auto;
}

/* Адаптация для темной темы */
html.dark-theme .service-card--promoted {
    border-color: var(--color-accent);
    background: linear-gradient(180deg, var(--color-bg-white) 0%, rgba(249, 115, 22, 0.1) 150%);
    box-shadow: 0 0 25px -5px var(--color-accent);
}

/* dashboard-catalog.css */
.listing-card .card-image {
    width: 240px; /* или 100% для мобильной версии */
    background-size: cover;
    background-position: center;

    /* 🔥 ВОТ РЕШЕНИЕ ПРОБЛЕМЫ С ПРЫЖКАМИ: */
    aspect-ratio: 16 / 10; /* Соотношение сторон, например, 16:10. */

    /* Добавляем цвет-заглушку, пока картинка грузится */
    background-color: var(--color-border);
}
.category-count {
    position: absolute;
    top: 4px;
    right: 8px;
    background-color: var(--color-primary);
    color: var(--color-text-on-primary);
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    line-height: 1;
}

/* --- НОВЫЕ СТИЛИ ДЛЯ ПРЕМИУМ БАННЕРА --- */
.promo-banner-slider {
    position: relative;
    width: 100%;
    border-radius: 20px; /* Более крупные скругления */
    overflow: hidden;
    box-shadow: 0 10px 30px -10px rgba(0,0,0,0.2);
}

.promo-slides-wrapper {
    display: flex;
    transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1); /* Более плавная анимация */
}

.promo-slide {
    position: relative;
    flex: 0 0 100%;
    min-width: 100%;
    display: block;
    color: white; /* Цвет текста по умолчанию */
    text-decoration: none;
    height: 300px; /* Фиксированная высота для десктопа */
}

.promo-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Изображение будет заполнять контейнер */
    display: block;
    transition: transform 0.6s ease;
}

/* Эффект затемнения для читаемости текста */
.promo-slide-overlay {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(90deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.3) 50%, rgba(0,0,0,0.1) 100%);
    z-index: 1;
}

/* Контент поверх картинки */
.promo-slide-content {
    position: absolute;
    top: 50%;
    left: 60px;
    transform: translateY(-50%);
    z-index: 2;
    max-width: 45%;
    opacity: 0; /* Изначально невидимый для анимации */
    transition: opacity 0.5s ease 0.3s, transform 0.5s ease 0.3s;
}

.promo-slide.is-active .promo-slide-content {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

.promo-slide-content h2 {
    font-size: 2.5rem;
    font-weight: 800;
    line-height: 1.2;
    text-shadow: 0 2px 5px rgba(0,0,0,0.5);
    margin: 0 0 10px 0;
}

.promo-slide-content p {
    font-size: 1rem;
    margin-bottom: 25px;
    text-shadow: 0 1px 3px rgba(0,0,0,0.5);
    opacity: 0.9;
}

.btn-promo {
    background-color: var(--color-accent);
    color: white;
    border: none;
    padding: 12px 24px;
    border-radius: 8px;
    font-weight: 700;
    cursor: pointer;
    font-size: 1rem;
    transition: all 0.2s ease;
    box-shadow: 0 4px 15px -5px var(--color-accent);
}

.btn-promo:hover {
    background-color: var(--color-accent-hover);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px -5px var(--color-accent);
}

/* Эффекты при наведении на слайд */
.promo-slide:hover img {
    transform: scale(1.05);
}
.service-card .card-image {
    position: relative;
    height: 150px; /* Эту строку можно будет заменить */
    background-size: cover;
    background-position: center;
    border-radius: 8px 8px 0 0;

    /* 🔥 ГЛАВНОЕ ДОБАВЛЕНИЕ: ЗАДАЕМ СООТНОШЕНИЕ СТОРОН */
    aspect-ratio: 16 / 10; /* Например, 16:10. Подберите значение, которое вам нравится. */
    background-color: var(--skeleton-bg, #374151); /* Цвет фона-заглушки */
}
/* Стили кнопок и точек (остаются почти без изменений, но проверены) */
.promo-banner-slider .slider-btn { position: absolute; top: 50%; transform: translateY(-50%); background-color: rgba(31, 41, 55, 0.5); color: white; border: none; width: 44px; height: 44px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; z-index: 10; transition: all 0.2s ease; backdrop-filter: blur(4px); }
.promo-banner-slider .slider-btn:hover { background-color: rgba(17, 24, 39, 0.8); transform: translateY(-50%) scale(1.1); }
.promo-banner-slider .slider-btn.prev { left: 20px; }
.promo-banner-slider .slider-btn.next { right: 20px; }
.slider-dots { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); display: flex; gap: 10px; z-index: 10; }
.slider-dots button { width: 10px; height: 10px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.5); background-color: transparent; padding: 0; cursor: pointer; transition: all 0.3s ease; }
.slider-dots button.active { background-color: white; border-color: white; transform: scale(1.2); }

/* Адаптивность для мобильных */
@media (max-width: 768px) {
    .promo-slide { height: 200px; }
    .promo-slide-content { left: 20px; right: 20px; max-width: 80%; }
    .promo-slide-content h2 { font-size: 1.5rem; }
    .promo-slide-content p { display: none; } /* Скрываем подзаголовок на маленьких экранах */
    .btn-promo { padding: 8px 16px; font-size: 0.9rem; }
}

.nav-link-chat {
    position: relative;
    display: inline-flex; /* или flex, в зависимости от вашей верстки */
    align-items: center;
}

/* Сам кружок-уведомление */
.notification-badge {
    position: absolute;
    top: -2px;      /* Положение сверху */
    right: -2px;     /* Положение справа */
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    border-radius: 9px;
    background-color: #ff4d4f; /* Яркий красный цвет */
    color: white;
    font-size: 11px;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    border: 1px solid var(--header-bg-color, #fff); /* Рамка в цвет фона, чтобы выглядело аккуратно */
    display: none; /* Изначально скрыт */
    transition: transform 0.2s ease;
}

/* Анимация появления */
.notification-badge.show {
    display: block;
    animation: bounce-in 0.3s ease;
}

@keyframes bounce-in {
    0% { transform: scale(0.5); opacity: 0; }
    70% { transform: scale(1.1); opacity: 1; }
    100% { transform: scale(1); }
}
