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

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

.gc-card {
    background: var(--bg-content-main);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: all var(--transition-slow);
    width: 100%;
    display: flex;
    flex-direction: column;
}

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

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

a.gc-card:hover {
    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 h3,
.gc-card-header h4 {
    margin: 0;
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--font-primary);
}

/* Группировка 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;
    font-weight: 800;
    color: var(--font-primary);
    line-height: 1.4;
}

.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;
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--font-primary);
    line-height: 1.4;
}

.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;
    font-size: var(--font-size-md);
}

.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: 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;
}

.gc-card-footer {
    padding: var(--spacing-md) var(--spacing-md);
    border-top: 1px solid var(--border-primary);
    background: transparent;
}

/* Текстовые элементы внутри карточки */
.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: none;
    box-shadow: var(--shadow-md);
}

.gc-card-shadow:hover {
    box-shadow: var(--shadow-xl);
}

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

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

.gc-card-img-top {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 12px 12px 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: 12px 0 0 12px;
}

.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);
    transform: translateY(-4px);
}

.gc-card-clickable:active {
    transform: translateY(-2px);
}

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

.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 {
    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-карточек - фиксированные колонки */
.gc-cards-grid-weapons {
    grid-template-columns: repeat(3, 1fr); /* 3 колонки одинаковой ширины */
}

/* Ссылки в weapon-grid НЕ влияют на размер (карточка внутри ссылки) */
.gc-cards-grid-weapons > a {
    display: contents; /* Убираем ссылку из layout! */
    text-decoration: none;
}

.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-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}

.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);
}

.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: 1;
}

.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;
}

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

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

.gc-event-card {
    background: var(--bg-content-main);
    border: 1px solid var(--border-primary);
    border-radius: 12px;
    padding: var(--spacing-md);
    min-height: 100px;
    transition: all var(--transition-slow);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    width: 100%;
    min-width: 280px;
}

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

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

/* Activity Post Card - основная карточка поста
   Используется как обертка для постов в Activity Feed.
   Стили карточки минимальны, так как это контейнер для контента поста. */
.gc-card-activity-post {
    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(--border-primary);
    border-radius: 12px;
    padding: var(--spacing-md);
    display: flex;
    flex-direction: row;
    gap: 12px;
    transition: all var(--transition-fast);
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}

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

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

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

/* Время (мелко, серое) */
.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) {
    /* Для weapon-карточек на планшетах - 2 колонки */
    .gc-cards-grid-weapons {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .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: 12px 12px 0 0;
    }
    
    /* На мобильных 2 колонки для weapon-карточек */
    .gc-cards-grid-weapons {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .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;
    min-height: 420px;
    cursor: pointer;
}

.gc-card-briefing > a {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.gc-card-briefing:hover {
    box-shadow: var(--shadow-md);
    cursor: pointer;
}

/* Заголовок брифинга */
.gc-card-briefing .gc-card-title {
    transition: color var(--transition-fast);
}

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

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

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

.gc-briefing-img-container[onclick]:hover,
.gc-briefing-img-container[style*="cursor: pointer"]: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 {
    background: rgba(0, 0, 0, 0.4);
}

/* Заблюренный фон */
.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;
}

/* Основное изображение */
.gc-briefing-img {
    transition: filter var(--transition-slow);
    max-height: 100%;
    max-width: 100%;
    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-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;
    z-index: 2;
}

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

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

/* Контентная часть карточки брифинга 
   Использует utility классы: d-flex, flex-column, flex-1 */
.gc-card-briefing .gc-card-body {
    /* Только уникальные стили, flex-классы перенесены в HTML */
}

/* Описание брифинга (2 строки с ellipsis) */
.gc-briefing-description {
    display: -webkit-box;
    -webkit-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);
}

/* Элемент характеристики */
.gc-stat-item {
    padding: var(--spacing-sm) 0;
}

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

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

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

.gc-stat-value {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: var(--font-size-md);
    font-weight: 500;
    color: var(--font-primary);
}

/* Горизонтальное расположение в модале на десктопе */
@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(--border-primary);
        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
   ================================= */

/* Карточка контента брифинга */
.gc-stage-content-card {
    /* margin-bottom убран - управляется родителем catalog-main через gap */
}

/* Карточка этапов */
.gc-stage-sections-card {
    /* margin-bottom убран - управляется родителем catalog-main через gap */
}

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

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

/* Заголовок секций */
.gc-stage-sections-title {
    /* 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%;
    }
}

/* Секция заголовка - использует utility: flex-grow-1, me-3 */

/* Заголовок брифинга */
.gc-briefing-title-section .gc-card-title {
    font-size: var(--font-size-md);
    font-weight: 600;
    line-height: 1.3;
}

/* Блок счетчика выстрелов - использует utility: d-flex, flex-column, align-items-end, flex-shrink-0, text-end, ms-3 */

.gc-briefing-shots-count {
    font-size: var(--font-size-3xl);
    font-family: var(--font-family-heading);
    font-weight: bold;
    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);
}

/* Блок автора - использует utility: d-flex, align-items-center, mt-auto, pt-3 */

/* Аватар автора */
.gc-briefing-avatar {
    width: 40px;
    height: 40px;
    object-fit: cover;
    border-radius: var(--radius-full);
    border: 1px solid var(--border-primary);
}

/* Инфо автора - использует utility: flex-grow-1, overflow-hidden, me-2 */

.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-card-briefing {
        min-height: 380px; /* Уменьшенная высота на планшетах */
    }
    
    .gc-briefing-shots-count {
        font-size: var(--font-size-2xl);
    }
    
    .gc-briefing-img-container {
        padding-top: 50%; /* Соотношение 2:1 на мобильных */
    }
}

@media (max-width: 576px) {
    .gc-card-briefing {
        min-height: 340px; /* Еще более компактная на мобильных */
    }
    
    .gc-card-briefing .gc-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 {
    box-shadow: var(--shadow-md);
}

.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); /* Увеличен с 0.9375rem */
    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: var(--bg-content-main);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: all var(--transition-base);
    border: 1px solid var(--border-primary);
    display: flex;
    flex-direction: column;
    width: 100%; /* Явная ширина */
    height: 100%;
    box-sizing: border-box; /* Border не увеличивает ширину */
}

.weapon-card:hover {
    transform: translateY(-2px);
    background: var(--bg-content-secondary);
    border-color: var(--border-secondary);
}

.weapon-card-image {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9; /* Современный метод */
    background: var(--bg-content-secondary);
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.weapon-card-image img {
    width: 100%;
    height: 100%;
    object-fit: contain; /* Показываем всё изображение без обрезки */
}

.weapon-card-image img.is-icon-placeholder {
    object-fit: contain;
    width: 50%;
    height: 50%;
    opacity: 0.25;
    transition: filter var(--transition-base), opacity var(--transition-base);
}

/* Инверсия 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%;
}

.weapon-card:hover .weapon-card-image img.is-icon-placeholder {
    opacity: 0.35;
}

.weapon-card-badge {
    position: absolute;
    top: var(--spacing-2sm);
    right: var(--spacing-2sm);
    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: 0 2px 8px rgba(0, 0, 0, 0.15);
    backdrop-filter: blur(4px);
}

.weapon-card:hover .weapon-card-badge {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.weapon-card-body {
    padding: var(--spacing-md);
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.weapon-card-title {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--font-primary);
    margin: 0;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: var(--spacing-xs);
}

.weapon-card-subtitle {
    font-size: var(--font-size-xs);
    color: var(--font-secondary);
    line-height: 1.4;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* 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.03);
    transform: translateY(-2px);
}

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

.weapon-card-add .weapon-card-image i {
    font-size: 40px;
    color: var(--font-tertiary);
    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 var(--spacing-md) var(--spacing-md);
    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: 576px) {
    .weapon-card-body {
        padding: var(--spacing-md) var(--spacing-sm);
    }
    
    .weapon-card-title {
        font-size: var(--font-size-sm);
    }
    
    .weapon-card-subtitle {
        font-size: 11px;
    }
    
    .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;
}

/* Адаптивный grid для топ-3: первое место большое слева, 2-3 места справа */
.top3-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: minmax(240px, 1fr) minmax(240px, 1fr);
    gap: 0.5rem;
}

.top3-grid > div {
    min-width: 0; /* Позволяет элементам сжиматься в grid */
}

/* Первая карточка занимает 2 ряда */
.top3-grid > div:first-child {
    grid-row: span 2;
}

/* Вторая и третья карточки по одному ряду, одинаковой высоты */
.top3-grid > div:nth-child(2),
.top3-grid > div:nth-child(3) {
    grid-row: span 1;
}

/* На мобильных: топ-1 на всю ширину, топ-2 и 3 по 50% */
@media (max-width: 768px) {
    .top3-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: minmax(200px, auto) minmax(180px, auto);
    }
    
    .top3-grid > div:first-child {
        grid-column: 1 / -1;
        grid-row: span 1;
    }
    
    .top3-grid > div:nth-child(2),
    .top3-grid > div:nth-child(3) {
        grid-row: span 1;
    }
}

/* Карточки топ-3 */
.card-top {
    position: relative;
    overflow: hidden !important;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-xl) !important;
    transition: background 0.3s ease, border-color 0.3s ease;
    
    /* 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: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(--border-primary);
}

.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;
    }
}
