/* ═══════════════════════════════════════════════════════════════════════
   Profile page — prx-* design system
═══════════════════════════════════════════════════════════════════════ */

/* ── Cover ──────────────────────────────────────────────────────────── */
.prx-cover-wrap {
    width: 90%; max-width: 1199px; margin: 0 auto;
}
.prx-cover {
    width: 100%; height: 210px; position: relative; overflow: hidden;
    background: linear-gradient(to bottom, #1e3a8a 0%, #3b82f6 55%, #818cf8 100%);
    border-radius: 18px;
}
.prx-cover--has-image { background: #0f172a !important; }
.prx-cover__img {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; border-radius: inherit;
}
.prx-cover-fade {
    position: absolute; bottom: 0; left: 0; width: 100%; height: 70px;
    background: linear-gradient(transparent, #fff); pointer-events: none;
}
.prx-cover-edit {
    position: absolute; bottom: 14px; right: 14px;
    opacity: 0.75; transition: opacity .2s;
}
.prx-cover:hover .prx-cover-edit { opacity: 1; }
.prx-cover-edit__btn {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(0,0,0,.55); color: #fff; border: 1.5px solid rgba(255,255,255,.35);
    border-radius: 8px; padding: 7px 13px; font-size: 12px; font-weight: 600;
    cursor: pointer; backdrop-filter: blur(6px); transition: background .15s;
}
.prx-cover-edit__btn:hover { background: rgba(0,0,0,.75); }
.prx-cover-delete {
    position: absolute; top: 14px; right: 14px; z-index: 3;
    width: 34px; height: 34px; border-radius: 8px;
    background: rgba(0,0,0,.55); color: #fff;
    border: 1.5px solid rgba(255,255,255,.35);
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer; backdrop-filter: blur(6px);
    transition: background .15s, color .15s, border-color .15s;
    opacity: 0.75;
}
.prx-cover:hover .prx-cover-delete { opacity: 1; }
.prx-cover-delete:hover { background: #ef4444; border-color: #ef4444; color: #fff; }
.prx-cover-delete.is-loading { pointer-events: none; opacity: .6; }
.prx-cover-delete svg { width: 14px; height: 14px; }

/* ── Layout ─────────────────────────────────────────────────────────── */
.prx-layout {
    display: flex; gap: 28px; padding-bottom: 56px;
    align-items: stretch; /* sidebar height = main height → sticky works */
}
.prx-sidebar {
    width: 248px; flex-shrink: 0; margin-top: -16px; position: relative; z-index: 10;
}
.prx-sticky-wrap {
    position: sticky;
    top: 150px; /* fallback; JS ниже уточняет по реальной высоте хедера */
}
.prx-card {
    background: #fff; border: 1px solid #e2e8f0; border-radius: 16px;
    padding: 68px 18px 18px; position: relative;
    margin-top: 54px;
}
.prx-main { flex: 1; min-width: 0; padding-top: 20px; }

/* ── Kebab menu ─────────────────────────────────────────────────────── */
.prx-card-menu { position: absolute; top: 12px; right: 12px; }
.prx-card-menu__btn {
    width: 28px; height: 28px; border-radius: 6px;
    background: transparent; border: none; color: #94a3b8;
    font-size: 16px; font-weight: 700; cursor: pointer; letter-spacing: .5px;
    display: flex; align-items: center; justify-content: center;
    opacity: .65;
    transition: background .15s, color .15s, opacity .15s;
}
.prx-card-menu__btn:hover { background: rgba(15,23,42,.06); color: #475569; opacity: 1; }
@media (max-width: 768px) {
    .prx-card-menu { top: 8px; right: 8px; }
    .prx-card-menu__btn { width: 24px; height: 24px; font-size: 14px; opacity: .5; }
}
.prx-card-menu__dropdown {
    display: none; position: absolute; top: 38px; right: 0;
    background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0,0,0,.1); min-width: 210px;
    padding: 8px 0; z-index: 100;
}
.prx-card-menu__dropdown.is-open { display: block; }
.prx-card-menu__info {
    display: flex; align-items: center; gap: 8px;
    padding: 7px 14px; font-size: 12px; color: #475569; white-space: nowrap;
}
.prx-card-menu__info i { color: #94a3b8; width: 14px; flex-shrink: 0; }
.prx-card-menu__divider { height: 1px; background: #f1f5f9; margin: 6px 0; }
.prx-card-menu__item {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 14px; font-size: 13px; font-weight: 600; cursor: pointer;
    background: none; border: none; width: 100%; text-align: left; transition: background .12s;
}
.prx-card-menu__item:hover { background: #f8fafc; }
.prx-card-menu__item--danger { color: #ef4444; }
.prx-card-menu__item--danger:hover { background: #fff5f5; }

/* ── Avatar ─────────────────────────────────────────────────────────── */
.prx-ava-wrap {
    position: absolute; top: -49px; left: 0; right: 0;
    display: flex; justify-content: center;
    pointer-events: none; /* let clicks through to kebab below */
}
.prx-ava {
    width: 108px; height: 108px; border-radius: 50%;
    object-fit: cover; display: block;
    pointer-events: auto; /* avatar itself is clickable */
}
.prx-ava--initials {
    width: 108px; height: 108px; border-radius: 50%;
    background: #e0e7ff; color: #4338ca;
    font-weight: 800; font-size: 36px;
    display: flex; align-items: center; justify-content: center;
    pointer-events: auto;
}
/* ── Name / handle / location ───────────────────────────────────────── */
.prx-name {
    font-size: 17px; font-weight: 800; color: #1e293b; text-align: center;
    line-height: 1.3; margin: 0 0 3px;
    display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 4px;
}
.prx-handle {
    font-size: 12px; color: #64748b; text-align: center; margin-bottom: 6px;
    display: inline-flex; align-items: center; gap: 6px;
}
.prx-handle-wrap { text-align: center; margin-bottom: 6px; }
/* Online dot — точка inline рядом с @username */
.prx-online-inline {
    display: inline-block; width: 8px; height: 8px; border-radius: 50%;
    background: #10b981; vertical-align: middle;
    box-shadow: 0 0 0 3px rgba(16,185,129,.18);
    animation: prx-online-pulse 2s ease-in-out infinite;
}
@keyframes prx-online-pulse {
    0%, 100% { box-shadow: 0 0 0 3px rgba(16,185,129,.18); }
    50%      { box-shadow: 0 0 0 5px rgba(16,185,129,.08); }
}
.prx-location { font-size: 12px; color: #64748b; text-align: center; margin-bottom: 12px; }
.prx-location i { margin-right: 3px; }

/* ── Stats ──────────────────────────────────────────────────────────── */
/* 2026-05-02: убрана внешняя рамка и разделители — цифры читаются легче,
   профиль выглядит чище, фокус на самих метриках. */
.prx-stats {
    display: flex; justify-content: center; margin-bottom: 14px;
}
.prx-stat { flex: 1; text-align: center; padding: 9px 4px; }
.prx-stat-val { font-size: 15px; font-weight: 800; color: #1e293b; line-height: 1; }
.prx-stat-lbl { font-size: 10px; color: #94a3b8; margin-top: 2px; }

/* ── Action buttons ─────────────────────────────────────────────────── */
/* Архитектура: 1 primary CTA full-width (Подписаться) + ряд из 3 secondary
   icon-only действий (Донат / Подарок / Чат). Один акцентный цвет.
   Чёткая иерархия: «главное действие» >> «вторичные». */
.prx-actions { margin-bottom: 10px; }
.prx-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    border: 1px solid transparent;
    border-radius: 10px; font-size: 14px; font-weight: 700;
    cursor: pointer; text-decoration: none;
    transition: background .15s ease, color .15s ease, border-color .15s ease, transform .1s ease;
    white-space: nowrap; padding: 10px 14px; line-height: 1;
    box-sizing: border-box;
}
.prx-btn:active { transform: scale(.98); }

/* Primary — full-width filled */
.prx-btn--primary {
    width: 100%;
    background: var(--color-primary, #0a43ff);
    border-color: var(--color-primary, #0a43ff);
    color: #fff;
}
.prx-btn--primary:hover {
    background: var(--color-primary--hover, #002fd8);
    border-color: var(--color-primary--hover, #002fd8);
    color: #fff;
}
/* Subscribed-state: outline вместо fill (стандарт UX). Hover показывает
   намерение «отписаться» (красный outline). */
.prx-btn--primary.is-subscribed {
    background: #fff;
    color: var(--color-primary, #0a43ff);
}
.prx-btn--primary.is-subscribed:hover {
    background: #fef2f2;
    border-color: #dc2626;
    color: #dc2626;
}

/* Auth-fallback (для не-creator юзеров) — те же стили */
.prx-btn--auth {
    width: 100%;
    background: var(--color-primary, #0a43ff);
    border-color: var(--color-primary, #0a43ff);
    color: #fff;
}
.prx-btn--auth:hover {
    background: var(--color-primary--hover, #002fd8);
    border-color: var(--color-primary--hover, #002fd8);
    color: #fff;
}

/* ── Secondary quick-actions: ряд иконок 40 одного веса ─────────────── */
.prx-quick {
    display: flex;
    gap: 8px;
    margin-bottom: 14px;
}
.prx-quick__btn {
    flex: 1 1 0;
    height: 40px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    background: #fff;
    color: #475569;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    text-decoration: none;
    transition: border-color .15s, color .15s, background .15s, transform .1s;
}
.prx-quick__btn:hover {
    border-color: var(--color-primary, #0a43ff);
    color: var(--color-primary, #0a43ff);
    background: #f8faff;
}
.prx-quick__btn:active { transform: scale(.97); }

/* ── Bio ────────────────────────────────────────────────────────────── */
.prx-bio { font-size: 13px; color: #475569; line-height: 1.55; margin-bottom: 12px; word-break: break-word; }

/* ── Social links (outside card, below border) ──────────────────────── */
.prx-socials-strip {
    display: flex; flex-wrap: wrap; gap: 14px;
    justify-content: center;
    padding: 14px 10px 4px;
}
.prx-social-ico {
    display: inline-flex; align-items: center; justify-content: center;
    width: 20px; height: 20px;
    font-size: 16px; text-decoration: none;
    color: #94a3b8;
    transition: color .15s;
}
.prx-social-ico:hover { color: #0f172a; }

/* ── Sidebar badge strip ────────────────────────────────────────────── */
.prx-badge-strip { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 4px; }
.prx-badge-mini {
    width: 32px; height: 32px; border-radius: 8px; display: flex;
    align-items: center; justify-content: center;
    background: #f8fafc; border: 1px solid #e2e8f0;
}
.prx-badge-mini svg { width: 18px; height: 18px; }
.prx-badge-mini i { font-size: 16px; line-height: 1; }
/* Стикер-иконка для бейджа (заменяет FA-иконку). Чуть больше FA — стикер
   занимает почти всю «плашку», но с небольшим внутренним отступом. */
.prx-badge-mini .aw-icon-sticker { width: 26px; height: 26px; object-fit: contain; display: block; }
/* Стикер в модалке (увеличенная иконка-круг 64×64). */
.prx-aw-modal__icon .aw-icon-sticker { width: 54px; height: 54px; object-fit: contain; display: block; }
.prx-badge-mini.js-award-card { cursor: pointer; transition: transform .15s, box-shadow .15s, border-color .15s; }
.prx-badge-mini.js-award-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.1); border-color: #c7d2fe; }
.prx-badge-mini--hidden { display: none; }
.prx-badge-mini--more {
    font-size: 11px; font-weight: 700; color: #64748b;
    background: #f1f5f9; border: 1px dashed #cbd5e1; cursor: pointer;
    transition: background .15s, color .15s, border-color .15s;
}
.prx-badge-mini--more:hover { background: #e2e8f0; color: #334155; border-color: #94a3b8; }

/* ── Топовые мини-бейджи в сайдбаре (tier 3-5) ───────────────────────────
   Визуальная иерархия: Лег/Эп/Миф выделяются от обычных —
   градиент на иконке + градиентная рамка + лёгкое свечение.
   Чтобы не перегружать мелкий элемент — без анимаций (в отличие от крупной
   карточки на вкладке "Награды"). */

.prx-badge-mini--tier-3,
.prx-badge-mini--tier-4,
.prx-badge-mini--tier-5 {
    border-color: transparent;
    /* Двойной background: белый фон под градиент + градиент по границе */
}

/* tier 3 — Легендарный (золото) */
.prx-badge-mini--tier-3 {
    background:
        linear-gradient(#fff, #fff) padding-box,
        linear-gradient(135deg, #fde68a, #f59e0b, #fde68a) border-box;
    box-shadow: 0 0 0 1px rgba(245,158,11,.08), 0 2px 8px rgba(245,158,11,.18);
}
.prx-badge-mini--tier-3 i {
    background: linear-gradient(135deg, #fcd34d 0%, #f59e0b 50%, #b45309 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* tier 4 — Эпический (pink) */
.prx-badge-mini--tier-4 {
    background:
        linear-gradient(#fff, #fff) padding-box,
        linear-gradient(135deg, #f9a8d4, #ec4899, #f9a8d4) border-box;
    box-shadow: 0 0 0 1px rgba(236,72,153,.10), 0 2px 8px rgba(236,72,153,.22);
}
.prx-badge-mini--tier-4 i {
    background: linear-gradient(135deg, #f472b6 0%, #ec4899 50%, #be185d 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* tier 5 — Мифический (радуга) */
.prx-badge-mini--tier-5 {
    background:
        linear-gradient(#fff, #fff) padding-box,
        conic-gradient(from 90deg, #a855f7, #ec4899, #f59e0b, #10b981, #6366f1, #a855f7) border-box;
    box-shadow: 0 0 0 1px rgba(168,85,247,.12), 0 2px 10px rgba(168,85,247,.28);
}
.prx-badge-mini--tier-5 i {
    background: linear-gradient(135deg,
        #a855f7 0%, #ec4899 30%, #f59e0b 55%, #10b981 80%, #6366f1 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* Усиление свечения на hover для топовых */
.prx-badge-mini--tier-3:hover { box-shadow: 0 0 0 1px rgba(245,158,11,.18), 0 4px 14px rgba(245,158,11,.32); }
.prx-badge-mini--tier-4:hover { box-shadow: 0 0 0 1px rgba(236,72,153,.18), 0 4px 14px rgba(236,72,153,.32); }
.prx-badge-mini--tier-5:hover { box-shadow: 0 0 0 2px rgba(168,85,247,.22), 0 4px 16px rgba(168,85,247,.40); }

/* ── Tabs ───────────────────────────────────────────────────────────── */
.prx-tabs {
    position: relative; display: inline-flex; gap: 20px;
    align-items: flex-end; padding-bottom: 6px;
    border-bottom: 1px solid #e7ecff; user-select: none; width: 100%;
}
.prx-tab {
    -webkit-appearance: none; appearance: none; border: 0; background: transparent;
    cursor: pointer; padding: 0 2px 5px; font-size: 14px; font-weight: 700;
    color: #64748b; transition: color .15s; white-space: nowrap;
    display: inline-flex; align-items: center; gap: 5px;
    position: relative;
}
.prx-tab:hover { color: #334155; }
.prx-tab.is-active { color: var(--color-primary,#0a43ff); }
.prx-tabs__line {
    position: absolute; left: 0; bottom: -1px; height: 2.5px; width: 0;
    background: var(--color-primary,#0a43ff); border-radius: 2px;
    transition: left .22s ease, width .22s ease; pointer-events: none;
}
.prx-new {
    position: absolute; top: -8px; right: -22px;
    font-size: 8px; font-weight: 800; line-height: 1;
    background: var(--color-primary, #0a43ff); color: #fff; border-radius: 4px;
    padding: 2px 5px; letter-spacing: .05em; text-transform: uppercase;
    box-shadow: 0 2px 6px rgba(10, 67, 255, .25);
    pointer-events: none;
}
/* Счётчик у табов (например, число активных тиров рядом с «Подписки»). */
.prx-tab-count {
    font-size: 11px; font-weight: 700; line-height: 1;
    color: #94a3b8; background: #f1f5f9;
    padding: 2px 6px; border-radius: 999px;
}
.prx-tab.is-active .prx-tab-count {
    color: var(--color-primary, #0a43ff);
    background: rgba(10, 67, 255, .08);
}
.prx-panels { margin-top: 20px; }
.prx-panel[hidden] { display: none; }

/* ── Coming soon / empty ────────────────────────────────────────────── */
.prx-coming-soon { text-align: center; padding: 64px 24px; }
.prx-coming-soon__icon { font-size: 42px; opacity: .3; margin-bottom: 10px; }
.prx-coming-soon__title { font-size: 16px; font-weight: 800; color: #334155; margin-bottom: 5px; }
.prx-coming-soon__sub { font-size: 13px; color: #94a3b8; }
.prx-empty { text-align: center; padding: 64px 24px; }
.prx-empty__icon { font-size: 42px; opacity: .3; margin-bottom: 10px; }
.prx-empty__title { font-size: 16px; font-weight: 700; color: #475569; margin-bottom: 5px; }
.prx-empty__sub { font-size: 13px; color: #94a3b8; }

/* ── Home panel ─────────────────────────────────────────────────────── */
.prx-home-section { margin-bottom: 28px; }
.prx-home-section__head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px;
}
.prx-home-section__title { font-size: 15px; font-weight: 800; color: #1e293b; }
.prx-home-section__more {
    font-size: 12px; font-weight: 600; color: var(--color-primary,#0a43ff);
    background: none; border: none; cursor: pointer; padding: 0;
}
.prx-home-section__more:hover { text-decoration: underline; }
.prx-home-bio { font-size: 14px; color: #475569; line-height: 1.6; margin-bottom: 24px; word-break: break-word; }
.prx-fp-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px;
}
.prx-fp-card {
    position: relative;
    display: flex; flex-direction: column;
    background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
    text-decoration: none; color: inherit; overflow: hidden;
    transition: box-shadow .15s, transform .1s, border-color .15s;
}
.prx-fp-card:hover { box-shadow: 0 4px 14px rgba(0,0,0,.06); border-color: #cbd5e1; color: inherit; transform: translateY(-2px); }
.prx-fp-card__preview {
    position: relative; width: 100%; aspect-ratio: 16/10;
    background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
    overflow: hidden;
}
.prx-fp-card__preview img {
    width: 100%; height: 100%; object-fit: cover; display: block;
}
.prx-fp-card__preview-placeholder {
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    font-size: 32px; color: #94a3b8;
}
.prx-fp-card__body {
    padding: 10px 12px 12px; flex: 1; display: flex; flex-direction: column; gap: 4px;
}
.prx-fp-card__title {
    font-size: 13px; font-weight: 700; color: #1e293b; line-height: 1.3;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden; min-height: calc(1.3em * 2);
}
.prx-fp-card__price-row { display: flex; align-items: baseline; gap: 6px; margin-top: auto; }
.prx-fp-card__price { font-size: 14px; font-weight: 800; color: var(--color-primary,#0a43ff); }
.prx-fp-card__price-old { font-size: 11px; color: #94a3b8; text-decoration: line-through; }
.prx-fp-card__free { font-size: 13px; font-weight: 800; color: #10b981; }

/* Remove button for owner */
.prx-fp-card__remove {
    position: absolute; top: 8px; right: 8px; z-index: 2;
    width: 26px; height: 26px; border-radius: 7px;
    background: rgba(15,23,42,.65); color: #fff;
    border: none; cursor: pointer; backdrop-filter: blur(4px);
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; line-height: 1;
    opacity: 0; transition: opacity .15s, background .15s;
}
.prx-fp-card:hover .prx-fp-card__remove { opacity: 1; }
.prx-fp-card__remove:hover { background: #ef4444; }

/* Empty "+" slot */
.prx-fp-slot {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    aspect-ratio: 16/10;
    background: #f8fafc; border: 2px dashed #cbd5e1; border-radius: 12px;
    color: #64748b; cursor: pointer; transition: background .15s, border-color .15s, color .15s;
    padding: 16px;
}
.prx-fp-slot:hover { background: #eff6ff; border-color: var(--color-primary,#0a43ff); color: var(--color-primary,#0a43ff); }
.prx-fp-slot__plus { font-size: 24px; font-weight: 700; line-height: 1; margin-bottom: 6px; }
.prx-fp-slot__label { font-size: 12px; font-weight: 600; text-align: center; line-height: 1.35; }

/* Empty state (fully empty) */
.prx-fp-empty {
    text-align: center; padding: 28px 20px;
    background: #f8fafc; border: 2px dashed #cbd5e1; border-radius: 14px;
    color: #64748b;
}
.prx-fp-empty__title { font-size: 14px; font-weight: 700; color: #334155; margin-bottom: 6px; }
.prx-fp-empty__sub   { font-size: 12px; color: #94a3b8; margin-bottom: 14px; }

/* ── Edit-toolbar (переключатель preview ↔ edit-mode главной) ─────── */
.prx-edit-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    margin-bottom: 16px;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px dashed #cbd5e1;
    font-size: 13px;
}
.prx-edit-bar--active {
    background: linear-gradient(135deg, #eff6ff, #e0e7ff);
    border-style: solid;
    border-color: #c7d2fe;
}
.prx-edit-bar__info {
    display: flex; align-items: center; gap: 8px;
    color: #64748b; font-weight: 500;
    flex: 1; min-width: 0;
}
.prx-edit-bar--active .prx-edit-bar__info {
    color: #1e40af; font-weight: 600;
}
.prx-edit-bar__info i { font-size: 14px; }
.prx-edit-bar__btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 14px; border-radius: 8px;
    font-size: 13px; font-weight: 600;
    text-decoration: none;
    transition: background .15s, color .15s, box-shadow .15s, transform .1s;
    flex-shrink: 0;
}
.prx-edit-bar__btn:active { transform: scale(.97); }
.prx-edit-bar__btn--edit {
    background: var(--color-primary, #0a43ff);
    color: #fff;
}
.prx-edit-bar__btn--edit:hover {
    box-shadow: 0 4px 12px rgba(10, 67, 255, .25);
    color: #fff;
}
.prx-edit-bar__btn--done {
    background: #fff;
    color: #1e40af;
    border: 1px solid #c7d2fe;
}
.prx-edit-bar__btn--done:hover {
    background: #eff6ff;
    color: #1e40af;
}
@media (max-width: 560px) {
    .prx-edit-bar {
        padding: 10px 12px; font-size: 12.5px;
        flex-wrap: wrap;
    }
    .prx-edit-bar__btn { padding: 7px 12px; font-size: 12px; }
}

/* ── Home blocks (конфигурируемые блоки на вкладке «Главная») ─────── */
.prx-home-block {
    position: relative;
    margin-bottom: 18px;
    padding: 0;
}
.prx-home-block:last-child { margin-bottom: 0; }

/* Owner-режим: шапка + контент — одна объединённая карточка.
   У гостя обёртки нет — контент показывается без рамок (как на скриншоте). */
.prx-home-block--owner {
    background: #fff;
    border: 1px solid #e9edf3;
    border-radius: 14px;
    overflow: hidden;
    transition: border-color .2s, box-shadow .2s;
}
.prx-home-block--owner:hover {
    border-color: #dbe0ea;
}
.prx-home-block--owner.prx-home-block--is-hidden {
    background: #fafbfc;
    border-color: #e4e8ef;
    border-style: dashed;
}
.prx-home-block--owner.prx-home-block--is-hidden:hover {
    border-color: #d7dde7;
}

/* ── Owner bar: единая шапка над каждым блоком ──────────────────────
   Иконка + название + бейдж статуса + шестерёнка. Виден только owner'у. */
.prx-home-block__bar {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 12px 12px 14px;
    background: transparent;
    border: none;
    border-radius: 0;
    margin-bottom: 0;
    transition: background .15s;
}
.prx-home-block--owner:not(.prx-home-block--is-hidden) .prx-home-block__bar {
    border-bottom: 1px solid #eef1f6;
}
.prx-home-block--is-hidden .prx-home-block__bar {
    /* В скрытом состоянии — никакого разделителя, карточка "дышит" единым фоном */
}
.prx-home-block__bar-main {
    display: flex; align-items: center; gap: 10px;
    flex: 1; min-width: 0;
}
.prx-home-block__bar-icon {
    width: 30px; height: 30px; flex: 0 0 30px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 8px;
    background: #eef2ff;
    color: var(--color-primary,#0a43ff);
    font-size: 13px;
    transition: background .15s, color .15s;
}
.prx-home-block--is-hidden .prx-home-block__bar-icon {
    background: #f1f5f9; color: #94a3b8;
}
.prx-home-block__bar-title {
    font-size: 14px; font-weight: 700;
    color: #0f172a; letter-spacing: -.005em;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    min-width: 0;
}
.prx-home-block--is-hidden .prx-home-block__bar-title { color: #475569; }

.prx-home-block__badge {
    display: inline-flex; align-items: center; gap: 5px;
    height: 22px; padding: 0 9px;
    border-radius: 999px;
    font-size: 11px; font-weight: 700;
    letter-spacing: .02em;
    background: #ecfdf5; color: #047857;
    border: 1px solid #d1fae5;
    flex-shrink: 0;
}
.prx-home-block__badge--off {
    background: #f1f5f9; color: #64748b;
    border-color: #e2e8f0;
}
.prx-home-block__badge i { font-size: 9px; }

.prx-home-block__bar-actions {
    display: inline-flex; align-items: center; gap: 4px;
    flex-shrink: 0;
}
.prx-home-block__btn {
    width: 34px; height: 34px; border-radius: 8px;
    background: #fff; border: 1px solid #e2e8f0;
    color: #64748b; cursor: pointer; flex-shrink: 0;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 13px;
    transition: background .15s, color .15s, border-color .15s, transform .1s;
    position: relative; z-index: 2;
}
.prx-home-block__btn:hover:not(:disabled) {
    background: #eff6ff; color: var(--color-primary,#0a43ff); border-color: var(--color-primary,#0a43ff);
}
.prx-home-block__btn:active:not(:disabled) { transform: scale(.95); }
.prx-home-block--is-hidden .prx-home-block__btn {
    background: #fff; border-color: #dfe5ee;
}
/* Reorder-стрелки — компактнее настроек, чтобы не доминировать в баре. */
.prx-home-block__btn--reorder { width: 30px; height: 30px; font-size: 11px; }
.prx-home-block__btn:disabled {
    opacity: .35; cursor: default; background: #f8fafc; color: #94a3b8;
}
.prx-home-block__btn.is-busy { pointer-events: none; opacity: .5; }

/* Hint-line под bar'ом у скрытых блоков — только информация, не кликается. */
.prx-home-block__hint {
    padding: 12px 16px 14px;
    border-top: 1px dashed #e4e8ef;
    color: #94a3b8; font-size: 12.5px;
}
.prx-home-block__hint-body { flex: 1; }

/* Body — контейнер контента внутри карточки (только owner). Даёт единый padding
   и отделяется от bar'а через border-bottom bar'а. */
.prx-home-block__body {
    padding: 16px 16px 18px;
}

/* Внутренний head над контентом (для гостя — с названием, для owner — только actions) */
.prx-home-block__head {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; margin-bottom: 12px; min-width: 0;
}
.prx-home-block__head--actions-only { justify-content: flex-end; }
.prx-home-block__section-title { font-size: 15px; font-weight: 800; color: #1e293b; }
.prx-home-block__section-more {
    font-size: 13px; font-weight: 600;
    color: var(--color-primary,#0a43ff);
    background: none; border: none;
    cursor: pointer; padding: 4px 0;
    transition: opacity .15s;
}
.prx-home-block__section-more:hover { opacity: .7; }

.prx-home-block__title {
    font-size: 18px; font-weight: 800; color: #0f172a;
    margin: 0 0 10px; line-height: 1.35; word-break: break-word;
}
.prx-home-block__text {
    font-size: 14px; color: #334155; line-height: 1.65;
    word-break: break-word; white-space: pre-wrap;
}

/* Пустое состояние включённого текстового блока (приглашение ввести текст) */
.prx-home-block__empty {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    padding: 16px;
    background: #fafbfc;
    border: 1.5px dashed #e2e8f0;
    border-radius: 12px;
    color: #64748b; font-size: 13px; font-weight: 600;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s;
}
.prx-home-block__empty:hover {
    background: #eff6ff; border-color: var(--color-primary,#0a43ff);
    color: var(--color-primary,#0a43ff);
}
.prx-home-block__empty i { font-size: 14px; }

/* ── Home slider (recent_products) ─────────────────────────────────
   Горизонтальный скроллер в стиле Патреона: scroll-snap + кнопки ← →.
   Без внешних либ — native CSS + минимальный JS.                    */
.prx-home-block__head-left { display: flex; align-items: center; gap: 12px; min-width: 0; }
.prx-hs-nav { display: flex; gap: 6px; flex-shrink: 0; }
.prx-hs-arrow {
    width: 34px; height: 34px; border-radius: 50%;
    background: #fff; border: 1px solid #e2e8f0;
    color: #475569; font-size: 12px; cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .15s, color .15s, border-color .15s, opacity .15s;
}
.prx-hs-arrow:hover:not([disabled]) {
    background: var(--color-primary,#0a43ff); color: #fff; border-color: var(--color-primary,#0a43ff);
}
.prx-hs-arrow[disabled] { opacity: .35; cursor: default; }

.prx-hs {
    position: relative;
    margin: 0 -4px;  /* чтобы slide-padding не смещал контент */
}
.prx-hs__track {
    display: flex; gap: 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding: 2px 4px 10px;
    /* Скрываем скроллбар визуально, но оставляем скролл */
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.prx-hs__track::-webkit-scrollbar { display: none; }
.prx-hs__slide {
    flex: 0 0 calc((100% - 24px) / 3);  /* 3 в ряд на десктопе */
    scroll-snap-align: start;
    min-width: 0;
}
.prx-hs__slide .prx-fp-card { height: 100%; }

@media (max-width: 900px) {
    .prx-hs__slide { flex: 0 0 calc((100% - 12px) / 2); }  /* 2 в ряд */
}
@media (max-width: 560px) {
    .prx-hs__slide { flex: 0 0 82%; }                       /* 1 с превью следующей */
}

/* ── Gift-wall в home-блоке «Подарки» ─────────────────────────────────
   Горизонтальная полоса до края контейнера. JS считает сколько карточек
   влезает в одну строку, лишние прячет, последнюю позицию занимает
   кнопка «+N» (открывает gift-wall модалку с полным списком).
   Никакого wrap'а, никакого скролла — только что-влезает + счётчик. */
.prx-gw {
    display: flex;
    gap: 14px;
    flex-wrap: nowrap;
    padding: 4px 2px 6px;
    width: 100%;
    min-width: 0;
    overflow: hidden;
}
.prx-gw .prx-gw__card[hidden],
.prx-gw .prx-gw__more[hidden] { display: none; }
.prx-gw__count {
    display: inline-block;
    margin-left: 4px;
    font-size: 11px;
    font-weight: 700;
    color: #94a3b8;
    background: #f1f5f9;
    padding: 2px 7px;
    border-radius: 999px;
    vertical-align: middle;
}
/* Card — без хром-обводки и фона, чтобы анимированный подарок (APNG/WebP)
   читался как «висящий» предмет, а не как иконка в сером боксе. Hover —
   мягкий lift, без border'а. */
.prx-gw__card {
    position: relative;
    width: 84px; height: 84px;
    flex-shrink: 0;
    border: 0;
    background: transparent;
    border-radius: 16px;
    cursor: pointer;
    transition: transform .15s ease, filter .15s ease;
    padding: 0;
    overflow: visible;
}
.prx-gw__card:hover {
    transform: translateY(-2px);
    filter: drop-shadow(0 6px 14px rgba(15, 23, 42, .12));
}
.prx-gw__card:active { transform: scale(.97); }
.prx-gw__media {
    position: absolute; inset: 0;
    border-radius: 16px;
    overflow: hidden;
    display: flex; align-items: center; justify-content: center;
    color: #94a3b8; font-size: 30px;
}
.prx-gw__media img {
    width: 100%; height: 100%; object-fit: contain; display: block;
}
.prx-gw__sender {
    position: absolute; right: -4px; bottom: -4px;
    width: 28px; height: 28px;
    border-radius: 50%;
    border: 2px solid #fff;
    background: #e0e7ff;
    overflow: hidden;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 1px 3px rgba(15,23,42,.18);
}
.prx-gw__sender img { width: 100%; height: 100%; object-fit: cover; }
.prx-gw__sender-fallback {
    font-size: 12px; font-weight: 800; color: #4338ca;
}
/* «+N» — единственный элемент с явным chrome'ом, отличает CTA от подарков. */
.prx-gw__more {
    width: 84px; height: 84px;
    flex-shrink: 0;
    border: 1px dashed #cbd5e1;
    background: transparent;
    border-radius: 16px;
    cursor: pointer;
    font-weight: 800; color: #64748b; font-size: 16px;
    display: inline-flex; align-items: center; justify-content: center;
    transition: border-color .15s, color .15s, background .15s, transform .1s;
}
.prx-gw__more:hover {
    border-color: var(--color-primary, #0a43ff);
    color: var(--color-primary, #0a43ff);
    background: #f8faff;
}
.prx-gw__more:active { transform: scale(.97); }

/* ── Home-blocks settings modal ────────────────────────────────────── */
.prx-hb-modal { display: none; position: fixed; inset: 0; z-index: 1000100; align-items: center; justify-content: center; padding: 20px; }
.prx-hb-modal.is-open { display: flex; }
.prx-hb-modal__backdrop { position: absolute; inset: 0; background: rgba(15,23,42,.55); backdrop-filter: blur(4px); }
.prx-hb-modal__box {
    position: relative; z-index: 2;
    width: 100%; max-width: 520px; max-height: 86vh;
    background: #fff; border-radius: 16px; overflow: hidden;
    display: flex; flex-direction: column;
    box-shadow: 0 20px 60px rgba(15,23,42,.25);
}
.prx-hb-modal__head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 20px; border-bottom: 1px solid #e2e8f0;
}
.prx-hb-modal__title { font-size: 16px; font-weight: 800; color: #0f172a; }
.prx-hb-modal__close {
    width: 32px; height: 32px; border-radius: 8px;
    background: transparent; border: none; cursor: pointer;
    color: #64748b; font-size: 20px; line-height: 1;
}
.prx-hb-modal__close:hover { background: #f1f5f9; color: #0f172a; }
.prx-hb-modal__body { padding: 18px 20px; overflow: auto; }
.prx-hb-modal__foot {
    padding: 14px 20px; border-top: 1px solid #e2e8f0;
    display: flex; justify-content: flex-end; gap: 10px;
    background: #f8fafc;
}

/* Toggle switch */
.prx-hb-toggle {
    display: flex; align-items: center; gap: 14px;
    padding: 12px 14px; border-radius: 12px;
    background: #f8fafc; margin-bottom: 16px;
    border: 1px solid #e2e8f0;
}
.prx-hb-toggle__label { flex: 1; min-width: 0; }
.prx-hb-toggle__title { font-size: 14px; font-weight: 700; color: #1e293b; margin-bottom: 2px; }
.prx-hb-toggle__sub   { font-size: 12px; color: #94a3b8; }
.prx-hb-switch { position: relative; width: 44px; height: 24px; flex: 0 0 44px; }
.prx-hb-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.prx-hb-switch__slider {
    position: absolute; inset: 0; border-radius: 24px;
    background: #cbd5e1; cursor: pointer; transition: background .2s;
}
.prx-hb-switch__slider::before {
    content: ""; position: absolute; width: 18px; height: 18px;
    left: 3px; top: 3px; border-radius: 50%;
    background: #fff; transition: transform .2s;
    box-shadow: 0 1px 3px rgba(0,0,0,.15);
}
.prx-hb-switch input:checked + .prx-hb-switch__slider { background: var(--color-primary,#0a43ff); }
.prx-hb-switch input:checked + .prx-hb-switch__slider::before { transform: translateX(20px); }

/* Form fields */
.prx-hb-field { margin-bottom: 14px; }
.prx-hb-field:last-child { margin-bottom: 0; }
.prx-hb-field__label { display: block; font-size: 12px; font-weight: 700; color: #475569; margin-bottom: 6px; letter-spacing: .02em; text-transform: uppercase; }
.prx-hb-field__input,
.prx-hb-field__textarea,
.prx-hb-field__select {
    width: 100%; padding: 10px 12px;
    border: 1px solid #cbd5e1; border-radius: 10px;
    font-size: 14px; font-family: inherit; color: #0f172a;
    background: #fff; transition: border-color .15s, box-shadow .15s;
    outline: none;
}
.prx-hb-field__input:focus,
.prx-hb-field__textarea:focus,
.prx-hb-field__select:focus {
    border-color: var(--color-primary,#0a43ff);
    box-shadow: 0 0 0 3px rgba(10,67,255,.12);
}
.prx-hb-field__textarea { resize: vertical; min-height: 120px; line-height: 1.55; }
.prx-hb-field__counter { font-size: 11px; color: #94a3b8; margin-top: 4px; text-align: right; }

/* Buttons */
.prx-hb-btn {
    padding: 10px 18px; border-radius: 10px;
    font-size: 13px; font-weight: 700; cursor: pointer;
    border: 1px solid transparent; transition: background .15s, color .15s, border-color .15s;
    font-family: inherit;
}
.prx-hb-btn--primary { background: var(--color-primary,#0a43ff); color: #fff; }
.prx-hb-btn--primary:hover { background: var(--color-primary--hover,#002fd8); }
.prx-hb-btn--primary[disabled] { opacity: .55; cursor: default; }
.prx-hb-btn--ghost { background: #fff; color: #475569; border-color: #cbd5e1; }
.prx-hb-btn--ghost:hover { background: #f1f5f9; color: #0f172a; }

/* Product picker modal */
.prx-pp-modal { display: none; position: fixed; inset: 0; z-index: 1000100; align-items: center; justify-content: center; padding: 20px; }
.prx-pp-modal.is-open { display: flex; }
.prx-pp-modal__backdrop { position: absolute; inset: 0; background: rgba(15,23,42,.55); backdrop-filter: blur(4px); cursor: pointer; }
.prx-pp-modal__box {
    position: relative; background: #fff; border-radius: 20px;
    padding: 20px 22px; max-width: 520px; width: 100%;
    max-height: calc(100vh - 40px); display: flex; flex-direction: column;
    box-shadow: 0 24px 64px rgba(0,0,0,.18);
    transform: scale(.94) translateY(20px); opacity: 0;
    transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .2s ease;
}
.prx-pp-modal.is-open .prx-pp-modal__box { transform: scale(1) translateY(0); opacity: 1; }
.prx-pp-modal__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; flex-shrink: 0; }
.prx-pp-modal__title { font-size: 17px; font-weight: 800; color: #0f172a; }
.prx-pp-modal__close { width: 30px; height: 30px; border-radius: 8px; background: #f1f5f9; border: none; font-size: 18px; cursor: pointer; color: #64748b; display: flex; align-items: center; justify-content: center; }
.prx-pp-modal__close:hover { background: #e2e8f0; }
.prx-pp-modal__search {
    width: 100%; padding: 10px 12px; border-radius: 10px;
    border: 1px solid #e2e8f0; font-size: 13px; margin-bottom: 12px;
    outline: none; transition: border-color .15s;
    flex-shrink: 0;
}
.prx-pp-modal__search:focus { border-color: var(--color-primary,#0a43ff); }
.prx-pp-modal__list { flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 8px; padding-right: 4px; }
.prx-pp-item {
    display: flex; gap: 10px; align-items: center;
    padding: 8px; border-radius: 10px; border: 1px solid #e2e8f0; background: #fff;
    cursor: pointer; transition: background .15s, border-color .15s;
}
.prx-pp-item:hover:not(.is-disabled) { background: #f8fafc; border-color: #cbd5e1; }
.prx-pp-item.is-disabled { opacity: .5; cursor: not-allowed; }
.prx-pp-item__prev {
    width: 54px; height: 44px; border-radius: 7px;
    background: linear-gradient(135deg,#f1f5f9,#e2e8f0);
    overflow: hidden; flex-shrink: 0; position: relative;
}
.prx-pp-item__prev img { width: 100%; height: 100%; object-fit: cover; display: block; }
.prx-pp-item__prev-ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 18px; color: #94a3b8; }
.prx-pp-item__body { flex: 1; min-width: 0; }
.prx-pp-item__title { font-size: 13px; font-weight: 700; color: #1e293b; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.prx-pp-item__meta { font-size: 12px; color: #64748b; margin-top: 2px; display: flex; gap: 8px; align-items: center; }
.prx-pp-item__badge { font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 999px; background: #eff6ff; color: #2563eb; letter-spacing: .02em; text-transform: uppercase; }
.prx-pp-empty { text-align: center; color: #94a3b8; padding: 20px 10px; font-size: 13px; }
/* ── Post stubs ─────────────────────────────────────────────────────── */
.prx-post-stubs { display: flex; flex-direction: column; gap: 14px; padding: 4px 0; }
.prx-post-stub {
    display: flex; gap: 14px; padding: 14px; background: #f8fafc;
    border: 1px solid #e2e8f0; border-radius: 12px; overflow: hidden;
}
.prx-post-stub__img {
    width: 72px; height: 72px; border-radius: 8px; background: #e2e8f0;
    flex-shrink: 0; overflow: hidden;
}
.prx-post-stub__body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 6px; justify-content: center; }
.prx-post-stub__line {
    height: 12px; border-radius: 6px; background: #e2e8f0;
    filter: blur(2px);
}
.prx-post-stub__line--title  { width: 70%; height: 14px; }
.prx-post-stub__line--text   { width: 90%; }
.prx-post-stub__line--text2  { width: 55%; }
.prx-post-stub__line--meta   { width: 35%; height: 10px; }

/* ── Award grid ─────────────────────────────────────────────────────── */
/* Лаконичная карточка: [tier-dots][icon][name][desc].
   Прогресс-бар, «X/Y → Next», «Максимум достигнут» и другие детали
   живут только в модалке, которая открывается при клике на карточку. */
.prx-award-section { margin-bottom: 28px; }
.prx-award-section__title { font-size: 13px; font-weight: 700; color: #94a3b8; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 12px; }
/* Горизонтальный свайп-ряд наград — единое поведение на десктопе и мобилке.
   Вертикальные padding'и дают место для glow/shadow-эффектов tier-3..5
   (иначе overflow-y: hidden режет тени и hover-поднятие выглядит обрезанным).
   Negative margin компенсирует визуальное смещение секции. */
.prx-award-grid {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
    padding: 18px 2px 24px;
    margin: -18px -2px -12px;
    align-items: stretch;
}
.prx-award-grid::-webkit-scrollbar { height: 6px; }
.prx-award-grid::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 3px; }
.prx-award-grid::-webkit-scrollbar-thumb:hover { background: #94a3b8; }
.prx-award-grid::-webkit-scrollbar-track { background: transparent; }
.prx-award-grid > .prx-award-card {
    flex: 0 0 auto;
    width: 160px;
    scroll-snap-align: start;
}
.prx-award-card {
    display: flex; flex-direction: column; align-items: center;
    min-height: 170px;
    border: 1.5px solid #e2e8f0; border-radius: 14px; padding: 14px 12px;
    text-align: center; background: #fff; cursor: pointer;
    transition: box-shadow .18s, border-color .18s, transform .12s;
}
.prx-award-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.09); border-color: #c7d2fe; transform: translateY(-2px); }
.prx-award-card--pending { background: #f8fafc; }
.prx-award-card--pending .prx-award-card__icon { filter: saturate(.55); opacity: .85; }
.prx-award-card--pending:hover { border-color: #c8d0e0; }
.prx-award-card--locked { background: #f8fafc; cursor: default; pointer-events: none; }
.prx-award-card--locked .prx-award-card__icon { filter: grayscale(1); opacity: .5; }
.prx-award-card--locked .prx-award-card__name,
.prx-award-card--locked .prx-award-card__desc { opacity: .6; }

.prx-award-card__icon {
    width: 52px; height: 52px; border-radius: 14px; margin: 0 auto 10px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.prx-award-card__icon i   { font-size: 24px; line-height: 1; }
.prx-award-card__name { font-size: 12px; font-weight: 700; color: #334155; line-height: 1.3; margin-bottom: 4px; }
.prx-award-card__desc { font-size: 11px; color: #94a3b8; line-height: 1.4; }

/* ── Выделение ТОПОВЫХ earned-наград (tier_current ≥ 3) ──────────────────
   Применяется только к полученным наградам. Прогрессивная интенсивность:
   tier 3 — золотой halo, tier 4 — pink + shimmer, tier 5 — rainbow + pulse.
   Для progress/locked эффекты НЕ применяются (выделение заслужено). */
.prx-award-card--tier-3,
.prx-award-card--tier-4,
.prx-award-card--tier-5 {
    /* Общий приподнимающий эффект */
    border-width: 2px;
    position: relative;
    overflow: hidden;
}

/* ── tier 3 — Легендарный (amber/gold glow + градиент иконки) ────────── */
.prx-award-card--tier-3 {
    border-color: transparent;
    background:
        linear-gradient(#fff, #fff) padding-box,
        linear-gradient(135deg, #fde68a, #f59e0b, #fde68a) border-box;
    box-shadow: 0 0 0 1px rgba(245,158,11,.08), 0 4px 14px rgba(245,158,11,.16);
}
.prx-award-card--tier-3:hover {
    box-shadow: 0 0 0 1px rgba(245,158,11,.15), 0 6px 18px rgba(245,158,11,.24);
}
/* Золотой градиент на иконке (через background-clip: text) */
.prx-award-card--tier-3 .prx-award-card__icon i {
    background: linear-gradient(135deg, #fcd34d 0%, #f59e0b 50%, #b45309 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* ── tier 4 — Эпический (pink + shimmer) ─────────────────────────────── */
.prx-award-card--tier-4 {
    border-color: transparent;
    background:
        linear-gradient(#fff, #fff) padding-box,
        linear-gradient(135deg, #f9a8d4, #ec4899, #f9a8d4) border-box;
    box-shadow: 0 0 0 1px rgba(236,72,153,.10), 0 4px 14px rgba(236,72,153,.18);
}
.prx-award-card--tier-4:hover {
    box-shadow: 0 0 0 1px rgba(236,72,153,.18), 0 6px 18px rgba(236,72,153,.28);
}
/* Pink→magenta градиент на иконке */
.prx-award-card--tier-4 .prx-award-card__icon i {
    background: linear-gradient(135deg, #f472b6 0%, #ec4899 50%, #be185d 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    position: relative; z-index: 1;  /* иконка выше shimmer-блика */
}
/* Двигающийся блик по иконке раз в 6 секунд */
.prx-award-card--tier-4 .prx-award-card__icon::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,.6) 50%, transparent 70%);
    transform: translateX(-120%);
    animation: prx-award-shimmer 6s ease-in-out infinite;
    pointer-events: none;
}

/* ── tier 5 — Мифический (rainbow + pulse + sparkle) ─────────────────── */
.prx-award-card--tier-5 {
    border-color: transparent;
    background:
        linear-gradient(#fff, #fff) padding-box,
        conic-gradient(from 90deg, #a855f7, #ec4899, #f59e0b, #10b981, #6366f1, #a855f7) border-box;
    box-shadow: 0 0 0 1px rgba(168,85,247,.12), 0 5px 18px rgba(168,85,247,.22);
    animation: prx-award-pulse 3.2s ease-in-out infinite;
}
.prx-award-card--tier-5:hover {
    box-shadow: 0 0 0 2px rgba(168,85,247,.22), 0 8px 24px rgba(168,85,247,.32);
}
/* Радужный градиент на иконке + медленное движение gradient shift */
.prx-award-card--tier-5 .prx-award-card__icon i {
    background: linear-gradient(135deg,
        #a855f7 0%, #ec4899 30%, #f59e0b 55%, #10b981 80%, #6366f1 100%);
    background-size: 200% 200%;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    animation: prx-award-gradient-shift 6s ease-in-out infinite;
}
@keyframes prx-award-shimmer {
    0%, 70%  { transform: translateX(-120%); }
    85%, 100%{ transform: translateX(120%);  }
}
@keyframes prx-award-pulse {
    0%, 100% { box-shadow: 0 0 0 1px rgba(168,85,247,.12), 0 5px 18px rgba(168,85,247,.22); }
    50%      { box-shadow: 0 0 0 2px rgba(168,85,247,.20), 0 8px 24px rgba(168,85,247,.30); }
}
/* Плавное "перетекание" радужного градиента на иконке (tier 5) */
@keyframes prx-award-gradient-shift {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}

/* Уважаем пользователей с prefers-reduced-motion — отключаем анимации */
@media (prefers-reduced-motion: reduce) {
    .prx-award-card--tier-4 .prx-award-card__icon::before,
    .prx-award-card--tier-5,
    .prx-award-card--tier-5 .prx-award-card__icon i {
        animation: none !important;
    }
    .prx-award-card--tier-4 .prx-award-card__icon::before { display: none; }
}

/* Индикатор уровней цепочки (◉ ◉ ○) — всегда рендерится (min-height зарезервирован) */
.prx-award-card__tiers {
    display: flex; gap: 5px; justify-content: center;
    min-height: 8px; margin-bottom: 10px;
}
.prx-award-card__tier-dot {
    width: 6px; height: 6px; border-radius: 50%; background: #cbd5e1;
    transition: background .25s;
}
.prx-award-card__tier-dot--active { background: currentColor; }

/* ── Кнопка "глаз" для владельца: скрыть/показать награду ───────────────
   Появляется только на карточках владельца профиля. Клик переключает
   is_hidden в таблице user_hidden_awards. Для гостей награда невидима. */
.prx-award-card { position: relative; } /* обеспечиваем anchor для absolute-кнопки */
.prx-award-card__toggle {
    position: absolute; top: 8px; right: 8px; z-index: 3;
    width: 26px; height: 26px; border-radius: 7px;
    background: rgba(255,255,255,.85); border: 1px solid #e2e8f0;
    color: #94a3b8; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; line-height: 1;
    transition: background .15s, color .15s, border-color .15s, transform .12s;
    opacity: 0;                           /* скрыт по умолчанию */
}
.prx-award-card:hover .prx-award-card__toggle,
.prx-award-card__toggle:focus-visible,
.prx-award-card__toggle.is-hidden { opacity: 1; }  /* показываем на hover или если уже скрыта */
.prx-award-card__toggle:hover {
    background: #fff; color: #334155; border-color: #cbd5e1; transform: scale(1.06);
}
.prx-award-card__toggle.is-hidden { color: #6366f1; border-color: #c7d2fe; }

/* Скрытая от гостей карточка (видна только владельцу как приглушённая) */
.prx-award-card--hidden-self { opacity: .55; }
.prx-award-card--hidden-self:hover { opacity: .9; }
.prx-award-card__hidden-label {
    margin-top: 6px; font-size: 10px; font-weight: 700; color: #6366f1;
    letter-spacing: .04em; text-transform: uppercase;
}

/* ── Award modal ────────────────────────────────────────────────────── */
.prx-aw-modal {
    display: none; position: fixed; inset: 0; z-index: 1000100;
    align-items: center; justify-content: center; padding: 20px;
}
.prx-aw-modal.is-open { display: flex; }
.prx-aw-modal__backdrop {
    position: absolute; inset: 0; background: rgba(15,23,42,.55);
    backdrop-filter: blur(4px); cursor: pointer;
}
.prx-aw-modal__box {
    position: relative; background: #fff; border-radius: 20px;
    padding: 24px 28px 28px; max-width: 360px; width: 100%;
    box-shadow: 0 24px 64px rgba(0,0,0,.18);
    transform: scale(.88) translateY(20px); opacity: 0;
    transition: transform .35s cubic-bezier(.34,1.56,.64,1), opacity .25s ease;
}
.prx-aw-modal.is-open .prx-aw-modal__box { transform: scale(1) translateY(0); opacity: 1; }
.prx-aw-modal__topbar {
    display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px;
}
.prx-aw-modal__pill {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 12px 4px 7px; border-radius: 20px;
    font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
}
.prx-aw-modal__pill--earned   { background: #d1fae5; color: #065f46; }
.prx-aw-modal__pill--progress { background: #ede9fe; color: #5b21b6; }
.prx-aw-modal__close {
    width: 30px; height: 30px; border-radius: 8px; background: #f1f5f9;
    border: none; font-size: 18px; cursor: pointer; color: #64748b;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.prx-aw-modal__close:hover { background: #e2e8f0; }
.prx-aw-modal__icon-wrap {
    width: 90px; height: 90px; border-radius: 24px;
    display: flex; align-items: center; justify-content: center;
}
.prx-aw-modal__icon-wrap i   { font-size: 44px; line-height: 1; }
/* Ряд: [‹]  [icon]  [›] — стрелки tier-нав, расположены симметрично иконке. */
.prx-aw-modal__icon-row {
    display: flex; align-items: center; justify-content: center;
    gap: 14px; margin: 0 auto 16px;
}
.prx-aw-modal__nav {
    width: 36px; height: 36px; border-radius: 50%;
    background: #f1f5f9; border: 1px solid #e2e8f0;
    color: #475569; font-size: 22px; line-height: 1;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; flex-shrink: 0; padding: 0;
    transition: background .15s, border-color .15s, transform .15s, color .15s, opacity .15s;
    user-select: none;
}
.prx-aw-modal__nav:hover:not(:disabled) { background: #e2e8f0; border-color: #cbd5e1; color: #1e293b; transform: translateY(-1px); }
.prx-aw-modal__nav:disabled { opacity: .35; cursor: default; }
.prx-aw-modal__nav[hidden]  { display: none !important; }
.prx-aw-modal__name { font-size: 20px; font-weight: 800; color: #1e293b; text-align: center; margin-bottom: 8px; }
.prx-aw-modal__desc { font-size: 14px; color: #64748b; text-align: center; line-height: 1.55; margin-bottom: 16px; }
.prx-aw-modal__progress-label { font-size: 12px; color: #94a3b8; text-align: center; margin-bottom: 6px; }
.prx-aw-modal__progress-wrap { background: #f1f5f9; border-radius: 6px; height: 8px; overflow: hidden; margin-bottom: 4px; }
.prx-aw-modal__progress-bar  { height: 100%; border-radius: 6px; background: linear-gradient(90deg,#818cf8,#a78bfa); transition: width .6s cubic-bezier(.34,1.56,.64,1); }
.prx-aw-modal__progress-nums { font-size: 12px; color: #94a3b8; text-align: center; }
.prx-aw-modal__status {
    margin-top: 10px; padding: 8px 12px; border-radius: 10px;
    font-size: 13px; font-weight: 600; text-align: center;
}
.prx-aw-modal__status--max { background: #d1fae5; color: #065f46; }
.prx-aw-modal__tier-info {
    text-align: center; margin: -4px 0 12px;
    display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.prx-aw-modal__tier-dots { display: flex; gap: 7px; align-items: center; }
.prx-aw-modal__tier-dots button {
    width: 7px; height: 7px; border-radius: 50%;
    background: #cbd5e1;          /* locked default */
    border: none; padding: 0; cursor: pointer;
    transition: transform .15s, background .15s, box-shadow .15s;
}
.prx-aw-modal__tier-dots button:hover       { transform: scale(1.2); }
.prx-aw-modal__tier-dots button.is-earned   { background: #6366f1; }
.prx-aw-modal__tier-dots button.is-progress { background: #a5b4fc; }
.prx-aw-modal__tier-dots button.is-locked   { background: #cbd5e1; }
.prx-aw-modal__tier-dots button.is-current  {
    transform: scale(1.35);
    box-shadow: 0 0 0 2px rgba(99,102,241,.18);
}

/* ── Градиенты иконки в модалке (tier 3/4/5) ─────────────────────────── */
/* Крупная иконка (90×90, i font-size:44px) получает тот же градиент,
   что и на карточке — визуальная консистентность между карточкой и модалкой. */

/* tier 3 — Легендарный (золото) */
.prx-aw-modal--tier-3 .prx-aw-modal__icon-wrap i {
    background: linear-gradient(135deg, #fcd34d 0%, #f59e0b 50%, #b45309 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.prx-aw-modal--tier-3 .prx-aw-modal__icon-wrap {
    box-shadow: 0 0 0 2px rgba(245,158,11,.12), 0 10px 30px rgba(245,158,11,.25);
}

/* tier 4 — Эпический (pink → magenta) */
.prx-aw-modal--tier-4 .prx-aw-modal__icon-wrap i {
    background: linear-gradient(135deg, #f472b6 0%, #ec4899 50%, #be185d 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.prx-aw-modal--tier-4 .prx-aw-modal__icon-wrap {
    box-shadow: 0 0 0 2px rgba(236,72,153,.14), 0 10px 30px rgba(236,72,153,.28);
}

/* tier 5 — Мифический (радуга + движение) */
.prx-aw-modal--tier-5 .prx-aw-modal__icon-wrap i {
    background: linear-gradient(135deg,
        #a855f7 0%, #ec4899 30%, #f59e0b 55%, #10b981 80%, #6366f1 100%);
    background-size: 200% 200%;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    animation: prx-award-gradient-shift 6s ease-in-out infinite;
}
.prx-aw-modal--tier-5 .prx-aw-modal__icon-wrap {
    box-shadow: 0 0 0 2px rgba(168,85,247,.18), 0 12px 36px rgba(168,85,247,.35);
}
@media (prefers-reduced-motion: reduce) {
    .prx-aw-modal--tier-5 .prx-aw-modal__icon-wrap i { animation: none !important; }
}
.prx-aw-modal__tier-label {
    font-size: 11px; color: #64748b; font-weight: 700;
    letter-spacing: .04em; text-transform: uppercase;
}

/* Бейдж редкости внутри модалки — под именем награды */
.prx-aw-modal__rarity {
    display: flex; align-items: center; justify-content: center;
    width: fit-content;
    margin: 0 auto 14px;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    line-height: 1.25;
    letter-spacing: .08em;
    text-transform: uppercase;
    border: 1px solid transparent;
    white-space: nowrap;
}
.prx-aw-modal__rarity--tier-1 { background:#ecfdf5; color:#047857; border-color:#a7f3d0; }
.prx-aw-modal__rarity--tier-2 { background:#eef2ff; color:#4338ca; border-color:#c7d2fe; }
.prx-aw-modal__rarity--tier-3 { background:#fef3c7; color:#92400e; border-color:#fcd34d; }
.prx-aw-modal__rarity--tier-4 { background:#fce7f3; color:#9d174d; border-color:#f9a8d4; }
.prx-aw-modal__rarity--tier-5 {
    color:#fff; border-color: transparent;
    background: linear-gradient(90deg, #a855f7, #ec4899 45%, #f59e0b 75%, #a855f7);
    background-size: 200% 100%;
    animation: prx-award-gradient-shift 6s ease-in-out infinite;
    text-shadow: 0 1px 1px rgba(0,0,0,.18);
}
@media (prefers-reduced-motion: reduce) {
    .prx-aw-modal__rarity--tier-5 { animation: none !important; }
}

/* ── Cover upload modal ─────────────────────────────────────────────── */
.prx-cv-modal {
    display: none; position: fixed; inset: 0; z-index: 1000100;
    align-items: center; justify-content: center; padding: 20px;
}
.prx-cv-modal.is-open { display: flex; }
.prx-cv-modal__backdrop {
    position: absolute; inset: 0; background: rgba(15,23,42,.55);
    backdrop-filter: blur(4px); cursor: pointer;
}
.prx-cv-modal__box {
    position: relative; background: #fff; border-radius: 20px;
    padding: 24px 24px 22px; max-width: 460px; width: 100%;
    box-shadow: 0 24px 64px rgba(0,0,0,.18);
    transform: scale(.92) translateY(20px); opacity: 0;
    transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .2s ease;
    max-height: calc(100vh - 40px); overflow-y: auto;
}
.prx-cv-modal.is-open .prx-cv-modal__box { transform: scale(1) translateY(0); opacity: 1; }
.prx-cv-modal__head {
    display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px;
}
.prx-cv-modal__title { font-size: 18px; font-weight: 800; color: #0f172a; }
.prx-cv-modal__close {
    width: 30px; height: 30px; border-radius: 8px; background: #f1f5f9;
    border: none; font-size: 18px; cursor: pointer; color: #64748b;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.prx-cv-modal__close:hover { background: #e2e8f0; }
.prx-cv-modal__preview {
    position: relative; width: 100%; aspect-ratio: 4 / 1;
    background: linear-gradient(to bottom, #1e3a8a 0%, #3b82f6 55%, #818cf8 100%);
    border-radius: 12px; overflow: hidden; margin-bottom: 16px;
    border: 1px solid #e2e8f0;
}
.prx-cv-modal__preview-fade {
    position: absolute; bottom: 0; left: 0; width: 100%; height: 30%;
    background: linear-gradient(transparent, #fff);
    pointer-events: none;
}
.prx-cv-modal__preview-guide {
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,.85); font-weight: 700; font-size: 12px;
    text-shadow: 0 1px 3px rgba(0,0,0,.4); letter-spacing: .02em;
}
.prx-cv-modal__list { list-style: none; padding: 0; margin: 0 0 16px; }
.prx-cv-modal__list li {
    display: flex; gap: 10px; align-items: flex-start;
    padding: 8px 0; font-size: 13px; color: #334155; line-height: 1.5;
    border-bottom: 1px solid #f1f5f9;
}
.prx-cv-modal__list li:last-child { border-bottom: 0; }
.prx-cv-modal__list li i {
    color: #3b82f6; font-size: 14px; margin-top: 2px; width: 16px; flex-shrink: 0; text-align: center;
}
.prx-cv-modal__list li b { color: #0f172a; font-weight: 700; }
.prx-cv-modal__actions { display: flex; gap: 10px; }
.prx-cv-modal__btn {
    flex: 1; padding: 11px 14px; border-radius: 10px; border: none;
    font-size: 14px; font-weight: 700; cursor: pointer; transition: background .15s;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
}
.prx-cv-modal__btn--primary { background: #3b82f6; color: #fff; }
.prx-cv-modal__btn--primary:hover { background: #2563eb; }
.prx-cv-modal__btn--primary:disabled { background: #cbd5e1; cursor: not-allowed; }
.prx-cv-modal__btn--ghost { background: #f1f5f9; color: #475569; }
.prx-cv-modal__btn--ghost:hover { background: #e2e8f0; }

/* ── Products infinite scroll (loader / sentinel / end state) ─────── */
.prx-products-more { position: relative; padding: 24px 0 8px; }
.prx-products-sentinel { height: 1px; }
.prx-products-loader {
    display: flex; align-items: center; justify-content: center; gap: 10px;
    color: #64748b; font-size: 13px; font-weight: 600;
    padding: 10px 0;
}
.prx-products-loader i { color: var(--color-primary, #0a43ff); font-size: 16px; }
.prx-products-end {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    color: #94a3b8; font-size: 13px; font-weight: 600;
    padding: 14px 0 4px;
}
.prx-products-end i { color: #10b981; font-size: 15px; }
.prx-products-more[data-exhausted="1"] .prx-products-loader   { display: none; }
.prx-products-more[data-exhausted="1"] .prx-products-loadmore { display: none; }
.prx-products-more[data-exhausted="1"] .prx-products-end      { display: flex !important; }

/* Load-more button: показывается после N авто-подгрузок, чтобы ограничить DOM.
   Когда [data-auto-capped="1"] → loader скрыт, кнопка видна. */
.prx-products-more[data-auto-capped="1"] .prx-products-loader   { display: none; }
.prx-products-more[data-auto-capped="1"] .prx-products-loadmore { display: inline-flex !important; }
.prx-products-loadmore {
    display: none; align-items: center; justify-content: center; gap: 8px;
    margin: 12px auto 4px; padding: 10px 22px;
    background: #fff; color: var(--color-primary, #0a43ff);
    border: 1.5px solid var(--color-primary, #0a43ff); border-radius: 10px;
    font-size: 14px; font-weight: 700; cursor: pointer;
    transition: background .15s, color .15s, transform .1s;
}
.prx-products-loadmore:hover {
    background: var(--color-primary, #0a43ff); color: #fff;
}
.prx-products-loadmore:active { transform: scale(.97); }
.prx-products-loadmore:disabled { opacity: .6; cursor: wait; }

/* ── Products responsive grid (auto-fit collapses empty tracks so single
   card centers instead of sticking to the left edge) ─────────────────── */
#prx-products-panel .products-list {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
    gap: 20px !important;
    justify-items: center;
}
#prx-products-panel .products-list .product-item {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 340px;
    box-sizing: border-box !important;
}

/* ── Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 860px) { .prx-layout { gap: 20px; } .prx-sidebar { width: 220px; } }
@media (max-width: 680px) {
    .prx-cover-wrap { width: 100%; }
    .prx-cover { height: 150px; border-radius: 0; }
    .prx-layout { flex-direction: column; gap: 0; }
    .prx-sidebar { width: 100%; margin-top: 0; padding: 0 0 8px; z-index: auto; }
    .prx-sticky-wrap { position: static; } /* no sticky on mobile */
    .prx-card { margin-top: 44px; padding-top: 54px; }
    .prx-ava-wrap { top: -39px; }
    .prx-ava, .prx-ava--initials { width: 88px; height: 88px; font-size: 28px; }
    .prx-main { padding-top: 8px; width: 100%; }
    /* Sticky tablist на мобиле + статичная раскладка БЕЗ horizontal-scroll.
       Раньше overflow-x: auto разрешал свайп влево/вправо («гуляющие» табы).
       Сейчас: 5 табов делятся поровну через flex:1 — никаких свайпов, ничего
       не двигается. `top` берётся из var --prx-header-h (sticky-wrap JS-script
       выставляет по реальной высоте `.menu`); fallback 62px = min-height: 56 + padding. */
    .prx-tabs {
        display: flex;
        gap: 4px;
        overflow: hidden;                       /* статика: ни вправо, ни влево не сдвинуть */
        position: sticky;
        top: var(--prx-header-h, 62px);
        z-index: 10;
        background: #fff;
        padding-top: 10px;
        padding-bottom: 6px;                    /* перекрывает border-bottom; sticky-фон без щели */
    }
    .prx-tab {
        flex: 1 1 0;                            /* равная ширина каждой вкладки */
        min-width: 0;                           /* разрешаем сжиматься ниже content-size */
        padding: 0 4px 5px;                     /* компакт по горизонтали */
        justify-content: center;
        font-size: 12px;
        text-align: center;
        overflow: hidden;
        text-overflow: ellipsis;                /* на узких экранах (≤340px) подстраховка */
    }
    /* На мобиле счётчики у табов не показываем — иначе «Подписки 1» получает
       лишний визуальный вес и текст уходит из центра ровного flex:1-слота.
       Все 5 табов теперь содержат только текст → строго центрированы. */
    .prx-tab-count { display: none; }
    /* Мобилка: карточки чуть компактнее + прячем scrollbar (на тач-устройствах
       он и так не нужен, жест скролла виден через snap-подсказки). */
    .prx-award-grid {
        gap: 10px;
        scrollbar-width: none;
    }
    .prx-award-grid::-webkit-scrollbar { display: none; height: 0; }
    .prx-award-grid > .prx-award-card {
        width: 140px;
    }
}

/* В диапазоне 481–680px cover согласуем с .container (90% центр) —
   без edge-to-edge, чтобы выровнять с контентом под ним. */
@media (min-width: 481px) and (max-width: 680px) {
    .prx-cover-wrap { width: 90%; }
    .prx-cover      { border-radius: 14px; }
}

/* Featured products: на узких экранах 1 колонка вместо auto-fill (2-3). */
@media (max-width: 499px) {
    .prx-fp-list { grid-template-columns: 1fr; }
}

/* Home blocks: модалка чуть выше на маленьких экранах + компактный bar */
@media (max-width: 640px) {
    .prx-hb-modal__box { max-height: 92vh; }
    .prx-home-block__bar { padding: 8px 8px 8px 10px; gap: 8px; }
    .prx-home-block__bar-icon { width: 28px; height: 28px; flex-basis: 28px; font-size: 12px; }
    .prx-home-block__bar-title { font-size: 13px; }
    .prx-home-block__badge { height: 20px; padding: 0 7px; font-size: 10px; }
    .prx-home-block__btn { width: 32px; height: 32px; }
    .prx-home-block__btn--reorder { width: 28px; height: 28px; }
    .prx-home-block__bar-actions { gap: 3px; }
    .prx-home-block__hint { padding: 10px 12px; font-size: 12px; }
}

/* ── Touch targets: WCAG AAA минимум 44×44 на тач-устройствах ─────────
   Применяется только для hover:none + pointer:coarse (телефоны, планшеты),
   на десктопе размеры остаются прежними, чтобы не ломать существующую раскладку. */
@media (hover: none) and (pointer: coarse) {
    .prx-btn { min-height: 44px; padding: 10px 14px; }
    .prx-btn--subscribe,
    .prx-btn--subscribed,
    .prx-btn--icon       { width: 44px; height: 44px; }
    .prx-card-menu__btn  { width: 40px; height: 40px; }
    .prx-pp-modal__close,
    .prx-cv-modal__close,
    .prx-aw-modal__close { width: 40px; height: 40px; font-size: 20px; }
    .prx-cover-edit__btn { padding: 10px 14px; min-height: 40px; }
    .prx-cover-delete    { width: 40px; height: 40px; }
    .prx-fp-card__remove { width: 32px; height: 32px; }
}

/* ── Product picker modal: bottom-sheet на узких экранах ───────────────
   max-height calc(100vh - 40px) на 320–480px оставляет слишком мало места
   для списка (после шапки, поиска и отступов). Делаем bottom-sheet на 90vh. */
@media (max-width: 480px) {
    .prx-pp-modal { padding: 0; align-items: flex-end; }
    .prx-pp-modal__box {
        max-width: 100%;
        width: 100%;
        height: 90vh;
        max-height: 90vh;
        border-radius: 20px 20px 0 0;
        padding: 16px 16px 24px;
    }
}

/* ── Readiness nudge на public profile (только owner-creator) ─────────
   Маленькая полоса под именем со ссылкой в студию. Минимальный footprint —
   не загораживает основной контент профиля. Прячется когда профиль готов
   на 100% (рендерится с server-side guard). */
.prx-readiness-nudge {
    /* display: flex + width: fit-content + margin: auto = pill принимает ширину
       по контенту и центрируется горизонтально в родителе. Раньше display: inline-flex
       не позволял margin: auto работать (для inline-элементов margin: auto в horizontal
       не центрирует), отчего pill прижимался к левому краю сайдбара. */
    display: flex;
    width: fit-content;
    align-items: center;
    gap: 10px;
    margin: 8px auto 4px;
    padding: 8px 14px;
    background: linear-gradient(90deg, rgba(10, 67, 255, .08) 0%, rgba(99, 102, 241, .08) 100%);
    border: 1px solid rgba(10, 67, 255, .2);
    border-radius: 999px;
    text-decoration: none;
    color: #0f172a;
    font-size: 13px;
    transition: background .15s, border-color .15s, transform .15s;
    max-width: 100%;
}
.prx-readiness-nudge:hover {
    background: linear-gradient(90deg, rgba(10, 67, 255, .14) 0%, rgba(99, 102, 241, .14) 100%);
    border-color: rgba(10, 67, 255, .35);
    transform: translateY(-1px);
}
.prx-readiness-nudge__bar {
    flex-shrink: 0;
    width: 60px;
    height: 4px;
    background: rgba(15, 23, 42, .1);
    border-radius: 999px;
    overflow: hidden;
}
.prx-readiness-nudge__bar-fill {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, #0a43ff 0%, #6366f1 100%);
    border-radius: 999px;
    transition: width .35s cubic-bezier(.4, 0, .2, 1);
}
.prx-readiness-nudge__text {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.prx-readiness-nudge__text strong {
    color: var(--color-primary, #0a43ff);
    font-weight: 700;
}
.prx-readiness-nudge i {
    color: var(--color-primary, #0a43ff);
    font-size: 12px;
    flex-shrink: 0;
}
@media (max-width: 480px) {
    .prx-readiness-nudge { font-size: 12px; padding: 7px 12px; gap: 8px; }
    .prx-readiness-nudge__bar { width: 44px; height: 3px; }
}

/* Deep-link подсветка #cover на /@username?edit=1 — из чек-листа готовности
   профиля. Когда юзер кликает «Обложка профиля», страница скроллит к div
   и подсвечивает soft-glow'ом. scroll-margin-top компенсирует sticky-меню. */
.prx-cover-edit:target {
    scroll-margin-top: 100px;
    animation: prx-cover-target-glow 2.4s cubic-bezier(.4, 0, .2, 1);
}
@keyframes prx-cover-target-glow {
    0%   { box-shadow: 0 0 0 0 rgba(10, 67, 255, .35); }
    30%  { box-shadow: 0 0 0 6px rgba(10, 67, 255, .18); }
    100% { box-shadow: 0 0 0 0 rgba(10, 67, 255, 0); }
}
@media (prefers-reduced-motion: reduce) {
    .prx-cover-edit:target { animation: none; }
}
