/* ============================================================================
   shop.css — Cửa hàng sản phẩm (marketplace + chi tiết)
   Token-only. KHÔNG hardcode hex. Dùng chung cho /pricing (listing) + /san-pham (detail).
   ============================================================================ */

.shop { background: var(--color-bg); color: var(--color-text); padding: var(--space-8) 0 var(--space-12); }
.shop__wrap { max-width: var(--page-w, 1140px); margin: 0 auto; padding: 0 var(--space-4); }

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.shop-hero { text-align: center; max-width: 720px; margin: 0 auto var(--space-6); }
.shop-hero__mascot {
    height: 68px; width: auto; display: block; margin: 0 auto var(--space-2);
    padding: 8px; border-radius: var(--radius-pill);
    background: var(--color-primary-soft);
}
.shop-hero__eyebrow {
    display: inline-flex; align-items: center; gap: 7px; padding: 5px 13px;
    background: var(--color-primary-soft); color: var(--color-primary);
    border-radius: var(--radius-pill); font-size: var(--fs-small); font-weight: var(--fw-bold);
    margin-bottom: var(--space-3);
}
.shop-hero__title {
    font-size: clamp(25px, 3.6vw, 34px); font-weight: var(--fw-extrabold);
    color: var(--color-ink); letter-spacing: -.025em; line-height: 1.18; margin: 0 auto var(--space-3);
    max-width: 18ch; text-wrap: balance;
}
.shop-hero__title em { font-style: normal; color: var(--color-primary); }
.shop-hero__lead { color: var(--color-muted); font-size: var(--fs-body); line-height: var(--lh-normal); margin: 0 auto; max-width: 580px; text-wrap: balance; }
.shop-hero__lead strong { color: var(--color-ink); font-weight: var(--fw-extrabold); }
.shop-hero__trust { display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; margin-top: var(--space-5); font-size: 12.5px; color: var(--color-text); }
.shop-hero__trust span {
    display: inline-flex; align-items: center; gap: 6px; font-weight: var(--fw-semibold);
    padding: 6px 12px; background: var(--color-surface);
    border: 1px solid var(--color-border); border-radius: var(--radius-pill);
    box-shadow: var(--shadow-sm);
}
.shop-hero__trust i { color: var(--color-secondary); font-size: 12px; }

.shop-switch {
    display: flex; justify-content: center; gap: 6px; width: fit-content;
    margin: 0 auto var(--space-5); padding: 5px;
    background: var(--color-surface); border: 1px solid var(--color-border);
    border-radius: var(--radius-md); box-shadow: var(--shadow-sm);
}
.shop-switch a {
    display: inline-flex; align-items: center; justify-content: center; gap: 7px;
    min-height: 38px; padding: 0 14px; border-radius: var(--radius-sm);
    color: var(--color-muted); text-decoration: none; font-size: 13px; font-weight: var(--fw-bold);
}
.shop-switch a:hover { color: var(--color-primary); background: var(--color-primary-soft); }
.shop-switch a.is-active { color: var(--color-on-dark); background: var(--color-primary); }

.shop-collections {
    display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-3); margin-bottom: var(--space-6);
}
.shop-collection {
    display: flex; gap: 12px; align-items: flex-start;
    min-height: 112px; padding: var(--space-4);
    background: var(--color-surface); border: 1px solid var(--color-border);
    border-radius: var(--radius-lg); color: inherit; text-decoration: none;
    transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.shop-collection:hover,
.shop-collection.is-active {
    border-color: color-mix(in srgb, var(--color-primary) 45%, var(--color-border));
    box-shadow: var(--shadow-sm); transform: translateY(-2px);
}
.shop-collection__icon {
    width: 38px; height: 38px; flex: 0 0 38px; border-radius: var(--radius-md);
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--color-primary-soft); color: var(--color-primary);
}
.shop-collection__body { min-width: 0; display: flex; flex-direction: column; gap: 5px; }
.shop-collection__top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.shop-collection__top strong { font-size: 14px; color: var(--color-ink); }
.shop-collection__top em {
    flex: 0 0 auto; font-style: normal; min-width: 24px; height: 24px; padding: 0 7px;
    border-radius: var(--radius-pill); display: inline-flex; align-items: center; justify-content: center;
    background: var(--color-soft); color: var(--color-primary); font-size: 12px; font-weight: var(--fw-extrabold);
}
.shop-collection__body > span:last-child { font-size: 12.5px; line-height: 1.45; color: var(--color-muted); }
@media (max-width: 960px) { .shop-collections { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) {
    .shop-switch { width: 100%; }
    .shop-switch a { flex: 1; padding-inline: 8px; }
    .shop-collections { grid-template-columns: 1fr; }
}

/* ── Owned banner ─────────────────────────────────────────────────────────── */
.shop-owned {
    display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap;
    max-width: 860px; margin: 0 auto var(--space-5); padding: var(--space-3) var(--space-4);
    background: var(--color-secondary-soft);
    border: 1px solid color-mix(in srgb, var(--color-secondary) 30%, transparent);
    border-radius: var(--radius-lg);
}
.shop-owned i { color: var(--color-secondary); font-size: 18px; }
.shop-owned__body { flex: 1; min-width: 200px; font-size: var(--fs-small); color: var(--color-text); }
.shop-owned__body strong { color: var(--color-ink); font-weight: var(--fw-bold); }
.shop-owned__tags { display: flex; gap: 6px; flex-wrap: wrap; }
.shop-owned__tag { padding: 3px 10px; background: var(--color-surface); border: 1px solid color-mix(in srgb, var(--color-secondary) 40%, transparent); border-radius: var(--radius-pill); font-size: 11.5px; font-weight: var(--fw-bold); color: var(--color-secondary); }

/* ── Toolbar: search + chips ──────────────────────────────────────────────── */
.shop-toolbar { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-6); }
.shop-search { position: relative; max-width: 520px; margin: 0 auto; width: 100%; }
.shop-search input {
    width: 100%; height: 46px; padding: 0 44px 0 44px;
    border: 1px solid var(--color-border); border-radius: var(--radius-md);
    background: var(--color-surface); color: var(--color-text);
    font-size: var(--fs-body); font-family: inherit; transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.shop-search input:focus { outline: none; border-color: var(--color-primary); box-shadow: var(--shadow-focus); }
.shop-search__ic { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--color-muted); font-size: 14px; }
.shop-search__clear { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: var(--color-muted); background: none; border: 0; cursor: pointer; font-size: 14px; }

.shop-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
.shop-chip {
    display: inline-flex; align-items: center; gap: 7px; padding: 8px 16px;
    background: var(--color-surface); border: 1px solid var(--color-border);
    border-radius: var(--radius-md); font-size: var(--fs-small); font-weight: var(--fw-bold);
    color: var(--color-text); cursor: pointer; text-decoration: none;
    transition: all var(--dur-fast) var(--ease); font-family: inherit;
}
.shop-chip:hover { border-color: var(--color-primary); color: var(--color-primary); }
.shop-chip.is-active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-on-dark); }
.shop-chip i { font-size: 12px; }
.shop-chip__count { font-size: 11px; font-weight: var(--fw-semibold); opacity: .75; }
.shop-chip.is-active .shop-chip__count { opacity: .9; }

/* ── Result bar ───────────────────────────────────────────────────────────── */
.shop-resultbar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap; margin-bottom: var(--space-4); }
.shop-resultbar__count { font-size: var(--fs-small); color: var(--color-muted); }
.shop-resultbar__count strong { color: var(--color-ink); font-weight: var(--fw-extrabold); font-size: var(--fs-body); }
.shop-resultbar__reset { display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-small); font-weight: var(--fw-semibold); color: var(--color-muted); text-decoration: none; padding: 5px 12px; border: 1px solid var(--color-border); border-radius: var(--radius-pill); transition: all var(--dur-fast) var(--ease); }
.shop-resultbar__reset:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ── Grid ─────────────────────────────────────────────────────────────────── */
.shop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); align-items: stretch; }
@media (max-width: 960px) { .shop-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .shop-grid { grid-template-columns: 1fr; max-width: 440px; margin-inline: auto; } }

/* ── Product card ─────────────────────────────────────────────────────────── */
.shop-card {
    background: var(--color-surface); border: 1px solid var(--color-border);
    border-radius: var(--radius-lg); overflow: hidden; position: relative;
    display: flex; flex-direction: column;
    transition: box-shadow var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.shop-card:hover { border-color: color-mix(in srgb, var(--color-primary) 45%, var(--color-border)); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.shop-card--featured { border: 1px solid var(--color-primary); }

/* "Bán chạy" ribbon header (featured) */
.shop-card__pop {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    padding: 7px; background: var(--color-primary); color: var(--color-on-dark);
    font-size: 11px; font-weight: var(--fw-extrabold); letter-spacing: .05em; text-transform: uppercase;
}
.shop-card__pop i { font-size: 11px; }

.shop-card__media { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--color-soft); }
.shop-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.shop-card__media--ph { display: flex; align-items: center; justify-content: center; }
.shop-card__media--ph i { font-size: 44px; color: var(--color-on-dark); opacity: .92; }
/* placeholder theo danh mục */
.shop-ph--ielts { background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)); }
.shop-ph--toeic { background: linear-gradient(135deg, var(--color-accent), var(--color-accent-deep)); }
.shop-ph--foundation { background: linear-gradient(135deg, var(--color-secondary), var(--color-secondary-hover)); }
.shop-ph--shadowing { background: linear-gradient(135deg, var(--color-warning), var(--color-warning-deep)); }
.shop-ph--combo { background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); }
.shop-ph--vocab { background: linear-gradient(135deg, var(--color-accent), var(--color-secondary)); }
.shop-ph--communication { background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); }
.shop-ph--roadmap { background: linear-gradient(135deg, var(--color-ink), var(--color-primary)); }
.shop-ph--ebook { background: linear-gradient(135deg, var(--color-warning), var(--color-accent)); }
.shop-ph--other { background: linear-gradient(135deg, var(--color-locked), var(--color-locked-deep)); }

.shop-card__badge {
    position: absolute; top: 10px; left: 10px; padding: 4px 11px;
    background: var(--color-ink); color: var(--color-on-dark); border-radius: var(--radius-sm);
    font-size: 11px; font-weight: var(--fw-extrabold); letter-spacing: .02em; box-shadow: var(--shadow-sm);
}
.shop-card--featured .shop-card__badge { background: var(--color-primary); }
.shop-card__owned-flag { position: absolute; top: 10px; right: 10px; padding: 4px 10px; background: var(--color-secondary); color: var(--color-on-dark); border-radius: var(--radius-sm); font-size: 11px; font-weight: var(--fw-bold); }

.shop-card__body { padding: var(--space-4); display: flex; flex-direction: column; gap: 8px; flex: 1; }
.shop-card__cat { font-size: 11px; font-weight: var(--fw-extrabold); letter-spacing: .06em; text-transform: uppercase; color: var(--color-primary); }
.shop-card__name { font-size: 16px; font-weight: var(--fw-extrabold); color: var(--color-ink); margin: 0; letter-spacing: -.015em; line-height: 1.3;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.shop-card__name a { color: inherit; text-decoration: none; }
.shop-card__name a:hover { color: var(--color-primary); }
.shop-card__desc { font-size: 13px; color: var(--color-muted); line-height: 1.5; margin: 0;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.shop-card__access { display: flex; flex-wrap: wrap; gap: 6px; }
.shop-card__access span {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 9px; border-radius: var(--radius-sm);
    background: var(--color-primary-soft); color: var(--color-primary);
    font-size: 11.5px; font-weight: var(--fw-bold);
}
.shop-card__access i { font-size: 10px; }

.shop-card__price { display: flex; align-items: baseline; flex-wrap: wrap; gap: 4px 8px; margin-top: auto; padding-top: var(--space-3); }
.shop-card__price-num { font-size: 22px; font-weight: var(--fw-extrabold); color: var(--color-ink); letter-spacing: -.02em; }
.shop-card__price-orig { font-size: 14px; color: var(--color-mute2); text-decoration: line-through; }
.shop-card__price-period { font-size: 12px; color: var(--color-muted); font-weight: var(--fw-semibold); margin-left: -4px; }
.shop-card__price-off { padding: 2px 8px; background: var(--color-warning-soft); color: var(--color-warning-deep); border-radius: var(--radius-sm); font-size: 11.5px; font-weight: var(--fw-extrabold); }

.shop-card__foot { padding: 0 var(--space-4) var(--space-4); display: flex; gap: 8px; }

/* ── Buttons (storefront) ─────────────────────────────────────────────────── */
.shop-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 7px;
    height: 42px; padding: 0 var(--space-4); border-radius: var(--radius-md);
    font-size: 14px; font-weight: var(--fw-bold); font-family: inherit; cursor: pointer;
    text-decoration: none; border: 1.5px solid transparent; white-space: nowrap;
    transition: all var(--dur-fast) var(--ease);
}
.shop-btn--primary { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-on-dark); }
.shop-btn--primary:hover { background: var(--color-primary-hover); border-color: var(--color-primary-hover); color: var(--color-on-dark); box-shadow: var(--shadow-sm); }
.shop-btn--outline { background: var(--color-surface); border-color: var(--color-border); color: var(--color-text); }
.shop-btn--outline:hover { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-soft); }
.shop-btn--accent { background: var(--color-accent); border-color: var(--color-accent); color: var(--color-on-dark); }
.shop-btn--accent:hover { background: var(--color-accent-hover); border-color: var(--color-accent-hover); color: var(--color-on-dark); }
.shop-btn--owned { background: var(--color-secondary-soft); border-color: color-mix(in srgb, var(--color-secondary) 40%, transparent); color: var(--color-secondary); cursor: default; }
.shop-btn--soon { background: var(--color-soft); border-color: var(--color-border); color: var(--color-locked); cursor: default; }
.shop-btn--ghost { background: transparent; border-color: transparent; color: var(--color-primary); }
.shop-btn--ghost:hover { background: var(--color-primary-soft); }
.shop-btn--block { width: 100%; }
.shop-btn--lg { height: 50px; font-size: 15px; padding: 0 var(--space-6); }
.shop-btn:disabled { opacity: .6; cursor: not-allowed; }
.shop-card__foot .shop-btn { flex: 1; padding: 0 var(--space-3); }
.shop-card__foot .shop-btn--icon { flex: 0 0 auto; width: 42px; padding: 0; }
/* foot variant cho gói: nút full-width, có thể kèm khối nâng cấp phía trên */
.shop-card__foot--plan { flex-direction: column; align-items: stretch; gap: var(--space-3); }
.shop-card__foot--plan .shop-btn { width: 100%; flex: none; }

/* ── Khối nâng cấp trả chênh (gói) ────────────────────────────────────────── */
.shop-upgrade { padding: var(--space-3); border: 1px solid color-mix(in srgb, var(--color-primary) 30%, transparent); background: var(--color-primary-soft); border-radius: var(--radius-md); text-align: center; }
.shop-upgrade__from { font-size: 11px; font-weight: var(--fw-extrabold); color: var(--color-primary); letter-spacing: .04em; text-transform: uppercase; margin-bottom: 5px; }
.shop-upgrade__math { font-size: 12.5px; color: var(--color-muted); line-height: 1.6; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 4px; }
.shop-upgrade__op { font-weight: var(--fw-bold); color: var(--color-ink); }
.shop-upgrade__total { font-size: 24px; font-weight: var(--fw-extrabold); color: var(--color-primary); line-height: 1.1; margin-top: 4px; }
.shop-upgrade__hold { font-size: 11.5px; color: var(--color-muted); margin-top: 4px; }

/* ── Empty state ──────────────────────────────────────────────────────────── */
.shop-empty { text-align: center; padding: var(--space-12) var(--space-4); color: var(--color-muted); grid-column: 1 / -1; }
.shop-empty i { font-size: 40px; color: var(--color-locked); margin-bottom: var(--space-3); }
.shop-empty h3 { font-size: var(--fs-h4); color: var(--color-ink); margin: 0 0 6px; }
.shop-empty p { margin: 0 0 var(--space-4); }

/* ============================================================================
   DETAIL PAGE (/san-pham/{slug})
   ============================================================================ */
.shop-detail__back { display: inline-flex; align-items: center; gap: 7px; margin-bottom: var(--space-3); font-size: var(--fs-small); font-weight: var(--fw-bold); color: var(--color-muted); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
.shop-detail__back:hover { color: var(--color-primary); text-decoration: none; }
.shop-detail__back i { font-size: 12px; }
.shop-detail__bc { display: flex; align-items: center; gap: var(--space-2); font-size: var(--fs-small); color: var(--color-muted); margin-bottom: var(--space-4); min-width: 0; }
.shop-detail__bc a { color: var(--color-muted); text-decoration: none; white-space: nowrap; flex: 0 0 auto; transition: color var(--dur-fast) var(--ease); }
.shop-detail__bc a:hover { color: var(--color-primary); }
.shop-detail__bc > *:not(:first-child)::before { content: "\203A"; margin-right: var(--space-2); color: var(--color-mute2); }
.shop-detail__bc-cur { min-width: 0; flex: 1 1 auto; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--color-text); }

/* Social proof: sao đánh giá + người mua (số tự đặt trong admin) */
.shop-detail__social { display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-2); margin: var(--space-2) 0 var(--space-3); font-size: var(--fs-small); color: var(--color-muted); }
.shop-detail__stars { position: relative; display: inline-flex; font-size: 15px; line-height: 1; }
.shop-detail__stars-base { color: var(--color-border); }
.shop-detail__stars-fill { position: absolute; top: 0; left: 0; overflow: hidden; white-space: nowrap; color: var(--color-warning); }
.shop-detail__stars-base i + i, .shop-detail__stars-fill i + i { margin-left: 2px; }
.shop-detail__rating-num { font-weight: var(--fw-extrabold); color: var(--color-ink); }
.shop-detail__rating-max { font-weight: var(--fw-regular); color: var(--color-mute2); }
.shop-detail__social-cnt { color: var(--color-muted); }
.shop-detail__social-sep { color: var(--color-mute2); }
.shop-detail__social-sold { display: inline-flex; align-items: center; }
.shop-detail__social-sold i { font-size: 12px; margin-right: 5px; color: var(--color-mute2); }

.shop-detail__hero { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr); gap: var(--space-8); align-items: start; margin-bottom: var(--space-10); }
@media (max-width: 880px) { .shop-detail__hero { grid-template-columns: 1fr; gap: var(--space-5); } }

.shop-detail__media { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--color-border); aspect-ratio: 16/10; background: var(--color-soft); position: relative; }
.shop-detail__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* placeholder không ảnh: panel phẳng, tông brand (không gradient xám) */
.shop-detail__media--ph { display: flex; align-items: center; justify-content: center; background: var(--color-primary-soft); }
.shop-detail__ph { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.shop-detail__ph-ic { width: 76px; height: 76px; border-radius: var(--radius-lg); background: var(--color-surface); color: var(--color-primary); display: flex; align-items: center; justify-content: center; font-size: 32px; box-shadow: var(--shadow-sm); }
.shop-detail__ph-label { font-size: 13px; font-weight: var(--fw-bold); color: var(--color-primary); text-transform: uppercase; letter-spacing: .06em; }
.shop-detail__media-badge { position: absolute; top: 14px; left: 14px; padding: 5px 13px; background: var(--color-primary); color: var(--color-on-dark); border-radius: var(--radius-pill); font-size: 12px; font-weight: var(--fw-extrabold); }

/* Ảnh hero — bấm để phóng to (lightbox) */
.shop-detail__media--zoom { cursor: zoom-in; }
.shop-detail__media-zoom { position: absolute; bottom: 12px; right: 12px; display: inline-flex; align-items: center; gap: 6px; padding: 6px 11px; background: color-mix(in srgb, var(--color-ink) 58%, transparent); color: var(--color-on-dark); border-radius: var(--radius-pill); font-size: 12px; font-weight: var(--fw-bold); opacity: 0; transform: translateY(4px); transition: opacity var(--dur-base) var(--ease), transform var(--dur-base) var(--ease); pointer-events: none; }
.shop-detail__media--zoom:hover .shop-detail__media-zoom,
.shop-detail__media--zoom:focus-visible .shop-detail__media-zoom { opacity: 1; transform: translateY(0); }

.shop-lightbox { position: fixed; inset: 0; z-index: 1300; display: none; align-items: center; justify-content: center; padding: var(--space-6); background: color-mix(in srgb, var(--color-ink) 86%, transparent); opacity: 0; transition: opacity var(--dur-base) var(--ease); }
.shop-lightbox.is-open { display: flex; opacity: 1; }
.shop-lightbox__img { max-width: min(960px, 94vw); max-height: 88vh; width: auto; height: auto; object-fit: contain; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); background: var(--color-surface); }
.shop-lightbox__close { position: absolute; top: 18px; right: 18px; width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; border: none; border-radius: var(--radius-pill); background: var(--color-surface); color: var(--color-ink); font-size: 17px; cursor: pointer; box-shadow: var(--shadow-md); transition: transform var(--dur-fast) var(--ease); }
.shop-lightbox__close:hover { transform: scale(1.06); }

.shop-detail__cat { font-size: 12px; font-weight: var(--fw-extrabold); letter-spacing: .06em; text-transform: uppercase; color: var(--color-primary); margin-bottom: 8px; }
.shop-detail__name { font-size: clamp(24px, 3.4vw, 32px); font-weight: var(--fw-extrabold); color: var(--color-ink); letter-spacing: -.02em; line-height: 1.18; margin: 0 0 var(--space-3); }
.shop-detail__short { font-size: var(--fs-body); color: var(--color-muted); line-height: var(--lh-normal); margin: 0 0 var(--space-4); }

.shop-detail__price { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; padding: var(--space-4) 0; border-top: 1px solid var(--color-line); border-bottom: 1px solid var(--color-line); margin-bottom: var(--space-4); }
.shop-detail__price-num { font-size: 34px; font-weight: var(--fw-extrabold); color: var(--color-ink); letter-spacing: -.03em; line-height: 1; }
.shop-detail__price-orig { font-size: 17px; color: var(--color-mute2); text-decoration: line-through; }
.shop-detail__price-period { font-size: 13px; color: var(--color-muted); font-weight: var(--fw-semibold); }
.shop-detail__price-off { padding: 3px 9px; background: var(--color-warning-soft); color: var(--color-warning-deep); border-radius: var(--radius-pill); font-size: 12px; font-weight: var(--fw-bold); }
/* Giá sau khi áp voucher công khai — khối "deal" emerald tạo động lực mua */
.shop-detail__voucher { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin: calc(-1 * var(--space-2)) 0 var(--space-4); padding: 9px 12px; background: var(--color-secondary-soft); border: 1px dashed color-mix(in srgb, var(--color-secondary) 45%, transparent); border-radius: var(--radius-md); }
.shop-detail__voucher-tag { display: inline-flex; align-items: center; gap: 6px; padding: 3px 9px; background: var(--color-secondary); color: var(--color-on-dark); border-radius: var(--radius-sm); font-size: 12px; font-weight: var(--fw-bold); white-space: nowrap; }
.shop-detail__voucher-tag i { font-size: 11px; }
.shop-detail__voucher-text { font-size: 13.5px; color: var(--color-text); font-weight: var(--fw-semibold); }
.shop-detail__voucher-text strong { color: var(--color-secondary-deep, var(--color-secondary)); font-weight: var(--fw-extrabold); font-size: 15px; }
.shop-detail__voucher-save { color: var(--color-muted); font-weight: var(--fw-semibold); font-size: 12px; }

.shop-detail__cta { display: flex; gap: 10px; margin-bottom: var(--space-5); flex-wrap: wrap; }
.shop-detail__cta .shop-btn { flex: 1; min-width: 150px; }

/* ── Section ──────────────────────────────────────────────────────────────── */
.shop-sec { margin-bottom: var(--space-8); }
.shop-sec__head { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-4); }
.shop-sec__ico {
    flex: 0 0 46px; width: 46px; height: 46px; border-radius: var(--radius-md);
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--color-primary-soft); color: var(--color-primary); font-size: 20px;
}
.shop-sec__htext { min-width: 0; }
.shop-sec__eyebrow { font-size: 12px; font-weight: var(--fw-extrabold); letter-spacing: .06em; text-transform: uppercase; color: var(--color-primary); margin-bottom: 3px; }
.shop-sec__title { font-size: var(--fs-h3); font-weight: var(--fw-extrabold); color: var(--color-ink); margin: 0; letter-spacing: -.015em; }

.shop-card-box { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5) var(--space-6); }

.shop-template {
    padding: var(--space-5); background: var(--color-surface);
    border: 1px solid color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
    border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
}
.shop-template__summary { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; margin-bottom: var(--space-3); }
.shop-template__summary > span {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 7px 11px; border-radius: var(--radius-pill);
    background: var(--color-soft); color: var(--color-text);
    font-size: 12.5px; font-weight: var(--fw-bold);
}
.shop-template__summary > span i { color: var(--color-primary); font-size: 11px; }
.shop-template__desc { margin: 0 0 var(--space-4); color: var(--color-muted); line-height: var(--lh-normal); }

/* Lộ trình chi tiết: Tuần → Ngày → bài (accordion, đồng bộ lộ trình của user) */
.shop-rm__toggleall {
    margin-left: auto;
    display: inline-flex; align-items: center; gap: 7px;
    padding: 7px 14px; border: 1px solid var(--color-border); border-radius: var(--radius-pill);
    background: var(--color-surface); color: var(--color-text);
    font-size: 12.5px; font-weight: var(--fw-semibold); font-family: inherit; cursor: pointer;
    transition: color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
.shop-rm__toggleall:hover { color: var(--color-primary); border-color: var(--color-primary); background: var(--color-primary-soft); }
.shop-rm__toggleall i { font-size: 11px; }
.shop-rm { display: flex; flex-direction: column; gap: 8px; }
.shop-rm__week { border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-surface); overflow: hidden; transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease); }
.shop-rm__week.is-open { border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border)); box-shadow: var(--shadow-sm); }
.shop-rm__whead { display: flex; align-items: center; gap: 12px; width: 100%; padding: 12px 16px; background: none; border: 0; cursor: pointer; font-family: inherit; text-align: left; transition: background var(--dur-fast) var(--ease); }
.shop-rm__whead:hover { background: var(--color-soft); }
.shop-rm__week.is-open .shop-rm__whead { background: var(--color-primary-soft); }
.shop-rm__wnum { width: 30px; height: 30px; flex-shrink: 0; border-radius: var(--radius-sm); background: var(--color-soft); color: var(--color-muted); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: var(--fw-bold); }
.shop-rm__week.is-open .shop-rm__wnum { background: var(--color-primary); color: var(--color-on-dark); }
.shop-rm__wtitle { font-size: 14px; font-weight: var(--fw-bold); color: var(--color-ink); }
.shop-rm__wmeta { margin-left: auto; font-size: 12.5px; color: var(--color-muted); font-weight: var(--fw-semibold); }
.shop-rm__chev { color: var(--color-muted); font-size: 14px; transition: transform var(--dur-base) var(--ease); flex-shrink: 0; }
.shop-rm__week.is-open .shop-rm__chev { transform: rotate(180deg); color: var(--color-primary); }
.shop-rm__wbody { display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur-base) var(--ease); }
.shop-rm__week.is-open .shop-rm__wbody { grid-template-rows: 1fr; }
.shop-rm__winner { overflow: hidden; min-height: 0; }
.shop-rm__day { border-top: 1px solid var(--color-line); }
.shop-rm__dhead { display: flex; align-items: center; gap: 9px; width: 100%; padding: 11px 16px; background: none; border: 0; cursor: pointer; font-family: inherit; text-align: left; transition: background var(--dur-fast) var(--ease); }
.shop-rm__dhead:hover { background: var(--color-soft); }
.shop-rm__dlabel { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: .04em; color: var(--color-muted); }
.shop-rm__dlabel::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--color-border); flex-shrink: 0; transition: background var(--dur-fast) var(--ease); }
.shop-rm__day.is-open .shop-rm__dlabel { color: var(--color-primary); }
.shop-rm__day.is-open .shop-rm__dlabel::before { background: var(--color-primary); }
.shop-rm__dmeta { margin-left: auto; font-size: 12px; color: var(--color-muted); font-weight: var(--fw-semibold); }
.shop-rm__dchev { color: var(--color-mute2); font-size: 12px; transition: transform var(--dur-base) var(--ease); flex-shrink: 0; }
.shop-rm__day.is-open .shop-rm__dchev { transform: rotate(180deg); color: var(--color-primary); }
.shop-rm__dbody { display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur-base) var(--ease); }
.shop-rm__day.is-open .shop-rm__dbody { grid-template-rows: 1fr; }
.shop-rm__dinner { overflow: hidden; min-height: 0; }
.shop-rm__tasks { display: flex; flex-direction: column; gap: 2px; padding: 2px 14px 14px; }
.shop-rm__task { display: flex; align-items: center; gap: 13px; padding: 9px 10px; border-radius: var(--radius-md); transition: background var(--dur-fast) var(--ease); }
.shop-rm__task:hover { background: var(--color-soft); }
.shop-rm__tic { width: 38px; height: 38px; flex-shrink: 0; border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: 16px; background: var(--color-primary-soft); color: var(--color-primary); }
.shop-rm__ttitle { flex: 1; min-width: 0; font-size: 15px; font-weight: var(--fw-medium); color: var(--color-ink); line-height: 1.45; }
.shop-rm__ttype { flex-shrink: 0; font-size: 11px; font-weight: var(--fw-extrabold); text-transform: uppercase; letter-spacing: .03em; padding: 4px 11px; border-radius: var(--radius-pill); background: var(--color-primary-soft); color: var(--color-primary-deep); }
/* tone theo loại bài */
.shop-rm__task[data-tone="accent"] .shop-rm__tic { background: var(--color-accent-soft); color: var(--color-accent); }
.shop-rm__task[data-tone="accent"] .shop-rm__ttype { background: var(--color-accent-soft); color: var(--color-accent-deep); }
.shop-rm__task[data-tone="secondary"] .shop-rm__tic { background: var(--color-secondary-soft); color: var(--color-secondary); }
.shop-rm__task[data-tone="secondary"] .shop-rm__ttype { background: var(--color-secondary-soft); color: var(--color-secondary-deep); }
.shop-rm__task[data-tone="warning"] .shop-rm__tic { background: var(--color-warning-soft); color: var(--color-warning); }
.shop-rm__task[data-tone="warning"] .shop-rm__ttype { background: var(--color-warning-soft); color: var(--color-warning-deep); }

/* badge "Học thử free" trên header tuần 1 */
.shop-rm__wfree { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: var(--fw-extrabold); text-transform: uppercase; letter-spacing: .03em; color: var(--color-secondary-deep); background: var(--color-secondary-soft); padding: 3px 9px; border-radius: var(--radius-pill); }
.shop-rm__wfree i { font-size: 10px; }
.shop-rm__wlock { color: var(--color-mute2); font-size: 11px; }

/* Task tuần 1 = link học thử (bấm được) */
.shop-rm__task--free { text-decoration: none; color: inherit; cursor: pointer; }
.shop-rm__task--free:hover { background: var(--color-primary-soft); }
.shop-rm__ttype--free { background: var(--color-secondary-soft) !important; color: var(--color-secondary-deep) !important; }
.shop-rm__tgo { flex-shrink: 0; color: var(--color-mute2); font-size: 12px; transition: transform var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); }
.shop-rm__task--free:hover .shop-rm__tgo { color: var(--color-primary); transform: translateX(3px); }

/* Task tuần 2+ = khoá */
.shop-rm__task--locked { cursor: pointer; opacity: .72; }
.shop-rm__task--locked:hover { opacity: 1; background: var(--color-soft); }
.shop-rm__task--locked .shop-rm__tic { background: var(--color-soft); color: var(--color-locked); }
.shop-rm__tlock { flex-shrink: 0; color: var(--color-locked); font-size: 12px; }

/* Toast nhắc mua khi bấm bài khoá */
.shop-rm-locktoast { position: fixed; left: 50%; bottom: 24px; transform: translate(-50%, 16px); z-index: 1200; display: inline-flex; align-items: center; gap: 8px; max-width: 90vw; padding: 12px 18px; border-radius: var(--radius-pill); background: var(--color-ink); color: var(--color-on-dark); font-size: 13.5px; font-weight: var(--fw-semibold); box-shadow: var(--shadow-lg); opacity: 0; pointer-events: none; transition: opacity var(--dur-base) var(--ease), transform var(--dur-base) var(--ease); }
.shop-rm-locktoast.is-show { opacity: 1; transform: translate(-50%, 0); }
.shop-rm-locktoast i { color: var(--color-warning); }

@media (max-width: 560px) { .shop-rm__ttype { display: none; } .shop-rm__ttitle { font-size: 14px; } }

/* who_for / what_you_get list */
.shop-list { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 20px; list-style: none; padding: 0; margin: 0; }
@media (max-width: 640px) { .shop-list { grid-template-columns: 1fr; } }
.shop-list li { display: flex; align-items: flex-start; gap: 10px; font-size: 14.5px; line-height: 1.5; color: var(--color-text); }
.shop-list li i { width: 20px; height: 20px; flex-shrink: 0; margin-top: 1px; border-radius: 50%; background: var(--color-secondary-soft); color: var(--color-secondary); display: flex; align-items: center; justify-content: center; font-size: 9px; }
.shop-list--who li i { background: var(--color-primary-soft); color: var(--color-primary); }

/* roadmap */
.shop-road { display: flex; flex-direction: column; gap: 0; }
.shop-road__step { display: flex; gap: var(--space-4); padding-bottom: var(--space-4); position: relative; }
.shop-road__step:not(:last-child)::before { content: ''; position: absolute; left: 17px; top: 36px; bottom: 0; width: 2px; background: var(--color-line); }
.shop-road__num { width: 36px; height: 36px; flex-shrink: 0; border-radius: 50%; background: var(--color-primary-soft); color: var(--color-primary); display: flex; align-items: center; justify-content: center; font-weight: var(--fw-extrabold); font-size: 15px; z-index: 1; }
.shop-road__body { padding-top: 4px; }
.shop-road__stage { font-size: 11px; font-weight: var(--fw-extrabold); letter-spacing: .05em; text-transform: uppercase; color: var(--color-muted); }
.shop-road__title { font-size: 15.5px; font-weight: var(--fw-bold); color: var(--color-ink); margin: 2px 0 3px; }
.shop-road__desc { font-size: 13.5px; color: var(--color-muted); line-height: 1.5; margin: 0; }


/* FAQ */
.shop-faq__item { border-bottom: 1px solid var(--color-line); }
.shop-faq__item:last-child { border-bottom: 0; }
.shop-faq__q { display: flex; align-items: center; justify-content: space-between; gap: 12px; width: 100%; padding: 15px 4px; background: none; border: 0; cursor: pointer; font-family: inherit; font-size: 14.5px; font-weight: var(--fw-bold); color: var(--color-ink); text-align: left; transition: color var(--dur-fast) var(--ease); }
.shop-faq__q:hover { color: var(--color-primary); }
.shop-faq__item.is-open .shop-faq__q { color: var(--color-primary); }
.shop-faq__q i { color: var(--color-mute2); font-size: 13px; transition: transform var(--dur-base) var(--ease); flex-shrink: 0; }
.shop-faq__item.is-open .shop-faq__q i { transform: rotate(180deg); color: var(--color-primary); }
.shop-faq__a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur-base) var(--ease); }
.shop-faq__item.is-open .shop-faq__a { grid-template-rows: 1fr; }
.shop-faq__inner { overflow: hidden; min-height: 0; }
.shop-faq__a p { font-size: 14px; color: var(--color-muted); line-height: var(--lh-body); margin: 0; padding: 0 4px 16px; }

/* related products reuse .shop-grid + .shop-card */

/* sticky mobile buy bar */
.shop-buybar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 90; display: none; align-items: center; gap: 12px; padding: 10px var(--space-4); background: var(--color-surface); border-top: 1px solid var(--color-border); box-shadow: 0 -4px 16px color-mix(in srgb, var(--color-ink) 8%, transparent); }
.shop-buybar__price { font-size: 18px; font-weight: var(--fw-extrabold); color: var(--color-ink); }
.shop-buybar .shop-btn { flex: 1; }
@media (max-width: 880px) { .shop-buybar { display: flex; } }

/* toast "Đã thêm vào giỏ" — card + CTA + progress bar */
.shop-toast {
    position: fixed; top: 86px; right: 20px; z-index: 1200;
    display: flex; align-items: center; gap: 12px;
    min-width: 300px; max-width: 380px; padding: 14px 14px 16px;
    background: var(--color-surface); color: var(--color-ink);
    border: 1px solid var(--color-border); border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg); overflow: hidden;
    opacity: 0; transform: translateY(-12px) scale(.98);
    transition: opacity var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
    pointer-events: auto;
}
.shop-toast.is-show { opacity: 1; transform: translateY(0) scale(1); }
.shop-toast__icon { flex: 0 0 auto; width: 38px; height: 38px; border-radius: 50%; background: var(--color-secondary-soft); color: var(--color-secondary); display: inline-flex; align-items: center; justify-content: center; font-size: 16px; }
.shop-toast.is-error .shop-toast__icon { background: var(--color-warning-soft); color: var(--color-warning); }
.shop-toast__body { flex: 1; min-width: 0; }
.shop-toast__title { font-size: 14px; font-weight: var(--fw-bold); color: var(--color-ink); line-height: 1.3; }
.shop-toast__sub { font-size: 12.5px; color: var(--color-muted); margin-top: 1px; }
.shop-toast__sub b { color: var(--color-ink); font-weight: var(--fw-bold); }
.shop-toast__cta { flex: 0 0 auto; display: inline-flex; align-items: center; gap: 5px; padding: 7px 13px; border-radius: var(--radius-md); background: var(--color-primary); color: var(--color-on-dark); font-size: 12.5px; font-weight: var(--fw-bold); text-decoration: none; white-space: nowrap; transition: background var(--dur-fast) var(--ease); }
.shop-toast__cta:hover { background: var(--color-primary-hover); color: var(--color-on-dark); text-decoration: none; }
.shop-toast__cta i { font-size: 10px; }
.shop-toast__close { flex: 0 0 auto; width: 26px; height: 26px; border: 0; background: none; color: var(--color-mute2); cursor: pointer; border-radius: var(--radius-sm); font-size: 13px; transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease); }
.shop-toast__close:hover { color: var(--color-ink); background: var(--color-soft); }
.shop-toast__bar { position: absolute; left: 0; bottom: 0; height: 3px; width: 100%; }
.shop-toast__bar span { display: block; height: 100%; width: 100%; background: var(--color-secondary); }
.shop-toast.is-error .shop-toast__bar span { background: var(--color-warning); }
@media (max-width: 480px) {
    .shop-toast { top: 70px; right: 12px; left: 12px; min-width: 0; max-width: none; }
}

/* ── Đánh giá người học ───────────────────────────────────────────────────── */
.shop-reviews { display: flex; flex-direction: column; gap: var(--space-4); }
.shop-reviews__summary {
    display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg);
}
.shop-reviews__avg { font-size: 30px; font-weight: var(--fw-extrabold); color: var(--color-ink); line-height: 1; letter-spacing: -.02em; }
.shop-reviews__avg-max { font-size: 16px; font-weight: var(--fw-bold); color: var(--color-muted); margin-left: 2px; }
.shop-reviews__cnt { font-size: var(--fs-small); color: var(--color-muted); font-weight: var(--fw-semibold); }

/* star overlay — dùng chung kỹ thuật với hero (amber fill) */
.shop-rv__stars { position: relative; display: inline-flex; font-size: 15px; line-height: 1; }
.shop-rv__stars-base { color: var(--color-border); }
.shop-rv__stars-fill { position: absolute; top: 0; left: 0; overflow: hidden; white-space: nowrap; color: var(--color-warning); }
.shop-rv__stars-base i + i, .shop-rv__stars-fill i + i { margin-left: 2px; }

.shop-reviews__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-3); }
@media (max-width: 720px) { .shop-reviews__grid { grid-template-columns: 1fr; } }

.shop-rv {
    display: flex; flex-direction: column; gap: var(--space-2);
    padding: var(--space-4) var(--space-5);
    background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg);
}
.shop-rv__head { display: flex; align-items: center; gap: 11px; }
.shop-rv__ava {
    width: 40px; height: 40px; flex: 0 0 40px; border-radius: var(--radius-pill);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 16px; font-weight: var(--fw-extrabold);
    background: var(--color-primary-soft); color: var(--color-primary);
}
.shop-rv[data-tone="secondary"] .shop-rv__ava { background: var(--color-secondary-soft); color: var(--color-secondary); }
.shop-rv[data-tone="accent"] .shop-rv__ava { background: var(--color-accent-soft); color: var(--color-accent); }
.shop-rv__who { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.shop-rv__name { font-size: 14px; font-weight: var(--fw-bold); color: var(--color-ink); display: inline-flex; align-items: center; gap: 6px; }
.shop-rv__verified { color: var(--color-secondary); font-size: 12px; }
.shop-rv__date { font-size: 12px; color: var(--color-muted); }
.shop-rv__rating { margin-top: 1px; }
.shop-rv__text { margin: 0; font-size: 13.5px; line-height: var(--lh-body); color: var(--color-text); }

/* ── Thông tin sản phẩm (full_desc): editorial + bút dạ teal tô cụm khóa ─────── */
.shop-about > p { margin: 0 0 var(--space-3); font-size: 16px; line-height: var(--lh-loose); color: var(--color-text); }
.shop-about > p:last-child { margin-bottom: 0; }
.shop-about > p:first-child { color: var(--color-ink); }
/* cụm khóa <strong> → bút dạ: nền teal nhạt, chữ teal đậm, bo nhẹ */
.shop-about strong, .shop-about b {
    background: var(--color-primary-soft); color: var(--color-primary-deep);
    padding: 1px 6px; border-radius: var(--radius-sm);
    font-weight: var(--fw-bold); box-decoration-break: clone; -webkit-box-decoration-break: clone;
}

/* ── Tối ưu mobile — trang chi tiết sản phẩm ─────────────────────────────── */
@media (max-width: 880px) {
    /* chừa chỗ đáy cho thanh mua cố định (kể cả footer, không che nội dung) */
    body:has(.shop-buybar) { padding-bottom: 76px; }
    /* cảm ứng không có hover → luôn hiện gợi ý "Phóng to" ảnh */
    .shop-detail__media-zoom { opacity: 1; transform: none; }
}

@media (max-width: 600px) {
    .shop { padding-top: var(--space-5); }
    /* card gọn lại — không bóp nội dung trên màn nhỏ */
    .shop-card-box, .shop-reviews__summary, .shop-rv, .shop-template { padding: var(--space-4); }
    .shop-sec { margin-bottom: var(--space-6); }

    /* tiêu đề mục: icon + chữ vừa mắt mobile */
    .shop-sec__head { gap: var(--space-2); margin-bottom: var(--space-3); }
    .shop-sec__ico { flex-basis: 40px; width: 40px; height: 40px; font-size: 18px; }
    .shop-sec__title { font-size: var(--fs-h4); }

    /* hero: giá gọn, nút mua xếp dọc full-width cho dễ bấm */
    .shop-detail__hero { margin-bottom: var(--space-6); }
    .shop-detail__price-num { font-size: 28px; }
    .shop-detail__cta { gap: 8px; }
    .shop-detail__cta .shop-btn { flex: 1 1 100%; min-width: 0; }

    /* nội dung editorial + đánh giá */
    .shop-about > p { font-size: 15px; }
    .shop-reviews__avg { font-size: 26px; }

    /* lộ trình bán kèm: header/task gọn hơn */
    .shop-rm__whead { padding: 11px 13px; gap: 10px; }
    .shop-rm__tasks { padding: 2px 10px 12px; }
    .shop-rm__task { gap: 11px; padding: 8px; }
    .shop-rm__tic { width: 34px; height: 34px; font-size: 15px; }
}
