/* ============================================================
   Готовые сумки в роддом — витрина и карточка (Приоритет №1 ТЗ)
   Цвета/шрифты — через токены (Manrope, бренд #e0455a).
   ============================================================ */

.bags-page {
    max-width: var(--container-content);
    margin: 0 auto;
    padding: var(--space-8) var(--container-gutter) var(--space-9);
}

/* ── Интро ── */
.bags-intro { margin: 0 0 var(--space-7); }
.bags-intro__title {
    font-family: var(--font-display);
    font-weight: var(--font-weight-extrabold);
    font-size: clamp(28px, 3.4vw, 40px);
    letter-spacing: -0.02em;
    color: var(--color-text);
    margin: 0 0 10px;
}
.bags-intro__subtitle {
    font-size: var(--font-size-lg);
    color: var(--color-text);
    opacity: 0.6;
    margin: 0;
}

/* ── Сетка тарифов ── */
.bags-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
@media (max-width: 1080px) { .bags-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .bags-grid { grid-template-columns: 1fr; } }

.bag-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid var(--home-card-bd, #ececef);
    border-radius: var(--home-radius-lg, 22px);
    overflow: hidden;
    text-decoration: none;
    color: var(--color-text);
    transition: transform .15s, box-shadow .15s, border-color .15s;
}
.bag-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(60, 30, 40, 0.10);
    border-color: var(--color-primary-200, #f8c4cc);
}
.bag-card__media {
    position: relative;
    aspect-ratio: 4 / 3;
    background: var(--home-hero-bg, #fce9e6);
    display: grid;
    place-items: center;
    overflow: hidden;
}
.bag-card__media img { width: 60%; height: 60%; object-fit: contain; }
.bag-card__tier {
    position: absolute;
    top: 12px; left: 12px;
    padding: 5px 12px;
    background: var(--color-primary);
    color: #fff;
    border-radius: var(--radius-pill, 999px);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.3px;
}
.bag-card__body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 18px 20px 20px;
    flex: 1;
}
.bag-card__name {
    font-family: var(--font-display);
    font-weight: var(--font-weight-bold);
    font-size: 22px;
    margin: 0;
}
.bag-card__count { font-size: 13.5px; color: var(--color-text); opacity: 0.55; }
.bag-card__price {
    margin-top: auto;
    font-weight: var(--font-weight-extrabold);
    font-size: 24px;
    color: var(--color-primary);
}
.bag-card__price s { font-size: 0.6em; color: var(--grey-400, #9ca3af); font-weight: 400; margin-left: 6px; }
.bag-card__cta {
    margin-top: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 44px;
    border-radius: var(--radius-pill, 999px);
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    font-size: 14.5px;
    transition: background .15s;
}
.bag-card:hover .bag-card__cta { background: var(--color-primary-600, #c93a4d); }

/* ── Детальная страница сумки ── */
.bag-detail {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 36px;
    align-items: start;
}
@media (max-width: 860px) { .bag-detail { grid-template-columns: 1fr; gap: 24px; } }

.bag-detail__media {
    aspect-ratio: 1;
    background: var(--home-hero-bg, #fce9e6);
    border-radius: var(--home-radius-lg, 22px);
    display: grid;
    place-items: center;
    overflow: hidden;
}
.bag-detail__media img { width: 55%; height: 55%; object-fit: contain; }

.bag-detail__tier {
    display: inline-block;
    padding: 5px 14px;
    background: var(--color-primary);
    color: #fff;
    border-radius: var(--radius-pill, 999px);
    font-size: 12px;
    font-weight: 700;
    margin-bottom: 12px;
}
.bag-detail__title {
    font-family: var(--font-display);
    font-weight: var(--font-weight-extrabold);
    font-size: clamp(26px, 3vw, 36px);
    letter-spacing: -0.02em;
    margin: 0 0 8px;
}
.bag-detail__maternity {
    font-size: 14px;
    color: var(--color-text);
    opacity: 0.6;
    margin: 0 0 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.bag-detail__desc { font-size: 15px; line-height: 1.5; color: var(--color-text); margin: 0 0 18px; }
.bag-detail__price {
    font-weight: var(--font-weight-extrabold);
    font-size: 32px;
    color: var(--color-primary);
    margin: 0 0 4px;
}
.bag-detail__count { font-size: 14px; opacity: 0.6; margin: 0 0 20px; }

/* Состав */
.bag-comp { margin: 0 0 24px; }
.bag-comp__title {
    font-family: var(--font-display);
    font-weight: var(--font-weight-bold);
    font-size: 18px;
    margin: 0 0 12px;
}
.bag-comp__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.bag-comp__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 11px 0;
    border-bottom: 1px solid var(--color-neutral-100, #efefef);
    font-size: 14.5px;
}
.bag-comp__item:last-child { border-bottom: none; }
.bag-comp__item-name { color: var(--color-text); }
.bag-comp__item-qty { color: var(--color-text); opacity: 0.5; font-size: 13px; margin-left: 6px; }
.bag-comp__item-price { color: var(--color-text); opacity: 0.7; white-space: nowrap; font-weight: 500; }

/* Кнопки действий */
.bag-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.bag-actions .btn { flex: 1 1 auto; min-width: 200px; }
.bag-btn-wa {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    height: 52px;
    padding: 0 24px;
    border-radius: var(--radius-pill, 999px);
    background: #25D366;
    color: #fff;
    font-weight: 600;
    font-size: 15px;
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: background .15s;
    flex: 1 1 auto;
    min-width: 200px;
}
.bag-btn-wa:hover { background: #1ebe5b; }
.bag-btn-wa svg { width: 22px; height: 22px; fill: currentColor; }

/* ============================================================
   Конструктор «Собери свою сумку» (ТЗ #4)
   ============================================================ */
.builder { display: grid; grid-template-columns: 1fr 380px; gap: 28px; align-items: start; }
@media (max-width: 920px) { .builder { grid-template-columns: 1fr; } }

/* Поиск товаров */
.builder__search {
    display: flex; align-items: center; gap: 10px;
    height: 48px; padding: 0 18px; margin: 0 0 18px;
    background: var(--color-neutral-100, #efefef);
    border-radius: var(--radius-pill, 999px);
}
.builder__search input { flex: 1; border: none; background: transparent; outline: none; font: 500 14px var(--font-sans); color: var(--color-text); }
.builder__search svg { width: 20px; height: 20px; opacity: .5; }

/* Сетка товаров-кандидатов */
.builder__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 1200px) { .builder__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .builder__grid { grid-template-columns: repeat(2, 1fr); } }

.builder__item {
    display: flex; flex-direction: column; gap: 8px;
    border: 1px solid var(--home-card-bd, #ececef); border-radius: 14px; padding: 12px;
    background: #fff;
}
.builder__item-media { aspect-ratio: 1; border-radius: 10px; overflow: hidden; background: var(--color-neutral-100, #efefef); }
.builder__item-media img { width: 100%; height: 100%; object-fit: cover; }
.builder__item-name { font-size: 13.5px; line-height: 1.3; min-height: 35px; }
.builder__item-price { font-weight: 800; color: var(--color-primary); font-size: 16px; }
.builder__add {
    margin-top: auto; height: 38px; border: 1.5px solid var(--color-primary); border-radius: 10px;
    background: transparent; color: var(--color-primary); font-weight: 600; font-size: 13.5px; cursor: pointer;
    transition: background .15s, color .15s;
}
.builder__add:hover { background: var(--color-primary); color: #fff; }

/* Виртуальная сумка (правая панель) */
.builder__bag {
    position: sticky; top: 16px;
    border: 1px solid var(--home-card-bd, #ececef); border-radius: var(--home-radius-lg, 22px);
    padding: 20px; background: #fff;
}
.builder__bag-title { font-family: var(--font-display); font-weight: 800; font-size: 20px; margin: 0 0 14px; }
.builder__bag-empty { color: var(--color-text); opacity: .5; font-size: 14px; padding: 20px 0; text-align: center; }
.builder__bag-list { list-style: none; padding: 0; margin: 0 0 16px; display: flex; flex-direction: column; }
.builder__row { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--color-neutral-100, #efefef); }
.builder__row:last-child { border-bottom: none; }
.builder__row-name { flex: 1; font-size: 13.5px; line-height: 1.25; }
.builder__row-price { font-weight: 600; font-size: 13.5px; white-space: nowrap; }
.builder__qty { display: inline-flex; align-items: center; gap: 8px; }
.builder__qty button {
    width: 26px; height: 26px; border-radius: 7px; border: 1px solid var(--color-neutral-200, #e5e5e5);
    background: #fff; cursor: pointer; font-size: 16px; line-height: 1; color: var(--color-text);
}
.builder__qty button:hover { border-color: var(--color-primary); color: var(--color-primary); }
.builder__qty span { min-width: 18px; text-align: center; font-weight: 600; font-size: 13px; }
.builder__remove { background: none; border: none; cursor: pointer; color: #b8b8c0; font-size: 18px; line-height: 1; padding: 2px; }
.builder__remove:hover { color: var(--color-primary); }

.builder__total { display: flex; justify-content: space-between; align-items: baseline; margin: 6px 0 16px; }
.builder__total-label { font-size: 14px; opacity: .6; }
.builder__total-val { font-family: var(--font-display); font-weight: 800; font-size: 26px; color: var(--color-primary); }
.builder__actions { display: flex; flex-direction: column; gap: 10px; }
.builder__actions .btn { width: 100%; }

/* ── Фильтр сумок (ТЗ #2) ── */
.bags-filters {
    display: flex; flex-wrap: wrap; gap: 10px;
    margin: 0 0 24px;
}
.bags-filter {
    padding: 9px 16px;
    border: 1.5px solid var(--color-neutral-200, #e5e5e5);
    background: #fff;
    border-radius: var(--radius-pill, 999px);
    font: 600 13.5px var(--font-sans);
    color: var(--color-text);
    cursor: pointer;
    transition: background .15s, color .15s, border-color .15s;
}
.bags-filter:hover { border-color: var(--color-primary); color: var(--color-primary); }
.bags-filter.is-active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
