/* Стили компонента item_card — базовые + витрина.
   Загружается всегда (Tier 1). Офисные override — card_office.css. */

.item-card {
    background: linear-gradient(135deg, var(--panel-bg-start) 0%, var(--panel-bg-end) 100%);
    border: 2px solid var(--tg-theme-section-separator-color);
    border-radius: var(--border-radius);
    overflow: hidden;
    margin-bottom: var(--spacing-sm);
    margin-left: var(--spacing-xs);
    margin-right: var(--spacing-xs);
    position: relative;
    box-sizing: border-box;
}

/* Убираем отступы, если карточка лежит внутри блока */
.block .item-card {
    margin-left: 0;
    margin-right: 0;
}

/* Overlay-ссылка: невидимая, покрывает всю карточку */
.item-card__card-link {
    position: absolute;
    inset: 0;
    z-index: 0;
}

/* Flex-строка карточки: фото + контент */
.item-card__row {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs);
    width: 100%;
}

.item-card__image-wrapper {
    width: 100px;
    height: 60px;
    /* Пропорция 5:3 */
    border-radius: var(--border-radius-sm);
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--tg-theme-secondary-bg-color, #f0f0f0);
}

.item-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.item-card__placeholder {
    font-size: 24px;
    line-height: 1;
}

.item-card__content {
    flex: 1;
    min-width: 0;
}

.item-card__title {
    margin: 0;
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--tg-theme-text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.25;
}

/* Контактная ссылка (telegram): z-index выше overlay */
.item-card__contact-link {
    display: block;
    font-size: var(--font-size-sm);
    color: var(--tg-theme-link-color, #2481cc);
    text-decoration: none;
    margin-top: 1px;
    line-height: 1.35;
    position: relative;
    z-index: 1;
}

/* Контактный текст (телефон без ссылки) */
.item-card__contact {
    display: block;
    font-size: var(--font-size-sm);
    color: var(--tg-theme-hint-color);
    margin-top: 1px;
    line-height: 1.35;
}

.item-card__info-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 2px;
}

.item-card__subtitle {
    font-size: var(--font-size-sm);
    font-weight: 300;
    color: var(--tg-theme-hint-color);
    line-height: 1.35;
}

.item-card__status {
    font-size: var(--font-size-sm);
    font-weight: 300;
    line-height: 1.35;
    padding: 1px 6px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.1);
}

.item-card__price {
    font-weight: 500;
    color: var(--tg-theme-text-color);
    font-size: var(--font-size-base);
}

.item-card__badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 500;
    padding: 1px 8px;
    border-radius: 10px;
    line-height: 1.4;
}

.item-card__badge--approval {
    background: rgba(255, 170, 0, 0.15);
    color: #e6a200;
}

/* Футер: статусы, цена, кнопки — во всю ширину карточки */
.item-card__footer {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    padding: var(--spacing-xs);
    border-top: 1px solid var(--tg-theme-section-separator-color);
    position: relative;
    z-index: 1;
}

/* Кнопка действия в футере */
.item-card__action-btn {
    padding: 5px 14px;
    border-radius: 14px;
    border: none;
    font-size: var(--font-size-sm);
    font-weight: 500;
    cursor: pointer;
    position: relative;
    z-index: 1;
    background: var(--tg-theme-button-color, #3390ec);
    color: var(--tg-theme-button-text-color, #fff);
}

/* Витринный override */
.item-card--vitrine {
    /* Витрина не добавляет специфики поверх базы */
}
