/* =========================================
   UI Kit - Catalog Layout
   ========================================= 
   
   ПРИМЕЧАНИЕ: Основные определения контейнеров и layout перенесены в layout.css
   Здесь остались только специфичные стили каталога
   ========================================= */

/* Шапка каталога */
.catalog-header {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    background: var(--bg-content-main);
    border: 1px solid var(--ui-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-mdl);
    margin-top: 0;
    position: relative;
    z-index: 10;
}

/* Убираем margin-bottom у catalog-header внутри catalog-main, т.к. родитель управляет gap */
.catalog-main > .catalog-header {
    margin-bottom: 0;
}

/* Прозрачный заголовок-страницы — без фона и скругления, просто текст над контентом */
.catalog-header-plain {
    background: transparent !important;
    border-radius: 0 !important;
    padding-left: var(--spacing-xs) !important;
    padding-right: var(--spacing-xs) !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.catalog-header-plain .catalog-header-title {
    color: var(--font-secondary);
}

.catalog-header-top {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
}

/* «Назад» + заголовок слева (как /events: h5 + действие справа) */
.catalog-header .catalog-header-top .gc-back-link.gc-back-link--sm {
    height: var(--gc-btn-sm-min-height);
    min-height: var(--gc-btn-sm-min-height);
}

.catalog-header .catalog-header-top .gc-back-link.gc-back-link--sm i {
    font-size: var(--font-size-mdl);
}

/* Паттерн gc-subheader--spread внутри .catalog-header: одна полоса с бордером у родителя, без второй «карточки» */
.catalog-header > .gc-subheader.catalog-header-subheader-row {
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
}

/* «Назад» и «Создать» в шапке каталога: одна высота с .gc-btn-sm, иконка как у компактного back-link */
.catalog-header > .gc-subheader.catalog-header-subheader-row .gc-back-link.gc-back-link--sm {
    height: var(--gc-btn-sm-min-height);
    min-height: var(--gc-btn-sm-min-height);
}

.catalog-header > .gc-subheader.catalog-header-subheader-row .gc-back-link.gc-back-link--sm i {
    font-size: var(--font-size-mdl);
}

/* Строка с заголовком и бейджами */
.catalog-header-title-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs); /* 4px между заголовком и бейджами */
}

/* «Назад» + h5 в одной строке слева от кнопки (add-stage) */
.catalog-header-title-row.catalog-header-title-row--lead {
    gap: var(--spacing-sm);
    flex: 1 1 auto;
    min-width: 0;
}

.catalog-header-title-row.catalog-header-title-row--lead .catalog-header-title {
    min-width: 0;
}

.catalog-header-search {
    position: relative;
    z-index: 1; /* Выше остальных элементов header для корректного отображения dropdown */
}

.catalog-header-search .gc-search-input-wrapper {
    margin-bottom: 0;
}

/* Строка: поиск + сортировка */
.catalog-header-toolbar {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

.catalog-header-toolbar .catalog-header-search {
    flex: 1 1 12rem;
    min-width: 0;
}

.catalog-header-toolbar .catalog-sort-dropdown-wrap {
    flex: 0 0 auto;
    display: flex;
    align-items: stretch;
}

/* Сортировка в toolbar: только иконка; внешняя капа = .gc-search-input-wrapper (spacing-1-5xl, border-box) */
.catalog-header-toolbar .catalog-sort-dropdown--icon-only.catalog-sort-dropdown .catalog-sort-dropdown__toggle--icon-square,
.catalog-header-toolbar .catalog-sort-dropdown--icon-only .catalog-sort-dropdown__toggle--icon-square {
    width: var(--spacing-1-5xl);
    height: var(--spacing-1-5xl);
    min-width: var(--spacing-1-5xl);
    max-width: var(--spacing-1-5xl);
    min-height: var(--spacing-1-5xl);
    padding: 0;
    justify-content: center;
    gap: 0;
    box-sizing: border-box;
    border: 1px solid var(--ui-border);
    border-radius: var(--gc-btn-radius);
    background: var(--bg-content-main);
}

.catalog-header-toolbar .catalog-sort-dropdown--icon-only .catalog-sort-dropdown__toggle--icon-square::after {
    display: none !important;
    content: none !important;
}

.catalog-header-toolbar .catalog-sort-dropdown--icon-only .catalog-sort-dropdown__toggle-lead i {
    font-size: var(--font-size-mdl);
}

.catalog-header-toolbar .catalog-sort-dropdown--icon-only .catalog-sort-dropdown__toggle--icon-square:hover {
    background: var(--bg-hover);
}

.catalog-header-toolbar .catalog-sort-dropdown--icon-only .catalog-sort-dropdown__toggle--icon-square:focus-visible {
    outline: none;
    border-color: var(--accent-link);
    box-shadow: 0 0 0 2px var(--ui-focus-ring);
}

/* Выпадающий список сортировки */
.catalog-sort-dropdown .catalog-sort-dropdown__toggle {
    max-width: 100%;
    min-width: min(100%, 14rem);
    justify-content: flex-start;
    gap: var(--spacing-sm);
}

.catalog-sort-dropdown__toggle-lead {
    display: inline-flex;
    align-items: center;
    opacity: 0.85;
    flex-shrink: 0;
}

.catalog-sort-dropdown__toggle-lead i {
    font-size: var(--font-size-lg);
}

.catalog-sort-dropdown__toggle-label {
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: left;
}

.catalog-sort-dropdown__menu {
    min-width: min(100vw - 2rem, 18rem);
}

.catalog-sort-dropdown__item.catalog-sort-dropdown__item--current {
    background: var(--bg-content-secondary);
    color: var(--accent-link);
}

/* Мобильная сортировка под шапкой: для /stages перенесено в .gc-nav-tabs-row (navbar.css) */
.catalog-mobile-sort {
    padding: var(--spacing-sm) var(--spacing-mdl) var(--spacing-mdl);
    border-bottom: 1px solid var(--ui-border);
}

.catalog-mobile-sort .catalog-sort-dropdown {
    width: 100%;
}

.catalog-mobile-sort .catalog-sort-dropdown__toggle {
    width: 100%;
    min-width: 0;
    justify-content: space-between;
}

.catalog-header-filters {
    position: relative;
}

.catalog-header-filters .gc-tabs-container {
    margin-bottom: 0;
}

/* Фикс для Bootstrap .d-lg-block, который переопределяет display: flex */
@media (min-width: 992px) {
    .catalog-header.d-lg-block {
        display: flex !important;
        flex-direction: column;
    }
}

@media (max-width: 575px) {
    .catalog-header {
        padding: var(--spacing-mdl);
    }
}

/* =========================================
   Catalog Navigation (Sidebar)
   ========================================= */

/* Специальный стиль для сайдбара профиля с разделенными секциями */
.profile-sidebar-sections {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

@media (min-width: 992px) {
    .profile-sidebar-sections {
        background: transparent !important;
        padding: 0 !important;
    }
}

    .profile-sidebar-sections .catalog-nav {
        overflow: hidden;
    }

/*
 * Ритм как у .gc-tabs (tabs.css): фон var(--ui-rail-bg), инсет 3xs, внутренний радиус у пунктов.
 * --catalog-nav-inset = --gc-tabs-inset; divider/form/addon — bleed через отрицательный margin-inline.
 * --catalog-nav-stack-gap — шаг между пунктами и секциями (прямые дети .catalog-nav и .catalog-nav-group).
 */
.catalog-nav {
    --catalog-nav-inset: var(--spacing-3xs);
    --catalog-nav-stack-gap: var(--spacing-2xs);
    --gc-tabs-r-outer: var(--radius-lg);
    --gc-tabs-r-inner: max(0px, calc(var(--gc-tabs-r-outer) - var(--catalog-nav-inset)));
    display: flex;
    flex-direction: column;
    align-items: stretch;
    padding: var(--catalog-nav-inset);
    gap: var(--catalog-nav-stack-gap);
    margin: 0;
    background-color: var(--ui-rail-bg);
    border: 1px solid var(--ui-border);
    border-radius: var(--gc-tabs-r-outer);
    overflow: hidden;
}

.catalog-nav-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-3sm);
    padding-block: var(--spacing-2sm);
    padding-inline: var(--spacing-sm);
    color: var(--font-primary);
    text-decoration: none;
    border-radius: var(--radius-md-lg);
    border: 1px solid transparent;
    background: transparent;
    box-shadow: none;
    font-size: var(--font-size-sm);
    font-weight: 500;
    font-family: inherit;
    line-height: inherit;
    transition: background var(--transition-fast) var(--ease-in-out),
        color var(--transition-fast) var(--ease-in-out),
        border-color var(--transition-fast) var(--ease-in-out),
        box-shadow var(--transition-fast) var(--ease-in-out);
    cursor: pointer;
}

.catalog-nav-item:hover:not(.active) {
    background: var(--ui-surface-3);
    color: var(--font-primary);
    border-color: transparent;
}

.catalog-nav-item.active {
    background: var(--ui-surface-1);
    color: var(--font-primary);
    border: 1px solid transparent;
    box-shadow: var(--shadow-sm);
}

/* Без отдельного hover у выбранного пункта */
.catalog-nav-item.active:hover {
    background: var(--ui-surface-1);
    color: var(--font-primary);
    border-color: transparent;
    box-shadow: var(--shadow-sm);
}

/* Кнопка как пункт навигации (фильтры и т.п.) */
button.catalog-nav-item {
    align-self: stretch;
    width: auto;
    max-width: 100%;
    text-align: left;
    background: transparent;
    font-family: inherit;
}

/* Иконка Phosphor: колонка + кегль — только токены (источник правды здесь, не sidebar-nav.css) */
.catalog-nav-item i {
    flex-shrink: 0;
    width: 1.25rem;
    min-width: 1.25rem;
    text-align: center;
    font-size: var(--font-size-mdl);
    line-height: 1;
}

/* Подпись пункта; бейджи/счётчики — не растягиваем как основной span */
.catalog-nav-item > span:not(.badge):not(.nav-badge):not(.gc-badge-car-number):not(.gc-status-indicator):not(.gc-badge):not([class*="gc-badge-"]) {
    flex: 1;
    min-width: 0;
}

.catalog-nav-item .badge {
    flex-shrink: 0;
    flex-grow: 0;
}

/* Одна колонка; вертикальный шаг как у прямых детей .catalog-nav */
.catalog-nav-group {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--catalog-nav-stack-gap, var(--spacing-2xs));
    min-width: 0;
}

/* Стек пунктов catalog-nav вне rail (панель, модалка): тот же шаг, без фона .catalog-nav */
.catalog-nav-stack,
.gc-panel-content.catalog-nav-stack {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xs);
    min-width: 0;
}

/* Как .gc-panel-content--list .gc-list-group-header — padding-sm внутри инсета .catalog-nav (--catalog-nav-inset) */
.catalog-nav-group-title {
    font-size: var(--font-size-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--font-secondary);
    padding: var(--spacing-sm) var(--spacing-sm) var(--spacing-xs) var(--spacing-sm);
}

/* Заголовок секции в основной колонке (напр. «Прошедшие сезоны»): без боковых инсетов; вертикальный ритм даёт gap у .catalog-main */
.catalog-main > .catalog-nav-group-title {
    padding-inline: 0;
    padding-block: 0;
    margin-block: 0;
    margin-inline: 0;
    text-align: center;
    font-size: var(--font-size-2xs);
    letter-spacing: 0.05em;
}

.catalog-nav-divider {
    height: 1px;
    background: var(--ui-border);
    margin-inline: calc(-1 * var(--catalog-nav-inset));
    margin-block: 0;
    flex-shrink: 0;
}

/* Под разделителем: краткая сводка + действия (каталог эпиков и т.п.) */
.catalog-nav-addon {
    margin-inline: calc(-1 * var(--catalog-nav-inset));
    padding: 0 var(--spacing-mdl);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.catalog-nav-item-disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.catalog-nav-item-disabled:hover {
    background: transparent;
    color: var(--font-primary);
    border-color: transparent;
    box-shadow: none;
}

/* Счётчик-pill в пункте каталога: только выравнивание (размеры — badges.css) */
.catalog-nav-item .gc-badge-counter {
    margin-left: auto;
    flex-shrink: 0;
}

/* Счетчики в навигации (muted). Не трогать .gc-badge-counter — единый UI в badges.css */
.catalog-nav-item .gc-badge:not(.gc-badge-counter) {
    margin-left: auto;
    font-size: var(--font-size-xs);
    flex: none;
    width: fit-content;
    background: var(--bg-accent);
    color: var(--font-primary);
    border-color: var(--ui-border);
}

/* Акцент без счётчика-pill (редко) */
.catalog-nav-item .gc-badge.gc-badge-primary:not(.gc-badge-counter) {
    background: var(--accent-link);
    color: #fff;
    border-color: var(--accent-link);
}

/* Контент с аватаркой и текстом в catalog-nav-item (для сообществ) */
.catalog-nav-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.catalog-nav-avatar-placeholder {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--ui-surface-1);
    border: 1px solid var(--ui-border);
    color: var(--font-secondary);
    font-size: var(--font-size-sm);
    font-weight: 600;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-sizing: border-box;
}

.catalog-nav-avatar-placeholder i {
    font-size: var(--font-size-lg);
    color: var(--font-secondary);
}

.catalog-nav-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4xs);
}

.catalog-nav-title {
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--font-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.catalog-nav-subtitle {
    font-size: var(--font-size-xs);
    color: var(--font-secondary);
}

/* =========================================
   Catalog Filters (в сайдбаре)
   ========================================= */

/* Форма на всю ширину карточки навигации; поля — как раньше от края chrome */
.catalog-nav > form {
    margin-inline: calc(-1 * var(--catalog-nav-inset));
    padding: 0 var(--spacing-mdl);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* Группа фильтров */
.catalog-filter-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.catalog-filter-title {
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--font-secondary);
}

/* Упрощенные чекбоксы для фильтров */
.catalog-filter-group .gc-checkbox-container {
    border: 1px solid var(--ui-border);
    background: transparent;
}

.catalog-filter-group .gc-checkbox-wrapper:hover .gc-checkbox-container {
    border-color: var(--accent-link);
    box-shadow: none;
}

.catalog-filter-actions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.catalog-filter-actions .gc-btn {
    width: 100%;
    justify-content: center;
}

/* =========================================
   Exercise Page - Специфичные стили
   (Layout используется из layout-utilities.css)
   ========================================= */

/* Кнопка "Назад" над заголовком */
.exercise-back-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
    text-decoration: none;
    font-weight: 500;
    transition: color var(--transition-fast);
}

.exercise-back-link:hover {
    color: var(--font-primary);
}

.exercise-back-link .ph {
    font-size: var(--font-size-md);
}

/* Расширенный sidebar для страницы упражнения */
@media (min-width: 992px) {
    .catalog-sidebar-wide {
        width: 360px;
        /* Убираем лишние стили родителя для этой страницы */
        background: transparent !important;
        padding: 0 !important;
    }
}

@media (min-width: 1600px) {
    .catalog-sidebar-wide {
        width: 400px;
    }
}

/* Блок-кнопка добавления брифинга в sidebar */
.gc-card-action {
    display: block;
    text-decoration: none;
    transition: all var(--transition-fast);
}

.gc-card-action:hover {
    background: var(--bg-hover);
    border-color: var(--accent-link);
}

.gc-card-action-disabled {
    cursor: default;
    pointer-events: none;
    background: var(--bg-content-secondary);
    border-color: var(--ui-border);
    box-shadow: none;
    opacity: 0.9;
}

.gc-card-action-disabled:hover {
    background: var(--bg-content-secondary);
    border-color: var(--ui-border);
}

.gc-card-action-disabled .gc-card-body {
    background: var(--bg-content-secondary);
}

.gc-card-action-disabled .ph {
    color: var(--font-tertiary) !important;
    opacity: 0.8;
}

.gc-card-action-disabled .gc-card-action-title {
    color: var(--font-secondary) !important;
}

.gc-card-action .ph {
    display: block;
    font-size: 32px !important;
    margin-bottom: var(--spacing-sm) !important;
}

.gc-card-action-title {
    font-size: var(--font-size-md);
    font-weight: 500;
    color: var(--font-primary);
    margin-bottom: var(--spacing-2xs) !important;
}

.gc-card-action-desc {
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
}

/* Список участников - убираем фон, используем только внутренние секции */
.exercise-participants {
    min-width: 0;
    max-width: 100%;
}

/* Секции упражнения (скводы, участники без сквода) */
.exercise-section {
    background: var(--bg-content-main);
    border-radius: var(--radius-lg);
    padding: var(--spacing-mdl);
    margin-bottom: var(--spacing-md);
}

.exercise-section-title {
    font-size: var(--font-size-md);
    font-weight: 600;
    color: var(--font-primary);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

/* Адаптивность для мобильных */
@media (max-width: 576px) {
    .exercise-section {
        padding: var(--spacing-md);
        margin-bottom: var(--spacing-sm);
        border-radius: var(--radius-lg);
    }
    
    .exercise-section-title {
        font-size: var(--font-size-md);
        margin-bottom: var(--spacing-md);
        flex-wrap: wrap;
    }
}

/* =========================================
   Страница упражнения /exercise/{id}
   ========================================= */

.exercise-show-page.catalog-layout .catalog-main.catalog-main--content {
    gap: var(--spacing-mdl);
}

/* =========================================
   Dropdown - Опасные действия (общие стили)
   ========================================= */
.gc-dropdown-item-danger {
    color: var(--danger) !important;
}

.gc-dropdown-item-danger:hover {
    background: var(--danger) !important;
    color: white !important;
}
