/* ===== Compare unified scroll v7 ===== */
:root {
    --cmp-sticky-top: 0px;
}

.cmp {
    --cmp-radius: 12px;
    --cmp-border: #e5e5e5;
    --cmp-muted: #6b7280;
    --cmp-muted2: #9ca3af;
    --cmp-line: #f0f0f0;
    --cmp-bg-alt: #f9fafb;
    --cmp-diff: #fff5eb;

    --cmp-col-width: 220px;
}

/* контейнер/топбар */
.cmp.container {
    width: 100%;
    max-width: 1248px;
    margin: 24px auto 40px;
    padding: 20px 16px 32px;
    box-sizing: border-box;
    background: #fff;
    border-radius: var(--cmp-radius);
    box-shadow: 0 4px 20px rgba(0, 0, 0, .04);
}

.cmp__bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
}

.switch {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    user-select: none;
    font-size: 14px;
    color: var(--cmp-muted);
}

.switch input {
    accent-color: #111;
}

.chips {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
}

.chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border: 1px solid #e6e6e6;
    border-radius: 999px;
    background: #fff;
    color: #111;
    text-decoration: none;
    font-size: 13px;
    line-height: 1.2;
}

.chip.is-active {
    background: #111;
    color: #fff;
    border-color: #111;
}

.chip__count {
    opacity: .65;
    font-size: 12px;
}

/* ===== ОБЩИЙ КОНТЕЙНЕР КАРТОЧКИ+ТАБЛИЦА ===== */
.cmp-table-wrap {
    position: relative;
    border-radius: var(--cmp-radius);
    border: 1px solid var(--cmp-border);
    overflow: hidden;
}

/* горизонтальный скролл */
.cmp__scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    scrollbar-gutter: stable both-edges;
    background: #fff;
}

.cmp__scroll::-webkit-scrollbar {
    height: 8px;
}

.cmp__scroll::-webkit-scrollbar-track {
    background: #f3f4f6;
}

.cmp__scroll::-webkit-scrollbar-thumb {
    background: #d1d5db;
    border-radius: 999px;
}

/* внутренняя обёртка */
.cmp-scroll-inner {
    width: max-content;
    padding: 12px 0 16px;
    box-sizing: border-box;
    margin-left: -1px;
    /* убираем лишнюю колонку слева */
}

/* ===== ВЕРХНИЕ КАРТОЧКИ ===== */
.cmp-cards {
    display: flex;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--cmp-line);
}

.cmp-card {
    position: relative;
    z-index: 1;
    /* ниже label */
    flex: 0 0 var(--cmp-col-width);
    border-right: 1px solid #e5e5e5;
    padding: 12px 12px 14px;
    background: #fff;
    text-align: center;
    box-sizing: border-box;
}

.cmp-card:last-child {
    border-right: 0;
}

/* первая карточка (над "Характеристика") */
.cmp-card--label {
    position: sticky;
    left: 0;
    z-index: 10;
    /* поверх остальных карточек */
    flex: 0 0 var(--cmp-col-width);
    padding: 0;
    border-right: 1px solid var(--cmp-line);
    background: #fff;
    box-shadow: none;
}

/* ВАЖНО: НЕ скрываем карточку, она просто уезжает под label */
/* .cmp-card.is-off-left { ... } — ЭТОГО ПРАВИЛА НЕТ */

.cmp-card__img {
    margin-bottom: 8px;
}

.cmp-card__name {
    margin-top: 4px;
}

.cmp-card__price {
    margin-top: 4px;
}

.cmp-card__rm {
    margin-top: 6px;
}

/* картинка товара */
.cmp-product__img {
    display: block;
    width: 160px;
    height: 160px;
    margin: 0 auto 8px;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 1px 8px rgba(0, 0, 0, .05);
    overflow: hidden;
}

.cmp-product__img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.cmp-product__img .ph {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cmp-muted2);
    font-size: 13px;
}

.cmp-product__name {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-weight: 600;
    color: #111;
    text-decoration: none;
    line-height: 1.15;
    min-height: 2.3em;
    margin: 2px 0;
}

.cmp-product__price {
    font-weight: 700;
    margin-top: 4px;
}

.cmp-product__rm {
    display: inline-block;
    margin-top: 6px;
    font-size: 13px;
    color: #c00;
    text-decoration: none;
}

/* ===== ТАБЛИЦА ===== */
.cmp-table {
    border-collapse: collapse;
    border-spacing: 0;
    width: max-content;
    min-width: 100%;
    font-size: 14px;
    background: #fff;
}

.cmp-table th,
.cmp-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--cmp-line);
    border-right: 1px solid var(--cmp-line);
    vertical-align: top;
}

.cmp-table th:last-child,
.cmp-table td:last-child {
    border-right: 0;
}

/* шапка */
.cmp-table thead th {
    position: sticky;
    top: var(--cmp-sticky-top);
    z-index: 1;
    background: #fff;
    text-align: center;
}

/* первый столбец */
.cmp-col-name {
    text-align: left;
    width: var(--cmp-col-width);
    min-width: var(--cmp-col-width);
    max-width: var(--cmp-col-width);
    position: sticky;
    left: 0;
    z-index: 8;
    background: #f9fafb;
    font-size: 13px;
    color: var(--cmp-muted);
}

/* товарные колонки */
.cmp-col-product {
    width: var(--cmp-col-width);
    min-width: var(--cmp-col-width);
    max-width: var(--cmp-col-width);
    position: relative;
    z-index: 1;
    /* под первой колонкой */
}

/* КОГДА КОЛОНКА ПОЛНОСТЬЮ УШЛА ВЛЕВО — НАЗВАНИЕ ПРЯЧЕМ */
.cmp-col-product.is-off-left {
    visibility: hidden;
}

/* строки / первый столбец */
.cmp-row-name {
    position: sticky;
    left: 0;
    z-index: 7;
    background: #f7f7f7;
    font-weight: 500;
    max-width: var(--cmp-col-width);
    min-width: var(--cmp-col-width);
    color: #111;
}

.cmp-table tbody tr:nth-child(odd) .cmp-row-name {
    background: #f3f4f6;
}

/* значения */
.cmp-cell {
    min-width: calc(var(--cmp-col-width) - 40px);
    color: #111;
    word-break: break-word;
}

.cmp-cell:empty::before {
    content: '—';
    color: var(--cmp-muted2);
}

/* подсветка различий */
.cmp-table tbody tr[data-row]:not(.is-equal) td.cmp-cell {
    background: var(--cmp-diff);
}

.cmp-table tbody tr[data-row]:not(.is-equal):nth-child(odd) td.cmp-cell {
    background: #ffeede;
}

.cmp-table tbody tr.is-equal td.cmp-cell {
    opacity: .7;
}

/* ===== СТРЕЛКИ ПРОКРУТКИ ===== */
.cmp__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 999px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, .08);
    cursor: pointer;
    z-index: 20;
    font-size: 0;
    transition: opacity .15s ease, box-shadow .15s ease;
}

.cmp__nav:before {
    content: '';
    width: 10px;
    height: 10px;
    border-right: 2px solid #111;
    border-bottom: 2px solid #111;
    transform: rotate(135deg);
    /* стрелка влево */
}

/* правая стрелка */
.cmp__nav--next:before {
    transform: rotate(-45deg);
    /* стрелка вправо */
}

.cmp__nav--prev {
    left: 12px;
}

.cmp__nav--next {
    right: 12px;
}

/* при disabled стрелка видима, но не кликается */
.cmp__nav:disabled {
    opacity: .35;
    pointer-events: none;
    box-shadow: none;
}

/* мягкие края */
.edge {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 24px;
    pointer-events: none;
    z-index: 4;
    transition: opacity .15s ease;
}

.edge--left {
    left: 0;
    background: linear-gradient(to right, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
}

.edge--right {
    right: 0;
    background: linear-gradient(to left, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
}

/* анти-конфликты */
.cmp-table,
.cmp-table * {
    box-sizing: border-box;
}

/* адаптив */
@media (max-width: 900px) {
    .cmp.container {
        padding-inline: 12px;
    }

    .cmp-product__img {
        width: 130px;
        height: 130px;
    }

    .cmp-row-name,
    .cmp-col-name {
        min-width: 180px;
        max-width: 220px;
    }
}

