/**
 * Cards - карточки контента
 * Универсальные контейнеры для группировки связанного контента
 */

/* ===================================
   Базовая карточка
   =================================== */

.gc-card {
    /* Контекст концентричных углов для вложенных блоков и медиа (см. variables.css --gc-corner-*) */
    --gc-corner-outer: var(--radius-lg);
    --gc-corner-nest: 0px;
    background: var(--bg-content-main);
    border: 1px solid var(--ui-border);
    border-radius: var(--gc-corner-outer);
    transition: background-color var(--transition-fast) var(--ease-in-out),
                border-color     var(--transition-fast) var(--ease-in-out);
    width: 100%;
    display: flex;
    flex-direction: column;
}

/* overflow:hidden только для карточек с медиа (фото обрезается по border-radius) */
.gc-card-media {
    overflow: hidden;
}

/* Модификатор: карточка без границы */
.gc-card-borderless {
    border: none;
}

/* Hover эффект для карточек-ссылок */
a.gc-card {
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}

a.gc-card:hover:not(.gc-card-activity-event) {
    background: var(--bg-content-secondary);
    border-color: var(--border-tertiary);
}

/* Модификатор: интерактивная карточка с hover эффектом */
.gc-card-interactive {
    cursor: pointer;
    transition: all var(--transition-base);
}

.gc-card-interactive:hover {
    background: var(--bg-content-secondary);
    border-color: var(--border-tertiary);
}

/* ===================================
   Структура карточки
   =================================== */

.gc-card-header {
    padding: var(--spacing-md);
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

/* Если после хедера нет контента — добавляем паддинг снизу */
.gc-card-header:last-child {
    padding-bottom: var(--spacing-md);
}

/* Если в header есть прямая кнопка или блок actions — строка: title слева, action справа */
.gc-card-header:has(> .gc-btn),
.gc-card-header:has(> .gc-panel-actions) {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
}

/* Группировка Title + Subtitle */
.gc-card-header-content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs); /* Маленький gap между title и subtitle */
}

/* Title и Subtitle внутри gc-card-header */
.gc-card-header .gc-card-title {
    padding: 0;
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.gc-card-title-badge {
    font-weight: 400;
}

.gc-card-header .gc-card-subtitle {
    padding: 0;
    margin: 0 !important;
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
    line-height: 1.5;
}

/* Title и Subtitle НАПРЯМУЮ в gc-card (без header) - deprecated, но поддержка для обратной совместимости */
.gc-card > .gc-card-title:not(.gc-card-header .gc-card-title) {
    padding: var(--spacing-lg) var(--spacing-lg) 0;
    margin: 0 0 var(--spacing-sm) 0 !important;
}

.gc-card > .gc-card-subtitle:not(.gc-card-header .gc-card-subtitle) {
    padding: 0 var(--spacing-lg) var(--spacing-md);
    margin: 0 !important;
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
    line-height: 1.5;
}

/* Компактная карточка - уменьшенные отступы */
.gc-card-compact .gc-card-title {
    padding: var(--spacing-md) var(--spacing-md) 0;
    margin: 0 0 var(--spacing-xs) 0 !important;
}

.gc-card-compact .gc-card-subtitle {
    padding: 0 var(--spacing-md) var(--spacing-sm);
    font-size: var(--font-size-sm);
}

.gc-card-compact .gc-card-body {
    padding: var(--spacing-md);
}

.gc-card-compact .gc-card-footer {
    padding: var(--spacing-sm) var(--spacing-md);
}

.gc-card-body {
    /* Совпадает с горизонтальным padding — для gc-list-*-flush bleed в lists.css */
    --gc-content-bleed: var(--spacing-md);
    padding: var(--spacing-md);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* Заголовок внутри gc-card-body */
.gc-card-body-title {
    margin: 0; /* Отступами управляет gap родителя */
}

/* Модификатор для текстового контента (описания, статьи) */
.gc-card-body--text {
    display: block;
    gap: 0;
}

/* Список в теле карточки — зона --list (padding/gap): styles.css */
.gc-card-body--list {
    --gc-content-bleed: var(--gc-list-zone-padding);
}

/* У края экрана (часто без бокового padding страницы) — чуть больше «воздуха» по горизонтали */
@media (max-width: 767.98px) {
    .gc-card-body--list {
        --gc-content-bleed: var(--gc-list-row-padding);
        padding: var(--gc-list-zone-padding) var(--gc-list-row-padding);
    }
}

.gc-card-footer {
    padding: var(--spacing-md);
    padding-top: 0;
    background: transparent;
    display: flex;
    flex-direction: column;
}



/* Текстовые элементы внутри карточки */
.gc-card p:last-child,
.gc-card-body p:last-child {
    margin-bottom: 0;
}

/* Для карточек без header - отступ между title и body */
.gc-card-title + .gc-card-body,
.gc-card-subtitle + .gc-card-body {
    padding-top: 0;
}

/* ===================================
   Варианты карточек
   =================================== */

/* Модификатор .gc-card-borderless определен выше (строка 22) */

.gc-card-borderless .gc-card-header {
    border-bottom: none;
}

/* Карточка с акцентной обводкой (без теней — как у остальных интерактивных карточек) */
.gc-card-shadow {
    border: 1px solid var(--ui-border);
    box-shadow: none;
}

.gc-card-shadow:hover {
    background: var(--bg-content-secondary);
    border-color: var(--border-tertiary);
    box-shadow: none;
}

/* Плоская карточка */
.gc-card-flat {
    background: var(--bg-content-secondary);
    border: none;
    box-shadow: none;
}

/* Карточка без фона — только бордер и скругление */
.gc-card-ghost {
    background: transparent;
}


@media (max-width: 768px) {
    .gc-card-ghost {
        /* border-left: none;
        border-right: none; */
    }
}

/* ===================================
   Карточка с изображением
   =================================== */

.gc-card-img-top {
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--gc-corner-outer) var(--gc-corner-outer) 0 0;
}

.gc-card-img-overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    padding: var(--spacing-lg);
    background: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.7));
    color: white;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

/* ===================================
   Горизонтальная карточка
   =================================== */

.gc-card-horizontal {
    display: flex;
    flex-direction: row;
}

.gc-card-horizontal .gc-card-img-top {
    width: 200px;
    height: 100%;
    object-fit: cover;
    border-radius: var(--gc-corner-outer) 0 0 var(--gc-corner-outer);
}

.gc-card-horizontal .gc-card-body {
    flex: 1;
}

/* ===================================
   Кликабельная карточка
   =================================== */

.gc-card-clickable {
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}

.gc-card-clickable:hover {
    background: var(--bg-content-secondary);
    border-color: var(--border-tertiary);
}

.gc-card-clickable:active {
    background: var(--bg-accent);
}

/* ===================================
   Размеры карточек
   =================================== */

.gc-card-sm .gc-card-body {
    padding: var(--spacing-md);
}

.gc-card-sm .gc-card-header,
.gc-card-sm .gc-card-footer {
    padding: var(--spacing-sm) var(--spacing-md);
}

.gc-card-lg .gc-card-body {
    --gc-content-bleed: var(--spacing-xl);
    padding: var(--spacing-xl);
}

.gc-card-lg .gc-card-header,
.gc-card-lg .gc-card-footer {
    padding: var(--spacing-lg) var(--spacing-xl);
}

/* ===================================
   Card Grid - сетка карточек
   =================================== */

.gc-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); /* Адаптивный grid */
    gap: var(--spacing-sm);
    width: 100%;
    min-width: 0; /* Предотвращает overflow в flex-родителе */
}

/* Weapon-карточки: 3 колонки на десктопе; ниже lg — одна колонка. Gap — см. «Адаптивность». */
.gc-cards-grid-weapons {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
}

/* Сетка брифингов: 3 колонки на десктопе; ниже lg — одна колонка. Gap: lg → md → sm — см. «Адаптивность». */
.gc-cards-grid-briefings {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.stages-index-sentinel {
    height: 1px;
}

.gc-cards-grid-briefings > .gc-card-briefing,
.gc-cards-grid-briefings > .gc-briefing-pick-wrap {
    height: 100%;
}

.gc-cards-grid-briefings > .gc-briefing-pick-wrap {
    min-height: 0;
    display: flex;
    flex-direction: column;
}

/* Выбор брифинга для упражнения: клик по карточке — превью в модале; «Добавить» — отдельная форма (см. legacy mini_stage_card) */
.gc-briefing-pick-wrap > .gc-card.gc-card-briefing.gc-card-briefing--pick-preview {
    width: 100%;
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

/*
 * Ссылка-обёртка в сетке /weapons: раньше здесь был display:contents на всех .weapon-card-link —
 * это ломало стабильность вложенной полосы статуса + overlap в части браузеров.
 * Растягиваем <a> на ячейку грида через flex (дочерний .weapon-card height:100%).
 */
.gc-cards-grid-weapons > a.weapon-card-link,
.gc-cards-grid-weapons > div.weapon-card-link.weapon-card-link--static {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
    min-width: 0;
    text-decoration: none;
    color: inherit;
}

.gc-cards-grid.gc-cards-grid-2 {
    grid-template-columns: repeat(2, 1fr) !important;
}

/* Если в grid-2 только один элемент - на всю ширину */
.gc-cards-grid.gc-cards-grid-2 > *:only-child {
    grid-column: 1 / -1;
}

.gc-cards-grid.gc-cards-grid-3 {
    grid-template-columns: repeat(3, 1fr) !important;
}

.gc-cards-grid.gc-cards-grid-4 {
    grid-template-columns: repeat(4, 1fr) !important;
}

/* ===================================
   Epic Card (карточка эпика)
   =================================== */

.gc-epic-card-cover {
    display: flex;
    flex-direction: column;
    padding: 0 !important;
    overflow: hidden;
    position: relative;
    aspect-ratio: 16/9;
}

/* Блюренный фон */
.gc-epic-card-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    filter: blur(20px);
    transform: scale(1.1);
    z-index: 0;
}

.gc-epic-card-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: transform var(--transition-base);
    z-index: 1;
}

.gc-epic-card-cover:hover .gc-epic-card-image {
    transform: scale(1.05);
}

.gc-epic-card-gradient {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.4) 40%, transparent 100%);
    transition: opacity var(--transition-base);
    z-index: 2;
}

.gc-epic-card-cover:hover .gc-epic-card-gradient {
    opacity: 0.9;
}

.gc-epic-card-content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--spacing-md);
    color: white;
    z-index: 3;
}

.gc-epic-card-meta {
    font-size: var(--font-size-sm);
    opacity: 0.9;
    margin-bottom: var(--spacing-2xs);
}

.gc-epic-card-title {
    font-size: var(--font-size-md);
    font-weight: 600;
}

/* Эпик без обложки */
.gc-epic-card-simple {
    display: flex;
    flex-direction: column;
    aspect-ratio: 16/9;
    padding: 0 !important;
    overflow: hidden;
    position: relative;
    background: linear-gradient(
        155deg,
        color-mix(in srgb, var(--bg-accent-viola) 24%, var(--bg-content-main)) 0%,
        var(--bg-content-secondary) 52%,
        var(--bg-content-main) 100%
    );
}

.gc-epic-card-simple .gc-epic-card-content {
    color: var(--font-primary);
}

/* ===================================
   Event Card (карточка события)
   =================================== */

.gc-event-card {
    min-height: 100px;
    text-decoration: none;
    color: inherit;
}

/* ===================================
   Activity Feed Cards (карточки ленты активности)
   =================================== */

/* Activity Post Card - основная карточка поста
   Используется как обертка для постов в Activity Feed.
   Стили карточки минимальны, так как это контейнер для контента поста. */
.gc-card-activity-post {
    /* Нулевое скругление карточки — сбрасываем контекст для медиа/вложений (см. --gc-corner-*) */
    --gc-corner-outer: 0px;
    --gc-corner-nest: 0px;
    border: none;
    box-shadow: none;
    padding: 0;
    border-radius: 0;
}

.gc-card-activity-post:hover {
    border: none;
    box-shadow: none;
    transform: none;
}

/* Activity Event Card - вложенная карточка события
   Используется для отображения события внутри Activity Post.
   Горизонтальная структура с иконкой слева и информацией справа. */
.gc-card-activity-event {
    background: transparent;
    border: 1px solid var(--ui-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-sm);
    display: flex;
    flex-direction: row;
    gap: 12px;
    transition: all var(--transition-fast);
    cursor: pointer;
    text-decoration: none;
    color: inherit;
    box-shadow: none;
}

.gc-card-activity-event:hover,
.gc-card-activity-event:focus-visible {
    background: var(--bg-content-secondary);
    border-color: var(--border-tertiary);
    transform: none;
    box-shadow: none;
}

/* Адаптивность для Activity Event Card */
@media (max-width: 768px) {
    .gc-card-activity-event {
        padding: var(--spacing-sm);
        gap: var(--spacing-3sm);
    }
}

/* Ряд «дата · время» + цена — всегда одна линия; узкий блок обрезает длинную дату или ценник */
.gc-card-activity-event .activity-event-meta-row {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-sm);
    min-width: 0;
    width: 100%;
}

.gc-card-activity-event .activity-event-meta-row > .activity-event-meta:not(.activity-event-meta--accent) {
    flex: 1 1 0;
    min-width: 0;
}

.gc-card-activity-event .activity-event-meta-row .activity-event-meta--accent {
    flex: 0 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Дата (крупно) - БЕЗ margin-top, НО с margin-bottom */
.gc-event-card h5 {
    margin: 0 0 var(--spacing-sm) 0 !important;
    padding: 0 !important;
}

/* Время (мелко, серое) */
.gc-event-card .text-muted.small {
    margin: 0 0 var(--spacing-sm) 0 !important;
    padding: 0 !important;
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
    line-height: 1.4;
}

/* Контейнер для названия и цены внизу */
.gc-event-card .event-grid-bottom {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

/* Название события (truncate) */
.gc-event-card .text-truncate {
    margin: 0 !important;
    color: var(--font-secondary);
    font-size: var(--font-size-sm);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Цена */
.gc-event-card .text-primary {
    margin: 0 !important;
    color: var(--accent-link) !important;
    font-weight: 700;
    font-size: var(--font-size-md);
}

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

@media (max-width: 992px) {
    /* Оружие и брифинги: ниже lg — одна колонка */
    .gc-cards-grid-weapons {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }

    .gc-cards-grid-briefings {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }

    .gc-cards-grid-4 {
        grid-template-columns: repeat(2, 1fr);
    }

    .gc-cards-grid-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .gc-card-horizontal {
        flex-direction: column;
    }
    
    .gc-card-horizontal .gc-card-img-top {
        width: 100%;
        height: 200px;
        border-radius: var(--gc-corner-outer) var(--gc-corner-outer) 0 0;
    }
    
    .gc-cards-grid-weapons {
        gap: var(--spacing-md);
    }

    .gc-cards-grid-briefings {
        gap: var(--spacing-sm);
    }

    .gc-cards-grid-2,
    .gc-cards-grid-3,
    .gc-cards-grid-4 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 576px) {
    .gc-card-body {
        padding: var(--spacing-md);
    }
    
    .gc-card-header {
        padding: var(--spacing-md);
        padding-bottom: 0;
    }
    
    .gc-card-footer {
        padding: var(--spacing-md);
    }
}

/* ===================================
   Briefing Cards (Карточки брифингов)
   =================================== */

.gc-card-briefing {
    display: flex;
    flex-direction: column;
    cursor: pointer;
    overflow: hidden;
}

/* На адаптиве без боковых линий только если сетка лежит прямо в .catalog-main (каталог /stages).
   Внутри .gc-panel (профиль /profile/stages) — полная рамка карточки, визуально согласована с панелью. */
@media (max-width: 991.98px) {
    .catalog-main > .gc-cards-grid.gc-cards-grid-briefings .gc-card.gc-card-briefing {
        /* border-left: none;
        border-right: none; */
    }
}

a.gc-card.gc-card-briefing:hover,
div.gc-card.gc-card-briefing.gc-card-briefing--preview-trigger:hover,
div.gc-card.gc-card-briefing.gc-card-briefing--pick-preview:hover {
    box-shadow: none;
    cursor: pointer;
}

/* Контейнер изображения с соотношением 16:9 */
.gc-briefing-img-container {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    flex-shrink: 0;
    background-color: var(--bg-main);
    transition: transform var(--transition-base);
}

/* Скругление вне карточек */
.catalog-main > .gc-briefing-img-container,
.split-form-section-content .gc-briefing-img-container {
    border-radius: var(--radius-lg);
}


/* Обложка профиля — пропорция 3:1 вместо 16:9 */
.gc-cover-profile {
    aspect-ratio: 3 / 1;
}

/* Фиксированная высота медиаблока (без aspect-ratio): карточки с полосой подписи снизу */
.gc-briefing-img-container.gc-briefing-img-container--fixed-height {
    aspect-ratio: auto;
    height: var(--gc-briefing-fixed-height, 13rem);
}

/* Низ градиента = --media-caption-strip-bg (стык с .gc-media-caption-bar; в light — тёмная плашка). Градиент поверх чёткого фото (см. z-index ниже). */
.gc-briefing-img-container.gc-briefing-img-container--gradient-bottom .gc-briefing-img-wrapper {
    z-index: 1;
}

.gc-briefing-img-container.gc-briefing-img-container--gradient-bottom .gc-briefing-img-overlay {
    z-index: 2;
    /* Fallback: к transparent интерполяция через чёрный даёт «грязь» */
    background: linear-gradient(
        to top,
        var(--media-caption-strip-bg) 0%,
        transparent 50%
    );
    background: linear-gradient(
        to top,
        var(--media-caption-strip-bg) 0%,
        rgb(from var(--media-caption-strip-bg) r g b / 0) 50%
    );
}

.gc-briefing-img-container.gc-briefing-img-container--gradient-bottom .gc-briefing-img-blur {
    z-index: 0;
}

/*
 * Полоса подписи под медиа (заголовок + действия справа). Фон/текст — --media-caption-strip-* (см. variables.css).
 * Используется с .gc-briefing-img-container--fixed-height и .gc-panel--flush.
 */
.gc-media-caption-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--media-caption-strip-bg);
    color: var(--media-caption-strip-fg);
}

.gc-media-caption-bar__titles {
    min-width: 0;
}

.gc-media-caption-bar__title {
    margin: 0;
    font-size: var(--font-size-mdl);
    font-weight: 600;
    line-height: 1.5;
    color: inherit;
}

.gc-media-caption-bar__meta {
    margin: 0;
    font-size: var(--font-size-caption);
    font-weight: 400;
    line-height: 1.38;
    color: inherit;
    opacity: var(--media-caption-strip-muted-opacity);
}

.gc-media-caption-bar .gc-dropdown-toggle-icon,
.challenge-hero-cover-chrome .gc-dropdown-toggle-icon {
    background: color-mix(in srgb, var(--media-caption-strip-fg) 14%, transparent);
    border: 1px solid color-mix(in srgb, var(--media-caption-strip-fg) 32%, transparent);
    color: var(--media-caption-strip-fg);
}

/* Компактная сущность в горизонтальном ряду (партнёр, участник «чипом») */
.gc-entity-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-lg);
    border: 1px solid var(--ui-border);
    background: var(--bg-content-main);
    color: var(--font-primary);
    flex-shrink: 0;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

a.gc-entity-chip {
    text-decoration: none;
    color: inherit;
}

a.gc-entity-chip:hover,
a.gc-entity-chip:focus-visible {
    background: var(--gc-interactive-hover-bg);
    text-decoration: none;
    color: inherit;
}

.gc-entity-chip--static {
    cursor: default;
}

/* Ряд в list-панели: без «карточной» рамки и лишних отступов как у бейджа */
.gc-entity-chip.gc-entity-chip--bare {
    border: none;
    background: transparent;
    border-radius: 0;
    padding: var(--spacing-2xs) var(--spacing-xs);
    gap: var(--spacing-sm);
}

a.gc-entity-chip.gc-entity-chip--bare:hover,
a.gc-entity-chip.gc-entity-chip--bare:focus-visible,
button.gc-entity-chip.gc-entity-chip--bare:hover,
button.gc-entity-chip.gc-entity-chip--bare:focus-visible {
    background: var(--gc-interactive-hover-bg);
    text-decoration: none;
    color: inherit;
}

button.gc-entity-chip {
    font: inherit;
    color: inherit;
    margin: 0;
    text-align: start;
}

button.gc-entity-chip:not(.gc-entity-chip--static) {
    cursor: pointer;
}

.gc-entity-chip .gc-list-avatar,
.gc-entity-chip .gc-list-media-icon {
    flex-shrink: 0;
}

.gc-entity-chip .gc-list-content {
    flex: 1;
    min-width: 0;
}

/* Hover эффект для кликабельной обложки */
.gc-briefing-img-container[onclick],
.gc-briefing-img-container[style*="cursor: pointer"],
.gc-briefing-img-container--clickable {
    cursor: pointer;
}

.gc-briefing-img-container[onclick]:hover,
.gc-briefing-img-container[style*="cursor: pointer"]:hover,
.gc-briefing-img-container--clickable:hover {
    transform: scale(1.01);
}

.gc-briefing-img-container[onclick]:hover .gc-briefing-img-overlay,
.gc-briefing-img-container[style*="cursor: pointer"]:hover .gc-briefing-img-overlay,
.gc-briefing-img-container--clickable:hover .gc-briefing-img-overlay {
    background: rgba(0, 0, 0, 0.4);
}

/* Кликабельная обложка + --gradient-bottom: не затирать градиент плоским rgba(:hover). */
.gc-briefing-img-container.gc-briefing-img-container--gradient-bottom[onclick]:hover .gc-briefing-img-overlay,
.gc-briefing-img-container.gc-briefing-img-container--gradient-bottom[style*="cursor: pointer"]:hover .gc-briefing-img-overlay,
.gc-briefing-img-container.gc-briefing-img-container--gradient-bottom.gc-briefing-img-container--clickable:hover .gc-briefing-img-overlay {
    background: linear-gradient(
        to top,
        var(--media-caption-strip-bg-hover) 0%,
        transparent 50%
    );
    background: linear-gradient(
        to top,
        var(--media-caption-strip-bg-hover) 0%,
        rgb(from var(--media-caption-strip-bg-hover) r g b / 0) 50%
    );
}

/* Заблюренный фон */
.gc-briefing-img-blur {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center;
    filter: blur(15px);
    opacity: 0.9;
    transform: scale(1.1);
    transition: filter var(--transition-slow);
}

/* Затемняющий overlay */
.gc-briefing-img-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.4);
    pointer-events: none;
    z-index: 1;
    transition: background-color var(--transition-slow);
}

/* Wrapper для основного изображения */
.gc-briefing-img-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

/* Основное изображение — по умолчанию cover (оружие, формы, обложка страницы брифинга) */
.gc-briefing-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: filter var(--transition-slow);
}

/*
 * Неформат / не 16:9 — чёткое фото целиком (contain), по полям размытый слой gc-briefing-img-blur.
 * Карточки каталога, модал предпросмотра, страница брифинга — единый модификатор.
 */
.gc-briefing-img-container--letterbox .gc-briefing-img {
    object-fit: contain;
}

/* Hover эффект для обложки - инверсия фильтра */
.gc-card-briefing:hover .gc-briefing-img-blur {
    filter: blur(15px) invert(0.1);
}

.gc-card-briefing:hover .gc-briefing-img-overlay {
    background-color: rgba(0, 0, 0, 0.3);
}

.gc-card-briefing:hover .gc-briefing-img {
    filter: brightness(1.05);
}

/* Плейсхолдер для брифинга без изображения */
.gc-briefing-img-blur--fallback {
    background: linear-gradient(135deg, var(--bg-accent) 0%, var(--bg-content-secondary) 100%);
    filter: none;
}

.gc-briefing-img-placeholder {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(44, 62, 80, 0.7), rgba(75, 108, 183, 0.7));
    background-size: cover;
    background-position: center;
    background-blend-mode: overlay;
    filter: blur(32px);
    transform: scale(1.05);
    z-index: 1;
}

/* Затемняющий слой для плейсхолдера */
.gc-briefing-img-placeholder-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    z-index: 2;
}

/* Контент плейсхолдера */
.gc-briefing-placeholder-content {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-2xs);
    z-index: 2;
    padding: var(--spacing-sm);
    text-align: center;
}

.gc-briefing-placeholder-title {
    color: rgba(255, 255, 255, 0.75);
    font-size: var(--font-size-sm);
    font-weight: 600;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.gc-briefing-placeholder-shots {
    color: rgba(255, 255, 255, 0.45);
    font-size: var(--font-size-xs);
}

.gc-briefing-placeholder-logo {
    width: 80px;
    opacity: 0.7;
    margin-bottom: var(--spacing-2xs);
}

.gc-briefing-placeholder-text {
    color: var(--font-secondary);
    margin-bottom: 0;
    text-align: center;
    font-size: var(--font-size-sm);
}

/* ── Карточка брифинга в каталоге / профиле (макет Figma BriefCard) ── */

.gc-card-briefing > .gc-briefing-img-container--card {
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

/* Заглушка обложки (Figma 586:7746) — плоский фон + центрированная иллюстрация */
.gc-briefing-thumb-empty {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-content-secondary);
}

.gc-briefing-thumb-empty-illu {
    width: min(40%, 7.5rem);
    height: auto;
    max-height: 45%;
}

/* Как .weapon-card-shots-badge: плотный фон, светлый текст (не --bg-content-main — иначе цифры «теряются» в тёмной теме) */
.gc-briefing-cover-badge {
    position: absolute;
    top: var(--spacing-mdl);
    right: var(--spacing-mdl);
    z-index: 3;
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-full);
    background: var(--btn-black-bg);
    color: var(--btn-black-color);
    font-size: var(--font-size-sm);
    font-weight: 500;
    line-height: 1;
    pointer-events: none;
}

.gc-briefing-cover-badge .weapon-card-shots-badge-icon {
    height: 12px;
    width: auto;
}

.gc-briefing-cover-badge .ph-fill {
    color: var(--btn-black-color);
    font-size: var(--font-size-sm);
}

.gc-briefing-cover-badge-value {
    color: var(--btn-black-color);
}

.gc-briefing-card-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    gap: 0;
    padding: var(--spacing-2sm);
}

.gc-briefing-card-stack {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    justify-content: space-between;
    gap: var(--spacing-mdl);
}

.gc-briefing-card-main-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-mdl);
    width: 100%;
    min-width: 0;
}

.gc-briefing-card-text {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    flex: 1;
    min-width: 0;
}

.gc-briefing-card-title {
    margin: 0;
    font-size: var(--font-size-mdl);
    font-weight: 500;
    line-height: 1.3;
    color: var(--font-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: color var(--transition-fast);
}

.gc-card-briefing:hover .gc-briefing-card-title {
    color: var(--accent-link);
}

.gc-briefing-card-usage {
    margin: 0;
    font-size: var(--font-size-sm);
    font-weight: 400;
    line-height: 1.3;
    color: var(--font-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.gc-briefing-card-stat {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    flex-shrink: 0;
}

.gc-briefing-card-stat-label {
    font-size: var(--font-size-sm);
    font-weight: 400;
    line-height: 1.3;
    color: var(--font-primary);
    white-space: nowrap;
}

.gc-briefing-photo-stack {
    display: flex;
    align-items: flex-start;
}

.gc-briefing-photo-stack-item {
    width: 24px;
    height: 24px;
    border-radius: var(--radius-full);
    border: 2px solid var(--bg-content-main);
    margin-right: calc(-1 * var(--spacing-sm));
    overflow: hidden;
    flex-shrink: 0;
    background: var(--bg-content-secondary);
}

.gc-briefing-photo-stack-item:last-child {
    margin-right: 0;
}

.gc-briefing-photo-stack-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.gc-briefing-photo-stack-fallback {
    display: block;
    width: 100%;
    height: 100%;
    background: var(--bg-accent);
}

.gc-briefing-card-author {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    min-width: 0;
}

.gc-briefing-card-author-avatar {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-full);
    object-fit: cover;
    border: 1px solid var(--ui-border);
    flex-shrink: 0;
}

.gc-briefing-card-author-name {
    font-size: var(--font-size-sm);
    font-weight: 500;
    line-height: 1.3;
    color: var(--font-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Описание в других контекстах (не список карточек) */
.gc-briefing-description {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: var(--font-size-sm);
    line-height: 1.4;
    max-height: 2.8em;
    color: var(--font-secondary);
}

/* Блок с метаданными - использует utility: d-flex, justify-content-between, align-items-start, flex-shrink-0 */

/* Кнопка добавления брифинга */
.gc-briefing-add-action {
    padding: var(--spacing-md);
}

.gc-briefing-add-action .gc-btn {
    width: 100%;
}

/* ===================================
   Stage Sidebar Styles
   =================================== */

/* Контейнер характеристик */
.gc-stage-stats {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

/* Уменьшаем gap внутри карточек характеристик */
.gc-stage-stats .gc-card-body {
    gap: var(--spacing-sm);
}

/* Карточка с выстрелами */
.gc-stage-shots-card {
    text-align: center;
    padding: var(--spacing-lg) 0;
}

.gc-stage-shots-number {
    font-size: 3rem;
    font-weight: 700;
    margin-bottom: var(--spacing-2xs);
    color: var(--accent-link);
    line-height: 1;
}

.gc-stage-shots-label {
    color: var(--font-secondary);
    margin: 0;
    font-size: var(--font-size-md);
}

/* Список характеристик — shadcn-стиль: компактные горизонтальные пары лейбл/значение */
.gc-stat-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.gc-stat-item {
    padding: 2px 0;
}

.gc-stat-item:first-child { padding-top: 0; }
.gc-stat-item:last-child  { padding-bottom: 0; }

/* В контексте gc-stat-list — горизонтальная строка */
.gc-stat-list .gc-stat-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.gc-stat-label {
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
    font-weight: 400;
    margin: 0;
}

.gc-stat-value {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-xs);
    margin: 0;
}

/* В контексте gc-stat-list — compact font */
.gc-stat-list .gc-stat-value {
    text-align: right;
}

/* Горизонтальное расположение в модале на десктопе */
@media (min-width: 768px) {
    .gc-modal .gc-stat-item {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    
    .gc-modal .gc-stat-label {
        margin-bottom: 0;
    }
    
    /* Автор растягивается и имеет border */
    .gc-modal .gc-stat-item:has(.gc-profile-link) {
        border: 1px solid var(--ui-border);
        border-radius: var(--radius-md);
        padding: var(--spacing-sm);
    }
    
    .gc-modal .gc-profile-link {
        flex: 1;
        margin: 0;
    }
}

/* Профиль-кнопка автора */
.gc-profile-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm);
    margin: calc(var(--spacing-sm) * -1);
    border-radius: var(--radius-md);
    transition: background-color var(--transition-fast);
    text-decoration: none;
    color: inherit;
}

.gc-profile-link:hover {
    background-color: var(--bg-hover);
}

.gc-profile-link:active {
    background-color: var(--bg-active);
}

/* Убираем hover подъем для кнопки в карточке */
.gc-briefing-add-action .gc-btn:hover {
    transform: none;
    box-shadow: none;
}

.gc-briefing-add-action .gc-btn:active {
    transform: none;
}

/* =================================
   Stage Content Styles
   ================================= */

/* Карточка контента брифинга: margin-bottom управляется gap родителя */

/* Карточка этапов: margin-bottom управляется gap родителя */

/* На адаптиве — секции брифинга у края экрана без боковых линий */
@media (max-width: 991.98px) {
    .catalog-main > .gc-card.gc-stage-content-card,
    .catalog-main > .gc-card.gc-stage-sections-card {
        /* border-left: none;
        border-right: none; */
    }
}

.gc-stage-content-title {
    margin-bottom: var(--spacing-md);
}

/* Стили в stage-editor.css */

/* Заголовок секций: margin убран, т.к. gc-card-body использует gap */

/* Заголовок этапа в accordion */
.gc-stage-section-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex: 1; /* Растягивается на всю доступную ширину */
}

.gc-stage-section-badge {
    min-width: 28px;
    justify-content: center;
}

/* Изображение этапа */
.gc-stage-section-img {
    margin-bottom: var(--spacing-md);
}

.gc-stage-section-img img {
    width: 100%;
    max-height: 400px;
    object-fit: cover;
    border-radius: var(--radius-md);
}

/* Описание этапа */
.gc-stage-section-description {
    white-space: pre-line;
    color: var(--font-secondary);
    margin-bottom: 0;
}

.gc-stage-section-description:not(:last-child) {
    margin-bottom: var(--spacing-md);
}

/* Кнопки управления этапом */
.gc-stage-section-actions {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
}

.gc-stage-section-actions .gc-btn {
    flex: 1;
}

.gc-stage-section-actions form {
    flex: 1;
    display: flex; /* Форма должна быть flex-контейнером */
}

.gc-stage-section-actions form .gc-btn {
    width: 100%; /* Кнопка внутри формы на всю ширину */
}

/* Кнопка добавления этапа */
.gc-stage-add-section-btn {
    width: 100%;
    /* margin-top убран, т.к. gc-card-body использует gap */
}

/* Empty State */
.gc-stage-empty-state {
    text-align: center;
    padding: var(--spacing-xl) 0;
}

.gc-stage-empty-icon {
    font-size: 3rem;
    opacity: 0.3;
}

.gc-stage-empty-title {
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.gc-stage-empty-description {
    color: var(--font-secondary);
    margin-bottom: var(--spacing-md);
}

/* Адаптив для контента брифинга */
@media (max-width: 767.98px) {
    .gc-stage-section-img img {
        max-height: 300px;
    }
    
    .gc-stage-section-actions {
        flex-direction: column;
    }
    
    .gc-stage-section-actions .gc-btn {
        width: 100%;
    }
}

/* Legacy: карточка брифинга в форме упражнения (exercises/partials/briefing-card) */
.gc-briefing-title-section .gc-card-title {
    font-family: var(--font-family-base);
    font-size: var(--font-size-md);
    font-weight: 600;
    line-height: 1.3;
}

.gc-briefing-shots-count {
    font-size: var(--font-size-3xl);
    font-weight: 700;
    color: var(--accent-link);
    margin-bottom: 0;
    line-height: 1;
}

.gc-briefing-shots-label {
    font-size: var(--font-size-xs);
    color: var(--font-secondary);
    line-height: 1;
    margin-top: var(--spacing-3xs);
}

.gc-briefing-avatar {
    width: 40px;
    height: 40px;
    object-fit: cover;
    border-radius: var(--radius-full);
    border: 1px solid var(--ui-border);
}

.gc-briefing-author-name {
    margin-bottom: 0;
    font-weight: 500;
    font-size: var(--font-size-sm);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--font-primary);
}

.gc-briefing-meta {
    font-size: var(--font-size-xs);
    color: var(--font-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ===================================
   Stage Card Mini (Компактная версия для упражнений)
   =================================== */

@media (max-width: 991px) {
    .gc-briefing-shots-count {
        font-size: var(--font-size-2xl);
    }
}

@media (max-width: 576px) {
    .gc-card-briefing .gc-card-body:not(.gc-briefing-card-body) {
        padding: var(--spacing-md);
    }

    .gc-briefing-shots-count {
        font-size: var(--font-size-2xl);
    }

    .gc-briefing-avatar {
        width: 32px;
        height: 32px;
    }

    .gc-briefing-author-name {
        font-size: var(--font-size-sm);
    }

    .gc-briefing-meta {
        font-size: var(--font-size-xs);
    }
}

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

/* Стили для карточки в контексте добавления брифинга */
.stage-card-wrapper {
    position: relative;
}

.stage-card-wrapper .gc-btn {
    transition: all var(--transition-fast);
}

/* Стили для удаления брифинга (кнопка в углу) */
.gc-card-briefing .gc-btn-icon-sm {
    width: 32px;
    height: 32px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 576px) {
    .gc-card-briefing .gc-btn-icon-sm {
        width: 28px;
        height: 28px;
    }
    
    .gc-card-briefing .gc-btn-icon-sm i {
        font-size: var(--font-size-sm);
    }
}

/* ===================================
   Briefing Card Compact (Компактная горизонтальная карточка)
   =================================== */

.gc-card-briefing-compact {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    min-height: 80px;
    cursor: pointer;
    padding: 0;
    gap: 0;
}

.gc-card-briefing-compact:hover {
    background: var(--bg-content-secondary);
    border-color: var(--border-tertiary);
    box-shadow: none;
}

.gc-card-briefing-compact:hover .gc-briefing-compact-title {
    color: var(--accent-link);
}

/* Квадратное изображение слева */
.gc-briefing-compact-img {
    width: 80px;
    height: 80px;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    background-color: var(--bg-main);
    border-radius: var(--radius-lg);
}

.gc-briefing-compact-img-content {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.gc-card-briefing-compact:hover .gc-briefing-compact-img-content {
    transform: scale(1.05);
}

/* Плейсхолдер для изображения */
.gc-briefing-compact-img-placeholder {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

/* Контент справа */
.gc-briefing-compact-body {
    flex: 1;
    padding: var(--spacing-sm) var(--spacing-md);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
    min-width: 0; /* Для корректного ellipsis */
}

.gc-briefing-compact-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xs);
}

/* Заголовок */
.gc-briefing-compact-title {
    margin: 0;
    font-size: var(--font-size-md);
    font-weight: 600;
    line-height: 1.3;
    color: var(--font-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color var(--transition-fast);
}

/* Лейбл "Брифинг" */
.gc-briefing-compact-label {
    font-size: var(--font-size-base);
    color: var(--font-secondary);
    font-weight: 500;
}

/* Счетчик выстрелов */
.gc-briefing-compact-shots {
    display: flex;
    flex-direction: column;
    align-items: right;
    justify-content: right;
    flex-shrink: 0;
    text-align: right;
    min-width: 48px;
}

.gc-briefing-compact-shots-count {
    font-size: var(--font-size-2xl); /* Увеличен с 1.25rem */
    font-weight: 700;
    color: var(--accent-link);
    line-height: 1;
}

.gc-briefing-compact-shots-label {
    font-size: var(--font-size-xs); /* Увеличен с 0.625rem */
    color: var(--font-secondary);
    line-height: 1;
    margin-top: 3px;
}

/* Адаптивность для компактной карточки */
@media (max-width: 576px) {
    .gc-card-briefing-compact {
        min-height: 72px;
    }
    
    .gc-briefing-compact-img {
        width: 72px;
        height: 72px;
    }
    
    .gc-briefing-compact-body {
        padding: var(--spacing-xs) var(--spacing-sm);
        gap: var(--spacing-sm);
    }
    
    .gc-briefing-compact-title {
        font-size: var(--font-size-base); /* Увеличен с 0.875rem */
    }
    
    .gc-briefing-compact-label {
        font-size: var(--font-size-sm);
    }
    
    .gc-briefing-compact-shots-count {
        font-size: var(--font-size-xxl); /* Увеличен с 1.125rem */
    }
    
    .gc-briefing-compact-shots {
        min-width: 44px;
    }
}

/* ===================================
   Weapon Cards (Карточки оружия)
   =================================== */

.weapon-card {
    background: transparent;
    border-radius: 0;
    overflow: visible;
    transition: all var(--transition-base);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    width: 100%; /* Явная ширина */
    height: 100%;
    box-sizing: border-box; /* Border не увеличивает ширину */
}

/*
 * Сетка /weapons: блок превью 16:9; рамка только если нет фото (иконка-плейсхолдер).
 * Статус — отдельная полоса НАД карточкой превью; превью заезжает вверх (как subscriptions-pricing-card-cell--strip).
 */
.weapon-card-media {
    width: 100%;
    aspect-ratio: 16 / 9;
    flex-shrink: 0;
    border-radius: var(--weapon-card-corner-radius);
    border: 1px solid var(--ui-border);
    overflow: hidden;
    background: var(--bg-content-secondary);
    isolation: isolate;
}

/* С реальным фото обводка превью не нужна; для SVG-плейсхолдера рамка остаётся */
.weapon-card-media:has(img:not(.is-icon-placeholder)) {
    border: none;
}

/* Лоадаут и др.: превью без обёртки .weapon-card-media — рамка на .weapon-card-image */
.weapon-card:not(.weapon-card-add) > .weapon-card-image:has(img:not(.is-icon-placeholder)) {
    border: none;
}

.weapon-card-media > .weapon-card-image,
.gc-weapon-popup-media > .weapon-card-image {
    width: 100%;
    height: 100%;
    aspect-ratio: unset;
    min-height: 0;
    border: none;
    border-radius: 0;
    overflow: hidden;
}

.weapon-card-media > .weapon-card-image img,
.gc-weapon-popup-media > .weapon-card-image img {
    border-radius: inherit;
}

/*
 * Субпиксельное округление + contain: при фактически 16:9 иногда остаётся ~1px по бокам.
 * Лёгкий scale внутри overflow:hidden съедает щель без заметной обрезки кадра.
 */
.weapon-card-media > .weapon-card-image img:not(.is-icon-placeholder),
.gc-weapon-popup-media > .weapon-card-image img:not(.is-icon-placeholder),
.weapon-card:not(.weapon-card-add) > .weapon-card-image img:not(.is-icon-placeholder) {
    display: block;
    transform: translateZ(0) scale(1.003);
    transform-origin: center center;
}

/* Полоса статуса — сосед сверху, не внутри .weapon-card-media */
.weapon-card.weapon-card--strip {
    gap: 0;
}

.weapon-card.weapon-card--strip > .weapon-card-body {
    margin-top: var(--spacing-sm);
}

.weapon-card.weapon-card--strip > .weapon-card-strip-row,
.weapon-show-strip-cell > .weapon-card-strip-row,
.weapon-show-sidebar-strip-cell > .weapon-card-strip-row {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    width: 100%;
    min-width: 0;
    position: relative;
    z-index: 0;
    padding: 0;
    pointer-events: none;
}

/* Карточка превью заезжает на полосу — нижняя часть полосы «из-под» плитки */
.weapon-card.weapon-card--strip > .weapon-card-media.weapon-card-media--overlap {
    position: relative;
    z-index: 1;
    margin-top: calc(-1 * (var(--spacing-md) + var(--spacing-xs)));
}

.weapon-card-strip-pill {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: var(--spacing-xs);
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-height: 0;
    background: var(--weapon-card-strip-bg);
    color: var(--weapon-card-strip-text);
    font-weight: 500;
    transition: background-color var(--transition-fast) var(--ease-in-out);
}

.weapon-card.weapon-card--strip .weapon-card-strip-pill,
.gc-weapon-popup-strip .weapon-card-strip-pill,
.weapon-show-strip-cell .weapon-card-strip-pill,
.weapon-show-sidebar-strip-cell .weapon-card-strip-pill {
    padding: var(--spacing-sm) var(--spacing-sm) var(--spacing-lg) var(--spacing-sm);
    border-top-left-radius: var(--weapon-card-corner-radius);
    border-top-right-radius: var(--weapon-card-corner-radius);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    font-size: var(--font-size-caption);
    line-height: var(--line-height-list-description);
}

.weapon-card-strip-pill--muted {
    /* Тёплый нейтраль — токен --gc-status-muted-chrome (абонементы, индикаторы и т.д.) */
    --weapon-card-strip-bg: color-mix(in srgb, var(--gc-status-muted-chrome) var(--weapon-card-strip-muted-mix), var(--bg-content-secondary));
    --weapon-card-strip-bg-hover: color-mix(in srgb, var(--gc-status-muted-chrome) var(--weapon-card-strip-muted-mix-hover), var(--bg-content-secondary));
    --weapon-card-strip-bg-active: color-mix(in srgb, var(--gc-status-muted-chrome) var(--weapon-card-strip-muted-mix-active), var(--bg-content-secondary));
    --weapon-card-strip-text: var(--font-primary);
}

.weapon-card-strip-pill--sale {
    --weapon-card-strip-bg: color-mix(in srgb, rgb(var(--warning-color-rgb)) var(--weapon-card-strip-sale-mix), var(--bg-content-main));
    --weapon-card-strip-bg-hover: color-mix(in srgb, rgb(var(--warning-color-rgb)) var(--weapon-card-strip-sale-mix-hover), var(--bg-content-main));
    --weapon-card-strip-bg-active: color-mix(in srgb, rgb(var(--warning-color-rgb)) var(--weapon-card-strip-sale-mix-active), var(--bg-content-main));
    --weapon-card-strip-text: var(--font-primary);
}

/* Вся полоса «любимое» — пастельный красный фон (не бадж у подписи типа) */
.weapon-card-strip-pill--favorite.weapon-card-strip-pill--muted {
    --weapon-card-strip-bg: color-mix(
        in srgb,
        rgb(var(--danger-color-rgb)) var(--weapon-card-strip-favorite-bg-mix),
        var(--bg-content-main)
    );
    --weapon-card-strip-bg-hover: color-mix(
        in srgb,
        rgb(var(--danger-color-rgb)) calc(var(--weapon-card-strip-favorite-bg-mix) + 5%),
        var(--bg-content-main)
    );
    --weapon-card-strip-bg-active: color-mix(
        in srgb,
        rgb(var(--danger-color-rgb)) calc(var(--weapon-card-strip-favorite-bg-mix) + 9%),
        var(--bg-content-main)
    );
}

.weapon-card-strip-name {
    flex: 1 1 auto;
    min-width: 0;
}

/* Тип оружия слева; при «любимом» — иконка сердца. Обрезка только при нехватке места (без фикс. max-width). */
.weapon-card-strip-type {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: var(--spacing-3xs);
    flex: 0 1 auto;
    min-width: 0;
    color: var(--weapon-card-strip-text);
}

.weapon-card-strip-type-heart {
    flex-shrink: 0;
    font-size: var(--font-size-caption);
    line-height: 1;
    color: var(--danger-color);
}

.weapon-card-strip-type-label {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* «Любимый травмат»: строчное существительное; вариант с заглавной — только когда прилагательное скрыто (см. profile-widgets.css). */
.weapon-card-strip-type-label-noun--solo {
    display: none;
}

/* Только статус (напр. «Продано») — на всю ширину полосы */
.weapon-card-strip-pill > .weapon-card-strip-name:only-child {
    flex: 1 1 auto;
    min-width: 0;
}

.weapon-card-strip-shots {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: var(--spacing-3xs);
    flex: 0 0 auto;
    min-width: 0;
    margin-left: auto;
}

.weapon-card-strip-shots-value {
    flex: 0 0 auto;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.weapon-card-strip-shots-icon-wrap {
    display: inline-flex;
    align-items: center;
    line-height: 0;
}

.weapon-card-strip-shots-icon {
    display: block;
    flex-shrink: 0;
    width: auto;
    height: var(--font-size-xs);
    object-fit: contain;
    object-position: center;
}

/* Полоса: тёмная тема — белый SVG; светлая — тёмная графика (как weapon-card-shots-badge-icon) */
.weapon-card-strip-shots-icon.weapon-card-strip-shots-icon--theme-light {
    display: none !important;
}

html[data-theme="light"] .weapon-card-strip-shots-icon.weapon-card-strip-shots-icon--theme-dark {
    display: none !important;
}

html[data-theme="light"] .weapon-card-strip-shots-icon.weapon-card-strip-shots-icon--theme-light {
    display: block !important;
}

.weapon-card-strip-shots-icon-fallback {
    flex-shrink: 0;
    font-size: var(--font-size-xs);
    line-height: 1;
    color: var(--weapon-card-strip-text);
}

.weapon-card-link:hover .weapon-card-strip-pill {
    background: var(--weapon-card-strip-bg-hover);
}

.weapon-card-link:active .weapon-card-strip-pill {
    background: var(--weapon-card-strip-bg-active);
}

.weapon-card-link:hover .weapon-card.weapon-card--strip .weapon-card-media:has(img.is-icon-placeholder) {
    border-color: var(--border-tertiary);
}

.weapon-card-image {
    --weapon-card-image-blur: 1.25rem;
    --weapon-card-image-blur-scale: 1.12;
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9; /* Современный метод */
    background: var(--bg-content-secondary);
    border-radius: var(--radius-md);
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    isolation: isolate;
    border: 1px solid var(--ui-border);
}

/* Размытый «заполнитель» из того же фото под contain — мягкие поля, если пропорции не 16:9 */
.weapon-card-image-blur {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: var(--weapon-card-photo);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    transform: scale(var(--weapon-card-image-blur-scale));
    filter: blur(var(--weapon-card-image-blur));
    pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
    .weapon-card-image-blur {
        filter: blur(calc(var(--weapon-card-image-blur) * 0.5));
    }
}

.weapon-card-image img {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    object-fit: contain; /* Весь кадр; поля при несовпадении с 16:9 закрывает blur-слой */
    transition:
        filter var(--transition-base),
        opacity var(--transition-base),
        transform var(--transition-base);
}

.weapon-card-image img.is-icon-placeholder {
    object-fit: contain;
    width: 50%;
    height: 50%;
    opacity: 0.25;
}

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

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

.weapon-card-image img.is-icon-placeholder.icon-pistol {
    width: 30%;
    height: 30%;
}

/* Чип выстрелов — макет Figma: gap 4px, py 4px px 8px, иконка h 12px, top/right 6px */
.weapon-card-shots-badge {
    position: absolute;
    top: var(--spacing-3xs);
    right: var(--spacing-3xs);
    z-index: 3;
    display: inline-flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    box-sizing: border-box;
    max-width: calc(100% - 2 * var(--spacing-3xs));
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-full);
    background: var(--btn-black-bg);
    color: var(--btn-black-color);
    font-weight: 500;
    line-height: 1;
    pointer-events: none;
    box-shadow: none;
}

.weapon-card-shots-badge-value {
    flex: 0 0 auto;
    font-size: var(--font-size-sm);
    white-space: nowrap;
}

.weapon-card-shots-badge i {
    flex-shrink: 0;
    font-size: var(--font-size-xs);
    line-height: 1;
}

/* Слот иконки: высота 12px как в Figma; ширина по содержимому, верхняя граница ~34px для широких SVG */
.weapon-card-shots-badge-icon-wrap {
    display: inline-flex;
    align-items: center;
    line-height: 0;
}

.weapon-card-shots-badge-icon {
    display: block;
    flex: 0 0 auto;
    width: auto;
    height: 12px;
    max-width: 2.25rem;
    object-fit: contain;
    object-position: left center;
}

/* nastr-badge.svg — тёмная тема; nastr-badge-light.svg — html[data-theme="light"]
   Специфичность должна перебивать `.weapon-card-shots-badge-icon { display:block; }`. */
.weapon-card-shots-badge-icon.weapon-card-shots-badge-icon--theme-light {
    display: none !important;
}

html[data-theme="light"] .weapon-card-shots-badge-icon.weapon-card-shots-badge-icon--theme-dark {
    display: none !important;
}

html[data-theme="light"] .weapon-card-shots-badge-icon.weapon-card-shots-badge-icon--theme-light {
    display: block !important;
}

/*
 * Чип выстрелов на карточках: фон всегда тёмный (--btn-black-bg), без смены SVG по теме страницы
 * (nastr-badge-light.svg рассчитан на светлый фон и «пропадает» на чёрном чипе).
 */
html[data-theme] .weapon-card-shots-badge .weapon-card-shots-badge-icon.weapon-card-shots-badge-icon--theme-light,
html[data-theme] .gc-briefing-cover-badge .weapon-card-shots-badge-icon.weapon-card-shots-badge-icon--theme-light {
    display: none !important;
}

html[data-theme] .weapon-card-shots-badge .weapon-card-shots-badge-icon.weapon-card-shots-badge-icon--theme-dark,
html[data-theme] .gc-briefing-cover-badge .weapon-card-shots-badge-icon.weapon-card-shots-badge-icon--theme-dark {
    display: block !important;
}

.weapon-card-badge {
    position: absolute;
    top: var(--spacing-2sm);
    right: var(--spacing-2sm);
    z-index: 3;
    background: rgba(255, 193, 7, 0.95);
    color: #000;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    box-shadow: none;
    backdrop-filter: blur(4px);
}

/* Звезда «основное» — влево, если справа чип выстрелов */
.weapon-card-image:has(.weapon-card-shots-badge) > .weapon-card-badge:not(.weapon-card-badge-private) {
    left: var(--spacing-2sm);
    right: auto;
}

.weapon-card-badge-private {
    z-index: 3;
    background: rgba(100, 100, 100, 0.85);
    color: #fff;
    top: var(--spacing-2sm);
    left: var(--spacing-2sm);
    right: auto;
}

.weapon-card--archived .weapon-card-image {
    opacity: 0.94;
}

/* /weapons: колонка из нескольких gc-panel (--plain-below-lg на мобиле) под профилем.
   До этого блока от профиля — gap у .catalog-main (--spacing-sm).
   Между панелями здесь — шире; меняй --weapon-index-panel-stack-gap или сам gap. */
.weapon-index-panel-stack {
    display: flex;
    flex-direction: column;
    gap: var(--weapon-index-panel-stack-gap, var(--spacing-mdl));
}

/* /weapons: архив — отдельная gc-panel под активным списком */
.weapon-archive-panel > .gc-panel-header {
    align-items: flex-start;
}

.weapon-archive-panel__heading {
    min-width: 0;
}

.weapon-archive-panel__heading .gc-form-description {
    margin: 0;
}

.weapon-card:hover .weapon-card-badge {
    transform: scale(1.05);
    box-shadow: none;
}

.weapon-card-body {
    padding: 0;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    min-width: 0;
}

/* Заголовок: текст + шеврон в одном ряду сразу после текста; шеврон до hover скрыт, на мобиле отключён */
.weapon-card-heading {
    min-width: 0;
    width: 100%;
}

.weapon-card-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    max-width: 100%;
    min-width: 0;
    margin: 0;
    font-weight: 500;
}

.weapon-card-title-text {
    flex: 0 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.weapon-card-chevron {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: translateX(calc(-1 * var(--spacing-xs)));
    transition:
        opacity var(--transition-fast) var(--ease-out),
        transform var(--transition-fast) var(--ease-out);
    color: var(--font-secondary);
}

.weapon-card-chevron i {
    font-size: var(--font-size-md);
}

.weapon-card:hover .weapon-card-chevron {
    opacity: 1;
    transform: translateX(0);
}

.weapon-card-subtitle {
    font-size: var(--font-size-xs);
    font-weight: 500;
    color: var(--font-secondary);
    margin: 0;
    display: flex;
    align-items: baseline;
    gap: var(--spacing-xs);
    min-width: 0;
}

.weapon-card-subtitle-caliber {
    flex: 0 1 auto;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.weapon-card-subtitle-class {
    flex: 1 1 auto;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.weapon-card-link {
    display: block;
    color: inherit;
    text-decoration: none;
}

/* Weapon Card - Add Button */
.weapon-card-add {
    border: 1px dashed var(--border-tertiary);
    background: transparent;
    justify-content: center;
    align-items: center;
}

.weapon-card-add:hover {
    border-color: var(--accent-link);
    background: rgba(var(--accent-link-rgb), 0.05);
}

/* Убираем aspect ratio для кнопки добавления */
.weapon-card-add .weapon-card-image {
    aspect-ratio: auto;
    height: auto;
    flex-grow: 0;
    flex-shrink: 1;
    background: transparent;
}

.weapon-card-add .weapon-card-image i {
    font-size: 40px;
    color: var(--font-secondary);
    opacity: 0.5;
    transition: all var(--transition-base);
}

.weapon-card-add:hover .weapon-card-image i {
    color: var(--accent-link);
    opacity: 0.8;
    transform: scale(1.1);
}

.weapon-card-add .weapon-card-body {
    padding: 0;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    flex-grow: 0;
}

.weapon-card-add .weapon-card-title {
    color: var(--font-secondary);
    font-weight: 500;
    margin: 0;
}

.weapon-card-add:hover .weapon-card-title {
    color: var(--accent-link);
}

/* Адаптивность для weapon cards */
@media (max-width: 767.98px) {
    .weapon-card-chevron {
        display: none;
    }

    .weapon-card:hover .weapon-card-badge {
        transform: none;
        box-shadow: none;
    }
}

@media (max-width: 576px) {
    .weapon-card-title {
        font-size: var(--font-size-sm);
    }
    
    .weapon-card-subtitle {
        font-size: var(--font-size-xs);
    }
    
    .weapon-card-badge {
        width: 24px;
        height: 24px;
        font-size: 12px;
        top: var(--spacing-3sm);
        right: var(--spacing-3sm);
    }
    
    .weapon-card-add .weapon-card-image i {
        font-size: 32px;
    }
}

/* Muted card - для мероприятий, которые не зачтены в рейтинг */
.gc-card-muted {
    opacity: 0.7;
    background: var(--bg-content-main);
}

.gc-card-muted .gc-card-header {
    opacity: 0.9;
}

/* ===================================
   Top-3 Ranking Grid (Топ-3 рейтинга)
   =================================== */

/* Обертка для контента рейтингов (топ-3 + топ 4-6) */
.gc-rankings-content {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* ── Подиум топ-3: аватарка на весь фрейм ───────────────────── */

.podium-card {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-lg);
    border: 1px solid var(--ui-border);
    cursor: pointer;
    background: var(--bg-content-secondary);
    transition: opacity 0.2s ease;
}

.podium-card:hover {
    opacity: 0.92;
}

/* Аватарка заполняет всю карточку */
.podium-card__avatar {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Wrapper для статусной точки + полноразмерного фона карточки */
.podium-card__avatar-wrap {
    position: absolute;
    inset: 0;
    display: block;
}

/* Фоллбэк без аватарки */
.podium-card__avatar-fallback {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.podium-card__initials {
    font-size: clamp(36px, 8cqw, 52px);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--font-secondary);
    line-height: 1;
    user-select: none;
    position: relative;
    z-index: 2;
}

/* Тёмный градиент снизу — только для карточек с фото */
.podium-card--has-avatar::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.88) 0%,
        rgba(0, 0, 0, 0.3) 50%,
        transparent 100%
    );
    z-index: 1;
    pointer-events: none;
}

/* Бейдж места — верхний левый угол */
.podium-card__badge-wrap {
    position: absolute;
    top: var(--spacing-sm);
    left: var(--spacing-sm);
    z-index: 2;
}

/* Имя и очки — внизу */
.podium-card__info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 2;
    padding: var(--spacing-md);
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.podium-card__name {
    color: var(--font-primary);
    font-weight: 600;
    font-size: var(--font-size-sm);
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

.podium-card--has-avatar .podium-card__name {
    color: rgba(255, 255, 255, 0.95);
    text-shadow: 0 1px 6px rgba(0, 0, 0, 0.6);
}

.podium-card__score {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    color: var(--font-secondary);
    font-size: var(--font-size-xs);
    min-width: 0;
}

.podium-card__score-text {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.podium-card__score .gc-badge {
    flex-shrink: 0;
}

.podium-card--has-avatar .podium-card__score {
    color: rgba(255, 255, 255, 0.8);
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
}

/* Цветные бордеры и тени по месту */
.podium-card--gold {
    border-color: rgba(255, 180, 40, 0.55);
    box-shadow: 0 0 0 1px rgba(255, 180, 40, 0.12);
}

.podium-card--silver {
    border-color: rgba(192, 192, 192, 0.45);
}

.podium-card--bronze {
    border-color: rgba(205, 127, 50, 0.45);
}

/* Фоллбэк: нейтральный фон */
.podium-card .podium-card__avatar-fallback {
    background: var(--ui-surface-1);
}

.podium-card__avatar-wrap .gc-avatar-status-dot {
    top: var(--spacing-sm);
    right: var(--spacing-sm);
}

/* Три места в три равные колонки */
.top3-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: minmax(280px, 1fr);
    gap: 0.5rem;
}

.top3-grid > div {
    min-width: 0;
}

.top3-grid .podium-card {
    height: 100%;
}

@media (max-width: 576px) {
    .top3-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-areas:
            "first first"
            "second third";
        grid-auto-rows: minmax(220px, auto);
    }

    .top3-grid > div {
        min-height: 220px;
    }

    .top3-grid > div:nth-child(1) { grid-area: first; }
    .top3-grid > div:nth-child(2) { grid-area: second; }
    .top3-grid > div:nth-child(3) { grid-area: third; }

    .podium-card__name {
        font-size: var(--font-size-sm);
    }

    .podium-card__score {
        font-size: var(--font-size-xs);
    }
}

/* Карточки топ-3 */
.card-top {
    position: relative;
    overflow: hidden !important;
    border: 1px solid var(--border-overlay);
    border-radius: var(--radius-lg) !important;
    transition: background var(--transition-fast) var(--ease-in-out),
                border-color var(--transition-fast) var(--ease-in-out);
    
    /* Glass morphism effect */
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
}

.card-top.profile-trigger {
    cursor: pointer;
}

.card-top:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.2);
}

/* Цветные варианты карточек топ-3 */
.card-top-gold:not(.card-with-blur) {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 0%, rgba(255, 180, 40, 0.08) 100%);
    border-color: rgba(255, 180, 40, 0.4);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
}

.card-top-gold:not(.card-with-blur):hover {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.08) 0%, rgba(255, 180, 40, 0.12) 100%);
    border-color: rgba(255, 180, 40, 0.6);
}

.card-top-silver:not(.card-with-blur) {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 0%, rgba(192, 192, 192, 0.08) 100%);
    border-color: rgba(192, 192, 192, 0.4);
}

.card-top-silver:not(.card-with-blur):hover {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.08) 0%, rgba(192, 192, 192, 0.12) 100%);
    border-color: rgba(192, 192, 192, 0.6);
}

.card-top-bronze:not(.card-with-blur) {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 0%, rgba(205, 127, 50, 0.08) 100%);
    border-color: rgba(205, 127, 50, 0.4);
}

.card-top-bronze:not(.card-with-blur):hover {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.08) 0%, rgba(205, 127, 50, 0.12) 100%);
    border-color: rgba(205, 127, 50, 0.6);
}

/* Карточки с фоном-аватаркой - без цветного градиента */
.card-top-gold.card-with-blur,
.card-top-silver.card-with-blur,
.card-top-bronze.card-with-blur {
    background: rgba(255, 255, 255, 0.05);
}

/* Усиление цветов в светлой теме */
[data-theme="light"] .card-top-gold:not(.card-with-blur) {
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.03) 0%, rgba(255, 180, 40, 0.15) 100%);
    border-color: rgba(255, 160, 20, 0.6);
}

[data-theme="light"] .card-top-gold:not(.card-with-blur):hover {
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.05) 0%, rgba(255, 180, 40, 0.2) 100%);
    border-color: rgba(255, 160, 20, 0.8);
}

[data-theme="light"] .card-top-silver:not(.card-with-blur) {
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.03) 0%, rgba(160, 160, 160, 0.15) 100%);
    border-color: rgba(140, 140, 140, 0.6);
}

[data-theme="light"] .card-top-silver:not(.card-with-blur):hover {
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.05) 0%, rgba(160, 160, 160, 0.2) 100%);
    border-color: rgba(140, 140, 140, 0.8);
}

[data-theme="light"] .card-top-bronze:not(.card-with-blur) {
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.03) 0%, rgba(205, 127, 50, 0.15) 100%);
    border-color: rgba(180, 100, 30, 0.6);
}

[data-theme="light"] .card-top-bronze:not(.card-with-blur):hover {
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.05) 0%, rgba(205, 127, 50, 0.2) 100%);
    border-color: rgba(180, 100, 30, 0.8);
}

.card-top-body {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 0;
    position: relative;
    z-index: 1;
}

.card-top-badge-section {
    padding: var(--spacing-sm);
    text-align: center;
}

.card-top-badge {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--font-secondary);
}

.card-top-avatar-section {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--ui-border);
}

.card-top-name-section {
    min-width: 0;
    width: 100%;
    text-align: center;
}

.card-top-name {
    margin: 0;
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--font-primary);
    font-size: var(--font-size-md);
}

.card-top-score-section {
    padding: var(--spacing-md);
    background: transparent;
    text-align: center;
}

.card-top-score {
    font-size: var(--font-size-sm);
    color: var(--font-secondary);
}

/* Legacy support */
.card-top .card-body {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.card-top .border-bottom {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

.card-top .name-section {
    min-width: 0;
    width: 100%;
}

.card-top .name-section h6 {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Wrapper для аватара без блюра */
.avatar-center-wrapper {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--spacing-md);
    text-align: center;
}

.avatar-center-wrapper img {
    display: block;
    margin: 0 auto;
}

/* Карточки с блюром фона */
.card-with-blur {
    position: relative;
    overflow: hidden !important;
}

.card-blur-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: blur(0px) saturate(1.3);
    transform: scale(1);
    opacity: 1;
    z-index: 0;
    transition: filter 0.3s ease;
}

.card-with-blur::after {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--bg-content-main);
    opacity: 0.1;
    z-index: 1;
    transition: opacity 0.3s ease;
}

/* Градиент снизу для читаемости текста */
.card-with-blur::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.95) 0%, transparent 100%);
    z-index: 2;
    pointer-events: none;
}

.card-with-blur .card-body {
    position: relative;
    z-index: 3;
}

.card-with-blur .border-bottom > div:first-child {
    flex: 1;
}

.card-with-blur:not(.card-top-1) .border-bottom {
    min-height: 180px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

/* Светлый текст с тенью для карточек с блюром */
.card-with-blur .name-section h6 {
    color: rgba(255, 255, 255, 0.95) !important;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}

.card-with-blur .score-section {
    color: rgba(255, 255, 255, 0.9) !important;
}

/* Белый текст для новых классов карточек с блюром */
.card-with-blur .card-top-name {
    color: rgba(255, 255, 255, 0.95) !important;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}

.card-with-blur .card-top-score {
    color: rgba(255, 255, 255, 0.9) !important;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
}

.card-with-blur .card-top-body {
    position: relative;
    z-index: 3;
}

/* Стили для секции с очками при наличии фона-аватарки */
.card-with-blur .card-top-score-section {
    background: transparent;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.card-with-blur .score-section * {
    color: rgba(255, 255, 255, 0.9) !important;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
}

/* Hover эффекты для карточек с блюром */
.card-with-blur:hover .card-blur-bg {
    filter: blur(4px) saturate(1);
}

.card-with-blur:hover::after {
    opacity: 0;
}

/* Адаптивность для карточек топ-3 */
@media (max-width: 768px) {
    /* Для карточек БЕЗ блюра на мобильных */
    .card-top:not(.card-with-blur) .border-bottom {
        min-height: 200px;
    }
    
    .card-top:not(.card-with-blur).card-top-1 .border-bottom {
        min-height: 280px;
    }
    
    /* Для карточек С блюром на мобильных */
    .card-with-blur.card-top-1 .border-bottom {
        min-height: 250px;
    }
    
    .card-with-blur:not(.card-top-1) .border-bottom {
        min-height: 200px;
    }
}

