/* === СЕКЦИИ === */
.collection-row {
    display: flex; flex-direction: column; gap: 14px;
}

/* Заголовок */
.collection-title {
    width: 100%; margin: 0; padding: 8px 0; text-align: center;
    font-family: 'Orbitron', sans-serif; font-size: 20px; font-weight: 700; letter-spacing: 2px;
    background: linear-gradient(
        180deg,
        color-mix(in oklab, var(--bg-elev) 90%, #000 10%) 0%,
        color-mix(in oklab, var(--bg-elev) 80%, #000 20%) 100%
    );
    border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
    color: var(--accent);
    text-shadow: 0 0 6px rgba(0, 179, 255, 0.6), 0 0 14px rgba(0, 179, 255, 0.3);
}

/* Сетка каталога */
.catalog {
    margin-top: 20px;
    display: grid; grid-template-columns: 1fr; gap: 36px; padding: 0;
}

/* Карусель */
.card-carousel {
    display: grid;
    grid-auto-flow: column;
    grid-template-rows: repeat(3, 1fr);
    grid-auto-columns: 85%;
    /* 💡 ИСПРАВЛЕНО: Разрешаем горизонтальный скролл */
    overflow-x: scroll; 
    overflow-y: hidden;
    gap: var(--gap); padding: 0 14px;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.card-carousel::-webkit-scrollbar { display: none; }

/* Карточка */
.card-carousel .card {
    background: var(--card); border: 1px solid var(--border);
    border-radius: var(--radius); height: 72px;
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 14px; position: relative; overflow: hidden; cursor: pointer;
    color: var(--text); font-size: 16px;
}
.card.placeholder {
    justify-content: center; color: var(--muted); font-size: 14px; padding: 0;
}

/* Медиа */
.card-media { position: relative; flex-shrink: 0; margin-right: var(--gap); }
.card-icon {
    width: 52px; height: 52px; object-fit: cover; border-radius: 12px;
    border: 1px solid color-mix(in oklab, var(--border) 50%, transparent);
}

/* Инфо */
.card-info { flex-grow: 1; min-width: 0; }

/* ✅ Название теперь в 2 строки, не ломает кнопку */
.card-info h3 {
    margin: 0;
    line-height: 1.25;
    display: -webkit-box;
    -webkit-line-clamp: 2; /* ✅ ПОЗВОЛЯЕМ ДВЕ СТРОКИ */
    -webkit-box-orient: vertical;
    overflow: hidden;
    max-width: 100%;
}

.card-info .meta { margin: 0; line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* CTA */
.card-cta {
    flex-shrink: 0;
    height: 30px;
    padding: 0 14px;
    border-radius: 9px;
    margin-left: var(--gap);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 700; text-decoration: none;
    background: var(--bg-elev); border: 1px solid var(--border); color: var(--accent);
    cursor: pointer; transition: background .2s ease;
    max-width: 90px; /* ✅ фиксируем кнопку, не растягивается */
    white-space: nowrap; /* текст не ломается */
}
.card-cta:active { background: color-mix(in oklab, var(--bg-elev) 80%, #000 20%); }

/* Бейдж */
.card-badge {
    position: absolute; top: -4px; right: -4px;
    font-size: 9px; font-weight: 700; color: var(--bg); background-color: var(--accent);
    padding: 2px 6px; border-radius: 6px; z-index: 2; box-shadow: 0 0 6px rgba(0, 179, 255, 0.6);
}

/* Кнопка "Смотреть все" */
.view-all-btn {
    margin: 6px auto 0 auto;
    background: linear-gradient(90deg, var(--accent), #00e0ff);
    border: none; color: #001018; font-weight: 700; border-radius: 12px; padding: 9px 20px;
    font-size: 15px; cursor: pointer; box-shadow: 0 0 12px rgba(0, 179, 255, 0.45);
    transition: transform .25s ease, box-shadow .25s ease;
}
.view-all-btn:hover { transform: scale(1.05); box-shadow: 0 0 20px rgba(0, 179, 255, 0.65); }

/* Десктоп */
@media (min-width: 521px) {
    .card-carousel {
        grid-template-rows: repeat(3, 1fr);
        grid-auto-flow: unset; grid-auto-columns: unset; 
        overflow-x: unset; /* 💡 ИСПРАВЛЕНО: Убираем скрытие скролла */
        grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    }
}
