/* === ART-GSM: бейджи наличия товара (v2, дизайн-система) ===
   4-state: many / medium / low (vivid) / out
   State определяется JS-ом (stock-badges.js) по тексту внутри .item-stock,
   поскольку Aspro в HTML различает только .icon.stock/.icon.order.
   Версия: 2026-04-22c
*/

/* Базовая плашка-бейдж (применяется только после навешивания .is-badge JS-ом) */
.item-stock.is-badge {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    height: 26px !important;
    padding: 0 10px !important;
    margin: 2px 0 !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    letter-spacing: -0.005em !important;
    white-space: nowrap !important;
    vertical-align: middle !important;
    border: none !important;
    box-sizing: border-box !important;
    text-transform: none !important;
    font-variant: normal !important;
    font-variant-caps: normal !important;
    font-feature-settings: normal !important;
    transition: background-color .15s ease !important;
}

/* Скрываем родные точки — иконку рисуем отдельным <span class="item-stock__icon"> */
.item-stock.is-badge .icon {
    display: none !important;
}

/* Снимаем все Aspro-стили со вложенных спанов */
.item-stock.is-badge .value,
.item-stock.is-badge .store_view,
.item-stock.is-badge > span:not(.item-stock__icon) {
    border-bottom: none !important;
    text-decoration: none !important;
    color: inherit !important;
    font: inherit !important;
    font-weight: inherit !important;
    padding: 0 !important;
    margin: 0 !important;
    background: none !important;
    letter-spacing: inherit !important;
    text-transform: none !important;
    font-variant: normal !important;
    font-feature-settings: normal !important;
}

/* Страховка: первая буква заглавная, если Aspro вдруг шлёт lowercase */
.item-stock.is-badge .value::first-letter,
.item-stock.is-badge > span:not(.item-stock__icon)::first-letter {
    text-transform: uppercase !important;
}

/* --- States (normal intensity по умолчанию) --- */
.item-stock.is-state-many {
    background: #dcfce7 !important;
    color: #14532d !important;
}
.item-stock.is-state-medium {
    background: #ecfccb !important;
    color: #365314 !important;
}
/* low = vivid (макс. внимание к заканчивающимся позициям) */
.item-stock.is-state-low {
    background: #ea580c !important;
    color: #ffffff !important;
}
.item-stock.is-state-out {
    background: #e7e5e4 !important;
    color: #292524 !important;
}

/* Hover — чуть темнее */
.item-stock.is-state-many:hover   { background: #bbf7d0 !important; }
.item-stock.is-state-medium:hover { background: #d9f99d !important; }
.item-stock.is-state-low:hover    { background: #c2410c !important; }
.item-stock.is-state-out:hover    { background: #d6d3d1 !important; }

/* --- Иконка --- */
.item-stock__icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 12px !important;
    height: 12px !important;
    flex-shrink: 0 !important;
    color: currentColor !important;
}
.item-stock__icon svg {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
}

/* Pulse-анимация у "Заканчивается" — визуально подгоняет к покупке */
.item-stock.is-state-low .item-stock__icon {
    animation: itemStockPulse 1.8s ease-in-out infinite;
    transform-origin: center;
}
@keyframes itemStockPulse {
    0%, 100% { transform: scale(1);   opacity: 1;  }
    50%      { transform: scale(1.3); opacity: .65; }
}

/* --- На детальной странице — увеличенный размер (lg) --- */
.product-info .item-stock.is-badge,
#main .catalog_detail .item-stock.is-badge,
.product_detail .item-stock.is-badge {
    height: 32px !important;
    padding: 0 13px !important;
    font-size: 13px !important;
    gap: 7px !important;
}
.product-info .item-stock.is-badge .item-stock__icon,
#main .catalog_detail .item-stock.is-badge .item-stock__icon,
.product_detail .item-stock.is-badge .item-stock__icon {
    width: 14px !important;
    height: 14px !important;
}
