/**
 * Карточная версия стилей сайдбара
 * Элементы внутри профиля становятся отдельными карточками с бордером
 */

/* ===== САЙДБАР СОБЫТИЙ: catalog-nav стиль ===== */

/* Контейнер лоадаута — та же визуальная система что sidebar-event-info-block.
   overflow не hidden: sidebar-profile-header сам клипирует фото через
   собственный overflow:hidden + border-radius.
   Скругление и контекст углов — как у .gc-panel (variables.css --gc-corner-*). */
.sidebar-profile-block {
    display: flex;
    flex-direction: column;
    --gc-corner-outer: var(--radius-lg);
    --gc-corner-nest: 0px;
    background: var(--bg-content-main);
    border-radius: var(--gc-corner-outer);
    border: 1px solid var(--ui-border);
    padding: var(--spacing-xs);
}

/* Разделитель между хедером и лоадаут-списком */
.sidebar-profile-divider {
    display: none; /* замена разделителя на gap через margin-top */
}

.sidebar-profile-block .sidebar-loadout-list {
    margin-top: var(--spacing-xs);
}

/*
 * Лоадаут: слот sm (32×32, lists.css) — не трогаем --gc-list-media-size.
 * Крупнее глиф SVG = только меньше --gc-list-media-mask-inset.
 */
.sidebar-profile-block .sidebar-loadout-list .gc-list-media-icon:has(.gc-list-media-mask),
.split-right .gc-panel .gc-interactive-row > .gc-list-media-icon:has(.gc-list-media-mask) {
    --gc-list-media-mask-inset: var(--spacing-2xs);
}

/* Айтемы в loadout-блоке: как --radius-md-lg (10px), в линию с оболочкой блока */
.sidebar-profile-block .gc-interactive-row {
    border-radius: var(--radius-md-lg);
}

/* Карточка оружия с тегом класса: те же размеры что у других айтемов блока */
.sidebar-profile-block .event-participant-card {
    border-radius: var(--radius-md-lg);
}

/*
 * Чип сайдбара / списков: единая база + модификаторы.
 * По умолчанию — акцент (класс оружия, заметная льгота в превью записи).
 * --benefit — длинный текст льготы (переносы, ширина по контенту).
 * --muted — спокойный тон для плотных списков (лента канала).
 */
.sidebar-weapon-class-badge {
    border-radius: 4px var(--radius-md-lg) var(--radius-md-lg) var(--radius-md-lg);
    text-transform: none;
    letter-spacing: 0;
    font-size: var(--font-size-xs);
    font-weight: 500;
    padding: var(--spacing-3xs) var(--spacing-sm);
    background: var(--bg-accent-viola);
    color: #fff;
    border: none;
}

.sidebar-weapon-class-badge--muted {
    background: var(--bg-content-secondary);
    color: var(--font-secondary);
    border: 1px solid var(--border-tertiary);
}

.sidebar-weapon-class-badge--benefit {
    box-sizing: border-box;
    width: fit-content;
    max-width: 100%;
    min-height: 0;
    white-space: normal;
    justify-content: flex-start;
    text-align: left;
    line-height: 1.35;
}

/* gc-list-shell-interactive (для транспорта, оставшийся gc-list-* паттерн) */
.sidebar-profile-block .gc-list-shell-interactive {
    border-radius: var(--radius-md-lg);
}

.sidebar-profile-block .gc-list-shell-interactive:hover {
    background: var(--bg-content-secondary);
}

/* Убираем divider-линии у оставшихся gc-list-item */
.sidebar-profile-block .gc-list-item {
    --gc-list-divider-color: transparent;
}

/* Профиль-хедер: padding совпадает с event-info-community (16px со всех сторон) */
.sidebar-profile-block > a.catalog-nav-item:first-child {
    padding: var(--spacing-md);
}

/* ── Баннер профиля с аватаркой ────────────────────────────────────────────── */

.sidebar-profile-header {
    position: relative;
    overflow: hidden;
    height: var(--sidebar-profile-header-height);
    display: block;
    background: var(--bg-content-secondary);
    text-decoration: none;
    padding: 0;
    color: inherit;
    cursor: pointer;
    transition: none;
    border-radius: var(--radius-md-lg);
}

/* Аватарка — чёткий полноблочный фон, центрирован по обеим осям */
.sidebar-profile-header-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    pointer-events: none;
}

/* Градиент снизу вверх для читаемости текста поверх фото */
.sidebar-profile-header-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.1) 60%, transparent 100%);
    pointer-events: none;
    opacity: 0.5;
    z-index: 0;
}

/* Контент: прижат к низу баннера */
.sidebar-profile-header-content {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: flex-end;
    padding: var(--spacing-md);
}

/* Нижняя строка: текст + шеврон, шеврон центрирован по высоте текстового блока */
.sidebar-profile-header-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.sidebar-profile-header-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4xs);
    min-width: 0;
}

.sidebar-profile-header-name {
    color: #fff;
    font-weight: 600;
    font-size: var(--font-size-mdl);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
}

.sidebar-profile-header-role {
    color: rgba(255, 255, 255, 0.6);
    font-size: var(--font-size-xs);
    font-weight: 500;
    line-height: 1.3;
}

.sidebar-profile-header-chevron {
    color: rgba(255, 255, 255, 0.5);
    font-size: var(--font-size-sm);
    flex-shrink: 0;
    transition: color var(--transition-fast);
}

/* Hover */
.sidebar-profile-header--link:hover .sidebar-profile-header-overlay {
    background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.2) 60%, transparent 100%);
}

.sidebar-profile-header--link:hover .sidebar-profile-header-chevron {
    color: rgba(255, 255, 255, 0.9);
}

/* Профиль-хэдер использует catalog-nav-item → никаких переопределений не нужно.
   sidebar-profile-divider — тонкий разделитель между профилем и action-items */
.sidebar-profile-block .sidebar-profile-divider {
    height: 1px;
    background: var(--ui-border);
    margin: 0;
}

/* ===== Loadout rail on UI Kit lists ===== */

.sidebar-loadout-list {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.sidebar-transport-section {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.sidebar-loadout-group {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-width: 0;
}

.sidebar-loadout-group + .sidebar-loadout-group {
    border-top: none;
}

.sidebar-loadout-action {
    appearance: none;
    -webkit-appearance: none;
    width: 100%;
    border: none;
    border-radius: 0;
    background: transparent;
    color: inherit;
    margin: 0;
    padding: 0;
    font: inherit;
    text-align: left;
}

.sidebar-loadout-action .gc-list-actions {
    margin-left: var(--spacing-xs);
}

.sidebar-loadout-shell > .gc-list-item .gc-list-actions {
    margin-left: var(--spacing-xs);
}

.sidebar-loadout-chevron {
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
    flex-shrink: 0;
}

.sidebar-loadout-meta-stack {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4xs);
}

.sidebar-loadout-shell {
    width: 100%;
    min-width: 0;
}

.sidebar-loadout-shell-action {
    cursor: pointer;
}

.sidebar-loadout-shell-action .gc-list-item {
    cursor: inherit;
}

.sidebar-loadout-shell .gc-list-shell-extra-list {
    gap: 0;
}

/* Сайдбар лоадаута: вертикальная плотность mdl, горизонталь остаётся md (под компенсацию flush-шелла) */
.sidebar-loadout-list,
.sidebar-loadout-group--transport {
    --gc-list-padding-y: var(--spacing-mdl);
}

/* Общие переопределения для items сайдбара (без dividers) */
.sidebar-loadout-list .gc-list-item,
.gc-list-shell.gc-list-shell-flush.gc-list-shell-passengers > .gc-list-item,
.sidebar-loadout-crew-list .gc-list-item,
.sidebar-loadout-group--transport .gc-list-item {
    --gc-list-item-min-height: 56px;
    --gc-list-item-gap: var(--spacing-mdl);
    --gc-list-divider-color: transparent;
}

.sidebar-loadout-crew-list .gc-list-item,
.sidebar-passenger-row {
    gap: var(--spacing-mdl);
}

.sidebar-loadout-group--transport .sidebar-loadout-subgroup {
    border-top: none;
}

.sidebar-passenger-row .gc-list-actions {
    margin-left: var(--spacing-xs);
}

/* Action-items: padding увеличен до var(--spacing-md) = 16px для
   соответствия profile-header, border-top как разделитель строк. */
.sidebar-profile-block .sidebar-card-action {
    border-top: 1px solid var(--ui-border);
    padding: var(--spacing-md) var(--spacing-md);
}

/* Первый action-item не нужен border-top, если есть sidebar-profile-divider */
.sidebar-profile-block .sidebar-profile-divider + .sidebar-card-action {
    border-top: none;
}

/* Rich-вариант кнопки: multi-line контент классов оружия */
.sidebar-card-action--rich {
    align-items: flex-start;
    height: auto;
    min-height: 0;
}

.sidebar-card-action--rich .sidebar-section-content {
    width: 100%;
}

/* Хедер категории — block-контекст, чтобы inline-дети не растягивались */
.sidebar-card-action--rich .sidebar-class-category-header {
    display: block;
    line-height: 1.6;
}

/* Баджик типа в block-контексте — inline, строго по тексту */
.sidebar-card-action--rich .sidebar-type-badge {
    display: inline;
    background: var(--bg-content-secondary);
    padding: 1px 5px;
    color: var(--font-primary);
    font-size: var(--font-size-xs);
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border-radius: var(--radius-md);
    white-space: nowrap;
    border: 1px solid var(--ui-border);
    margin-right: var(--spacing-xs);
    vertical-align: middle;
}

.sidebar-card-action--rich .sidebar-class-type-name {
    display: inline;
    margin: 0;
    vertical-align: middle;
}

.sidebar-card-action--rich .sidebar-class-type-icon {
    display: inline;
    height: 14px;
    width: auto;
    margin-left: var(--spacing-xs);
    vertical-align: middle;
    opacity: 0.7;
}

/* Универсальный rail/list блок для сайдбарных секций вне loadout.
   Использует тот же визуальный паттерн, что и event sidebar. */
.sidebar-list-block {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.sidebar-list-block .sidebar-card-action {
    border-top: 1px solid var(--ui-border);
    padding: var(--spacing-md);
    width: 100%;
    min-height: 0;
    text-decoration: none;
    color: inherit;
    box-sizing: border-box;
}

.sidebar-list-block .sidebar-card-action:first-child {
    border-top: none;
}

.sidebar-list-block .sidebar-card-action:hover {
    background: var(--bg-hover);
}

.sidebar-list-block .sidebar-section-content {
    width: 100%;
    min-width: 0;
}

.sidebar-list-block .sidebar-transport-person {
    width: 100%;
    min-width: 0;
    align-items: center;
}

.sidebar-list-block .catalog-nav-content {
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 36px;
}

.sidebar-list-block .sidebar-list-title {
    margin: 0;
    color: var(--font-primary);
    font-size: var(--font-size-sm);
    font-weight: 500;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sidebar-list-block .sidebar-list-meta {
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    width: fit-content;
    max-width: 100%;
    gap: var(--spacing-xs);
    color: var(--font-secondary);
    font-size: var(--font-size-xs);
    line-height: 1.4;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
}

/* Для гостей (без профиля) */
.sidebar-profile-block-guest {
    padding: 0;
}

/* ===== ДЕТАЛЬНЫЙ ЛОАДАУТ В КОНТЕНТЕ ===== */

/* Профиль крупный, по центру */
.loadout-profile-header {
    text-align: center;
    margin-bottom: var(--spacing-md);
}

.loadout-profile-avatar {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: var(--spacing-md);
}

.loadout-profile-name {
    font-size: var(--font-size-xxl);
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--spacing-xs);
}

.loadout-profile-role {
    font-size: var(--font-size-md);
    color: var(--text-secondary);
    margin: 0 0 var(--spacing-md) 0;
}

.loadout-profile-banner {
    margin-top: var(--spacing-sm);
    text-align: left;
}

.loadout-profile-banner strong i {
    color: var(--accent-link);
    font-size: 18px;
    margin-right: 4px;
}

/* Отступ между личным транспортом и доступными участниками */
.loadout-transport-personal + .loadout-transport-available {
    margin-top: var(--spacing-md);
}

.loadout-profile-description {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    max-width: 500px;
    margin: 0 auto;
    line-height: 1.5;
}

/* Контент лоадаута */
.loadout-content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

/* Заголовок секции с иконкой */
.loadout-section-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    font-size: var(--font-size-mdl);
    font-weight: 600;
    color: var(--text-primary);
}

/* Уменьшаем отступ, когда за заголовком идет описание */
.loadout-section-title:has(+ .loadout-section-description) {
    margin-bottom: var(--spacing-2xs);
}

.loadout-section-title i {
    font-size: var(--font-size-2xl);
    color: var(--primary-color);
    flex-shrink: 0;
}

/* Описание секции */
.loadout-section-description {
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
    line-height: 1.5;
    margin: 0 0 var(--spacing-sm) 0;
    max-width: 600px;
}

/* Пустое состояние */
.loadout-empty-state {
    text-align: center;
    padding-top: 0;
}

.loadout-empty-icon {
    margin-bottom: var(--spacing-md);
}

.loadout-empty-icon i {
    font-size: 64px;
    color: var(--text-tertiary);
    opacity: 0.4;
}

.loadout-empty-text {
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
    margin: 0 auto;
    line-height: 1.5;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

/* Информационный баннер */
.gc-info-banner {
    display: flex;
    align-items: center;
    gap: var(--spacing-mdl);
    padding: var(--spacing-md);
    border-radius: var(--radius-lg);
    border: 1px solid;
    background: var(--bg-content-main);
}

.gc-info-banner-primary {
    border-color: rgba(var(--accent-link-rgb), 0.2);
    background: rgba(var(--accent-link-rgb), 0.05);
}

.gc-info-banner-warning {
    border-color: rgba(255, 165, 0, 0.2);
    background: rgba(255, 165, 0, 0.05);
}

.gc-info-banner > i {
    font-size: 20px;
    color: var(--accent-link);
    flex-shrink: 0;
}

.gc-info-banner-warning > i {
    color: #ff9500;
}

.gc-info-banner-content {
    flex: 1;
    min-width: 0;
}

.gc-info-banner-content strong {
    display: block;
    color: var(--font-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
}

.gc-info-banner-content p {
    color: var(--font-secondary);
    font-size: var(--font-size-sm);
    line-height: 1.4;
}

/* Разделитель списка */
.gc-list-divider {
    display: flex;
    align-items: center;
    padding: var(--spacing-md) 0;
    margin: var(--spacing-sm) 0;
}

.gc-list-divider::before,
.gc-list-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--ui-border);
}

.gc-list-divider-text {
    padding: 0 var(--spacing-md);
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ===== КАРТОЧКИ ТРАНСПОРТА ===== */

/* ===== КАРТОЧКИ ОРУЖИЯ (МАРКЕТПЛЕЙС СТИЛЬ) ===== */

/* Grid-контейнер для оружия */
.loadout-weapon-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

/* Карточка оружия (вертикальная) */
.loadout-weapon-card {
    display: flex;
    flex-direction: column;
    background: transparent;
    border: none;
    overflow: visible;
    transition: all var(--transition-fast);
    cursor: pointer;
    gap: var(--spacing-sm);
}

/* Если оружие одно - отображаем на всю ширину */
.loadout-weapon-card:only-child {
    grid-column: 1 / -1;
}

/* Контейнер с фото оружия */
.loadout-weapon-photo-container {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9; /* Все карточки 16:9 как в кроппере */
    background: var(--bg-content-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    transition: all var(--transition-fast);
}

.loadout-weapon-card:hover .loadout-weapon-photo-container {
    box-shadow: var(--shadow-md);
}

/* Невидимые зоны для переключения фото (как на Avito) */
.loadout-weapon-photo-zones {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    z-index: 2;
}

.loadout-weapon-photo-zone {
    flex: 1;
    height: 100%;
    cursor: pointer;
    /* Для отладки раскомментируйте: */
    /* border: 1px dashed rgba(255, 0, 0, 0.3); */
}

/* Главное фото оружия */
.loadout-weapon-photo-main {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: transform var(--transition-fast);
    padding: 0;
    position: relative;
    z-index: 1;
    display: block;
}

/* Когда оружие одно - фото определяет высоту контейнера */
.loadout-weapon-card:only-child .loadout-weapon-photo-main {
    height: auto;
    max-height: none;
}

/* SVG иконки типов оружия как заглушки */
.loadout-weapon-photo-main.is-icon-placeholder {
    object-fit: contain;
    opacity: 0.25;
    width: 50%;
    height: 50%;
    transition: filter var(--transition-base), opacity var(--transition-base), transform var(--transition-fast);
}

/* Инверсия SVG иконок в светлой теме */
[data-theme="light"] .loadout-weapon-photo-main.is-icon-placeholder {
    filter: invert(1) grayscale(100%);
}

/* В темной теме - только grayscale */
[data-theme="dark"] .loadout-weapon-photo-main.is-icon-placeholder {
    filter: grayscale(100%);
}

/* Пистолеты меньше */
.loadout-weapon-photo-main.is-icon-placeholder.icon-pistol {
    width: 30%;
    height: 30%;
}

.loadout-weapon-card:hover .loadout-weapon-photo-main.is-icon-placeholder {
    opacity: 0.35;
}

/* Счетчик фотографий (как на Avito) */
.loadout-weapon-photo-counter {
    position: absolute;
    top: var(--spacing-mdl);
    right: var(--spacing-mdl);
    background: rgba(0, 0, 0, 0.75);
    color: #fff;
    padding: var(--spacing-xs) var(--spacing-3sm);
    border-radius: var(--radius-md);
    font-size: 11px;
    font-weight: 600;
    backdrop-filter: blur(var(--spacing-sm));
    z-index: 3;
    pointer-events: none;
    box-shadow: var(--shadow-md);
    letter-spacing: 0.03em;
}

/* Контейнер миниатюр */
.loadout-weapon-thumbnails {
    position: absolute;
    bottom: var(--spacing-mdl);
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: var(--spacing-sm);
    padding: var(--spacing-xs) var(--spacing-sm);
    z-index: 3;
    pointer-events: none;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(var(--spacing-sm));
    border-radius: var(--radius-lg);
}

/* Миниатюра */
.loadout-weapon-thumbnail {
    width: 6px;
    height: 6px;
    object-fit: cover;
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.4);
    cursor: pointer;
    transition: all var(--transition-base) ease;
    flex-shrink: 0; /* Не сжимаются */
}

.loadout-weapon-thumbnail:hover {
    background: rgba(255, 255, 255, 0.7);
}

.loadout-weapon-thumbnail.active {
    background: #fff;
    box-shadow: 0 0 var(--spacing-sm) rgba(255, 255, 255, 0.5);
}

/* Информация об оружии */
.loadout-weapon-info {
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
    text-align: center;
}

.loadout-weapon-name {
    font-size: var(--font-size-md);
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.4;
    transition: color var(--transition-fast);
}

.loadout-weapon-card:hover .loadout-weapon-name {
    color: var(--primary-color);
}

/* Калибр как простой текст */
.loadout-weapon-caliber {
    font-size: var(--font-size-xs);
    color: var(--text-secondary);
    margin: 0;
    line-height: 1.4;
}

/* Класс оружия */
.loadout-weapon-class {
    margin-top: var(--spacing-xs);
    display: flex;
    justify-content: center;
}

.loadout-weapon-class .gc-badge {
    font-size: var(--font-size-sm);
}

/* Адаптив для grid оружия */
@media (max-width: 768px) {
    .loadout-weapon-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }
}

@media (max-width: 480px) {
    .loadout-weapon-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }
    
    .loadout-weapon-photo-container {
        aspect-ratio: 16 / 9;
        touch-action: pan-x; /* Только горизонтальный свайп */
        user-select: none;
        background: var(--bg-content-secondary);
    }
    
    /* Отключаем зоны на мобильных - мешают свайпу */
    .loadout-weapon-photo-zones {
        display: none;
    }
    
    .loadout-weapon-photo-main {
        padding: 0;
        object-fit: contain;
        width: 100%;
        height: 100%;
        max-height: none;
    }
    
    /* Заглушка на мобильных */
    .loadout-weapon-photo-main.is-icon-placeholder {
        object-fit: contain;
        width: 50%;
        height: 50%;
    }
    
    .loadout-weapon-photo-main.is-icon-placeholder.icon-pistol {
        width: 30%;
        height: 30%;
    }
    
    /* Счетчик и точки на вертикальных фото */
    .loadout-weapon-photo-counter {
        top: 12px;
        right: 12px;
        font-size: 12px;
        padding: 6px 10px;
    }
    
    .loadout-weapon-thumbnails {
        bottom: 12px;
        gap: 8px;
    }
    
    .loadout-weapon-thumbnail {
        width: 8px;
        height: 8px;
    }
    
    .loadout-weapon-class .gc-badge {
        font-size: var(--font-size-xs);
    }
    
    /* Классы на мобильных */
    .loadout-class-type-card {
        padding: var(--spacing-sm);
    }
    
    .loadout-class-type-name {
        font-size: var(--font-size-sm);
    }
    
    .loadout-class-type-icon {
        height: 14px;
    }
    
    .loadout-class-unavailable {
        font-size: 10px;
    }
    
    .loadout-class-unavailable i {
        font-size: 12px;
    }
    
    .loadout-class-tags {
        gap: 4px;
    }
    
    .loadout-class-tags .gc-badge,
    .loadout-class-tags [class*="gc-badge-"] {
        font-size: var(--font-size-xs);
    }
}

/* ===== КЛАССЫ ОРУЖИЯ (КАРТОЧКИ-СПИСОК) ===== */

/* Список типов оружия */
.loadout-class-types-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

/* Карточка типа оружия */
.loadout-class-type-card {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--bg-content-main);
    border: 1px solid var(--ui-border);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
    cursor: pointer;
}

.loadout-class-type-card:hover {
    background: var(--bg-content-secondary);
    border-color: var(--border-secondary);
}

.loadout-class-type-card.disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* Заголовок типа */
.loadout-class-type-header {
    display: flex;
    align-items: center;
    gap: 6px;
}

.loadout-class-type-name {
    font-size: var(--font-size-md);
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    transition: color var(--transition-fast);
    display: flex;
    align-items: center;
    gap: 6px;
}

.loadout-class-type-icon {
    height: 20px;
    width: auto;
    flex-shrink: 0;
    opacity: 0.3;
    transition: opacity var(--transition-fast);
}

[data-theme="light"] .loadout-class-type-icon {
    filter: invert(1);
}

[data-theme="dark"] .loadout-class-type-icon {
    filter: none;
}

.loadout-class-type-card:hover .loadout-class-type-icon {
    opacity: 1;
}

.loadout-class-type-card:hover .loadout-class-type-name {
    color: var(--primary-color);
}

/* Индикатор недоступности */
.loadout-class-unavailable {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    color: var(--text-tertiary);
    margin-left: auto;
}

.loadout-class-unavailable i {
    font-size: 14px;
}

/* Контейнер для badge'ей классов (используем стандартные badge из UI-kit) */
.loadout-class-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

/* Увеличенный размер текста для баджей классов */
.loadout-class-tags .gc-badge,
.loadout-class-tags [class*="gc-badge-"] {
    font-size: var(--font-size-sm);
}

/* ВЫБРАННЫЕ классы - инвертируемый цвет (темно-серый в light, почти белый в dark) */
.loadout-class-tags .gc-badge-primary {
    background: var(--badge-selected-bg) !important;
    color: var(--badge-selected-color) !important;
}

/* То же самое для секции оружия */
.loadout-weapon-class .gc-badge-primary {
    background: var(--badge-selected-bg) !important;
    color: var(--badge-selected-color) !important;
}

/* Элементы идут вплотную — отступами управляет border-top разделителя */
.sidebar-profile-block > *:not(.sidebar-profile-header):not(.sidebar-loadout-title):not(:last-child) {
    margin-bottom: 0;
}

/* Карточки контента (класс, оружие) - добавляем бордер и фон */
.sidebar-profile-block .sidebar-profile-card {
    background: var(--bg-content-main);
    border: 1px solid var(--ui-border);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
    padding: var(--spacing-md);
}

.sidebar-profile-block .sidebar-profile-card:hover {
    background: var(--bg-content-secondary);
    border-color: var(--border-secondary);
    box-shadow: var(--shadow-sm);
}

/* Хедер строки оружия: flex-row, иконка не сжимается, имя обрезается */
.sidebar-card-action--rich .sidebar-weapon-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    min-width: 0;
    line-height: normal;
}

.sidebar-card-action--rich .sidebar-weapon-name {
    flex: 0 1 auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
    margin: 0;
}

/* Алиас для названия оружия (вместо gc-list-title gc-list-title-bold gc-list-title-sm) */
.sidebar-weapon-title {
    font-size: var(--font-size-mdl);
    font-weight: 500;
    color: var(--font-primary);
    margin: 0;
}

/* Ограничиваем текст одной строкой с многоточием */
.sidebar-profile-block .sidebar-profile-card .sidebar-class-name,
.sidebar-profile-block .sidebar-profile-card .sidebar-class-type-name,
.sidebar-profile-block .sidebar-profile-card .gc-list-title,
.sidebar-profile-block .sidebar-profile-card .sidebar-weapon-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Контейнеры также должны иметь ограничение */
.sidebar-profile-block .sidebar-profile-card .sidebar-section-content,
.sidebar-profile-block .sidebar-profile-card .d-flex {
    min-width: 0;
}

/* loadout-content сохраняет карточный стиль */
.loadout-content .sidebar-card-action {
    border: 1px solid var(--ui-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.loadout-content .sidebar-card-action:hover {
    border-color: var(--border-secondary);
    box-shadow: var(--shadow-sm);
}

/* Транспортные карточки - НЕТ padding у карточки */
.sidebar-profile-block .sidebar-profile-card.sidebar-transport-card {
    padding: 0;
    overflow: hidden;
}

/* Padding у контента внутри транспорта */
.sidebar-profile-block .sidebar-transport-card .sidebar-profile-content {
    padding: var(--spacing-md);
}

/* Ограничиваем текст в транспортной карточке одной строкой с многоточием */
.sidebar-profile-block .sidebar-transport-card .sidebar-vehicle-name,
.sidebar-profile-block .sidebar-transport-card .sidebar-address-text,
.sidebar-profile-block .sidebar-transport-card .sidebar-person-name,
.sidebar-profile-block .sidebar-transport-card .sidebar-person-address,
.sidebar-profile-block .sidebar-transport-card .gc-list-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Контейнеры для правильного расчета ширины многоточия */
.sidebar-profile-block .sidebar-transport-card .sidebar-person-info {
    min-width: 0;
    flex: 1;
}

/* Строка с именем авто + бадж — flex-row, бадж по тексту */
/* Блок авто: название+адрес слева, номер справа по верхней границе */
.sidebar-vehicle-summary {
    display: flex;
    align-items: center;
    gap: var(--spacing-3sm);
    min-width: 0;
}

.sidebar-vehicle-summary-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4xs);
}

.sidebar-vehicle-summary-info .sidebar-class-type-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sidebar-vehicle-summary .gc-badge-car-number {
    display: inline-flex;
    width: max-content;
    flex-shrink: 0;
    align-self: center;
}

/* Строка человека / оружия / класса — единый профильный ряд */
.sidebar-transport-person {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* Фон темнеет при ховере на интерактивный элемент */
.catalog-nav-item:hover .sidebar-icon-box,
.catalog-nav-item:hover .sidebar-weapon-icon {
    background: var(--bg-accent);
}

/* Текст в кнопках-плейсхолдерах — чуть крупнее для баланса с 40px иконкой */
.sidebar-card-action:not(.sidebar-card-action--rich) span {
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
}

/* Hover для транспортной карточки - тень и изменение бордера */
.sidebar-profile-block .sidebar-transport-card:hover {
    border-color: var(--border-secondary);
}

/* Убираем padding у внутреннего контента в обычных карточках */
.sidebar-profile-block .sidebar-profile-card:not(.sidebar-transport-card) .sidebar-profile-content,
.sidebar-profile-block .sidebar-profile-card:not(.sidebar-transport-card) .sidebar-section-content,
.sidebar-profile-block .sidebar-profile-card:not(.sidebar-transport-card) .sidebar-classes-content {
    padding: 0;
}

.sidebar-profile-block .sidebar-profile-card .sidebar-profile-content:hover {
    background: transparent;
}

/* Кнопка "Добавить транспорт" внутри карточки */
.sidebar-profile-block .sidebar-transport-card .sidebar-profile-action {
    border-radius: 0;
    border: none;
}

/* ===== УПРАВЛЕНИЕ ПАССАЖИРАМИ (водитель) ===== */

/* ── Визуальная группировка: транспорт + пассажиры + кнопка добавления ── */

/* Транспортная кнопка водителя — нет нижней границы, нет нижнего скругления */
.sidebar-profile-block .sidebar-transport-card + .sidebar-passengers-list,
.sidebar-profile-block .sidebar-transport-card + .sidebar-passengers-list + .sidebar-transport-add-passenger {
    border-top: none;
}

/* Список пассажиров — без внешних отступов, вплотную к соседям */
.sidebar-passengers-list {
    width: 100%;
    padding: 0;
    display: flex;
    flex-direction: column;
}

/* Кнопка "Добавить пассажира" без разделителя */
.sidebar-transport-add-passenger {
    border-top: none !important;
    color: var(--font-secondary);
}

/* Строка пассажира — паддинг как у catalog-nav-item */
.sidebar-passengers-list .sidebar-transport-person {
    align-items: center;
    padding: var(--spacing-2sm) var(--spacing-md);
    border-radius: 0;
    transition: background var(--transition-fast);
}
.sidebar-passengers-list .sidebar-transport-person:hover {
    background: var(--bg-hover);
}

/* Маленькие аватарки и текст в списке пассажиров */
.sidebar-passengers-list .sidebar-transport-person .catalog-nav-avatar,
.sidebar-passengers-list .sidebar-transport-person .catalog-nav-avatar-placeholder {
    width: 36px;
    height: 36px;
}
.sidebar-passengers-list .sidebar-transport-person .catalog-nav-avatar-placeholder {
    font-size: var(--font-size-xs);
}
.sidebar-passengers-list .sidebar-transport-person .catalog-nav-title {
    font-size: var(--font-size-sm);
}
.sidebar-passengers-list .sidebar-transport-person .catalog-nav-subtitle {
    font-size: var(--font-size-xs);
    color: var(--font-secondary);
    font-weight: 500;
}

/* Аватарка водителя — полный размер */
.sidebar-transport-card .sidebar-transport-person .catalog-nav-avatar,
.sidebar-transport-card .sidebar-transport-person .catalog-nav-avatar-placeholder {
    width: 36px;
    height: 36px;
}
.sidebar-transport-card .sidebar-transport-person .catalog-nav-avatar-placeholder {
    font-size: var(--font-size-sm);
}

/* Позиционирование кнопки удаления пассажира — стили из gc-btn gc-btn-text-danger gc-btn-icon-sm */
/* 28px — совпадает с gc-dropdown-toggle-icon--sm и другими action buttons */
.sidebar-passenger-remove {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    min-width: 28px;
    min-height: 28px;
    padding: 0;
    background: var(--bg-content-main);
    border-color: var(--ui-border);
    color: var(--font-secondary);
}

.sidebar-passenger-remove:hover {
    background: var(--bg-content-secondary);
    border-color: var(--ui-border);
    color: var(--font-primary);
}


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

@media (max-width: 576px) {
    /* Компактный профиль на мобильных */
    .loadout-profile-avatar {
        width: 80px;
        height: 80px;
    }
    
    .loadout-profile-name {
        font-size: var(--font-size-lg);
    }
    
    .loadout-profile-description {
        font-size: var(--font-size-xs);
    }
    
    /* Баннер в профиле: кнопка на отдельной строке */
    .loadout-profile-banner {
        flex-direction: column;
        align-items: stretch;
    }
    
    .loadout-profile-banner .gc-btn {
        margin-top: var(--spacing-sm);
        width: 100%;
    }
}
