@layer pages {
/* Похожие товары — v4 2026-04-09
   ВАЖНО: стили карточки 1:1 с каталожной плиткой .pc (catalog.css).
   Единый визуал: фон, радиус, шрифты, blend-mode, shimmer. */

/* Выравниваем с .p-layout (var(--container-content)) */
.p-similar {
    max-width: var(--container-content);   /* H-1: 1200px → переменная */
    margin: 0 auto;
    /* UX-AUDIT FIX-1c: 6rem → 2rem — 96px пустоты была для bottom-nav, но
       bottom-nav скрыт на десктопе, а на мобилке используем --body-pb */
    padding: 1.5rem 20px 2rem;
}

.p-similar h2 {
    /* UX-AUDIT FIX-1d: Заголовок крупнее — 11px = невидимый.
       13px + uppercase = визуально ~15px, читаемый метка секции */
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--text-muted);
    /* AUDIT-4.4: 12→16px — "воздух" между заголовком и grid, не слипаются */
    margin: 0 0 1rem;
}

/* Mobile: горизонтальный scroll-snap */
.p-sim-grid {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: .25rem;
}

.p-sim-grid::-webkit-scrollbar { display: none; }

/* ── Карточка: 1:1 с .pc из catalog.css ───────────────────────────────────── */
.p-sim-card {
    /* Мобилка: ~2.3 карточки в ширину, хвостик всегда виден */
    flex: 0 0 calc((100vw - 40px - 10px) / 2.3);
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    /* Фон, радиус, тень — ровно как .pc */
    background: var(--card-muted);  /* UX-2.1: #e4e4e9d6→var(--card-muted) — dark mode */
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .07);
    transition: transform .18s, box-shadow .18s;
    position: relative; /* для ::before shimmer */
}

.p-sim-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .13);
}

.p-sim-card:active {
    transform: scale(0.98);
}

/* Shimmer: ::before покрывает зону фото (как .pc::before в catalog.css).
   ВАЖНО: shimmer на псевдо-элементе, img стартует с opacity:0 — без «сползания».
   Загрузилось → .loaded → плавный fade-in. */
.p-sim-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    aspect-ratio: 4 / 5;
    background: linear-gradient(90deg, var(--border) 25%, var(--card) 50%, var(--border) 75%);
    background-size: 200% 100%;
    animation: shimmer 1.4s infinite;
    pointer-events: none;
}

/* Фото: aspect-ratio 4:5, multiply, без bg — фон карточки просвечивает */
.p-sim-card img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: contain;
    mix-blend-mode: var(--blend-img); /* dark mode fix */
    color: transparent;
    position: relative; /* поверх ::before shimmer */
    opacity: 0;
    transition: opacity .35s ease;
}

/* Когда фото загружено — плавно проявляем */
.p-sim-card img.loaded {
    opacity: 1;
}

/* ВАЖНО: ::before убираем при .loaded — mix-blend-mode:multiply просвечивает волну сквозь белые области */
.p-sim-card:has(img.loaded)::before {
    display: none;
}

/* Название: font-size, clamp, padding — как .pc__name */
.p-sim-title {
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 12px;
    line-height: 1.45;
    color: var(--text);     /* UX-2.1: #333→var(--text) — dark mode */
    padding: 3px 10px 20px;
}

/* Цена: font-size, weight, padding — как .pc__price */
.p-sim-price {
    font-size: 15px;
    font-weight: 700;
    color: var(--price-color);  /* UX-2.1: #111→var(--price-color) — единый цвет цены с каталогом */
    letter-spacing: -0.3px;
    padding: 0 10px 10px;
}

/* ── Skeleton: shimmer до загрузки AJAX ───────────────────────────────────── */
/* UX-AUDIT FIX-1a: Skeleton для card content (фото + текст + цена) */
.p-sim-grid.is-loading .p-sim-card {
    height: auto;
    min-height: 200px;
    pointer-events: none;
}

/* UX-AUDIT FIX-1a: Skeleton с формой — показывает layout будущей карточки */
.p-sim-skel-img {
    width: 100%;
    aspect-ratio: 4 / 5;
    border-radius: 0;
    background: linear-gradient(90deg, var(--border) 25%, var(--card) 50%, var(--border) 75%);
    background-size: 200% 100%;
    animation: shimmer 1.4s infinite;
}
.p-sim-skel-text {
    margin: 10px 10px 4px;
    width: 70%;
    height: 12px;
    border-radius: 4px;
    background: linear-gradient(90deg, var(--border) 25%, var(--card) 50%, var(--border) 75%);
    background-size: 200% 100%;
    animation: shimmer 1.4s infinite;
    animation-delay: .1s;
}
.p-sim-skel-price {
    margin: 4px 10px 10px;
    width: 40%;
    height: 14px;
    border-radius: 4px;
    background: linear-gradient(90deg, var(--border) 25%, var(--card) 50%, var(--border) 75%);
    background-size: 200% 100%;
    animation: shimmer 1.4s infinite;
    animation-delay: .2s;
}

/* Stagger shimmer: "волна" слева направо */
.p-sim-grid.is-loading .p-sim-card:nth-child(1) .p-sim-skel-img { animation-delay: 0ms; }
.p-sim-grid.is-loading .p-sim-card:nth-child(2) .p-sim-skel-img { animation-delay: 100ms; }
.p-sim-grid.is-loading .p-sim-card:nth-child(3) .p-sim-skel-img { animation-delay: 200ms; }
.p-sim-grid.is-loading .p-sim-card:nth-child(4) .p-sim-skel-img { animation-delay: 300ms; }
.p-sim-grid.is-loading .p-sim-card:nth-child(5) .p-sim-skel-img { animation-delay: 400ms; }
.p-sim-grid.is-loading .p-sim-card:nth-child(6) .p-sim-skel-img { animation-delay: 500ms; }

/* Скрываем skeleton-элементы когда реальный контент загружен */
.p-similar.is-ready .p-sim-skel-img,
.p-similar.is-ready .p-sim-skel-text,
.p-similar.is-ready .p-sim-skel-price {
    display: none;
}

/* UX-3.4: @keyframes shimmer перенесён в common.css (подключается везде).
   ВАЖНО: удалено из prod-similar.css — используем общий из common.css */

/* Fade-in + slide-up при появлении */
.p-similar.is-ready .p-sim-grid {
    animation: sim-fadein .3s ease;
}

@keyframes sim-fadein {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: none; }
}

/* Ландшафт мобилки — bottom-nav скрыт, убираем лишний clearance */
@media (max-height: 450px) and (orientation: landscape) {
    .p-similar { padding-bottom: 2rem; }
}

/* Desktop ≥768px — grid вместо скролла */
@media (min-width: 768px) {
    .p-similar {
        padding-bottom: 3rem;
    }

    /* UX-AUDIT FIX-1b: minmax(160px) → больше карточек в ряду, меньше пустых слотов */
    .p-sim-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
        overflow-x: visible;
        gap: 10px;
    }

    .p-sim-card {
        flex: unset;
    }
}
} /* @layer pages */
