/* ===== CLUB CHAT REDESIGN (вёрстка высоты — только в club-social под #page-club + вкладка Чат) ===== */
#tab-chat #clubChatUser {
    width: 100%;
    margin: 0;
}
/* Перебиваем product-theme .chat-messages { height: 400px } — иначе короткая колонка и «чёрная полоса» над композером */
#page-club.active #tab-chat #clubChatMessages.chat-messages,
#page-club.active #tab-chat #clubChatUser .visner-messenger__scroll.chat-messages {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 16px var(--vm-edge, 18px) 12px !important;
    gap: 0;
    border-radius: 0;
    background: transparent;
    border: none;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    box-shadow: none;
    position: relative;
    z-index: 1;
    -webkit-mask-image: none;
    mask-image: none;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
}
#tab-chat .club-chat-composer {
    padding: clamp(9px, 1.6vh, 12px);
    border-radius: 24px;
    background: linear-gradient(145deg, rgba(29, 30, 38, 0.58), rgba(14, 14, 18, 0.72));
    border: 1px solid rgba(255, 255, 255, 0.12);
    -webkit-backdrop-filter: blur(14px) saturate(1.2);
    backdrop-filter: blur(14px) saturate(1.2);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.32);
}
#tab-chat .chat-input-wrapper--club {
    flex-wrap: nowrap;
    gap: clamp(8px, 1.8vw, 11px);
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
}
#tab-chat .chat-tool-btn {
    width: clamp(40px, 10.2vw, 44px);
    height: clamp(40px, 10.2vw, 44px);
    border-radius: clamp(10px, 2.2vw, 12px);
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.04);
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}
#tab-chat .chat-tool-btn:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.24);
}
#tab-chat .chat-input-wrapper--club .chat-input {
    min-height: clamp(48px, 8.8vh, 56px);
    border-radius: clamp(12px, 2.8vw, 14px);
    padding: clamp(12px, 1.8vh, 15px) clamp(12px, 3.8vw, 16px);
    font-size: clamp(14px, 3.6vw, 15px);
    background: rgba(255, 255, 255, 0.045);
    border: 1px solid rgba(255, 255, 255, 0.12);
}
#tab-chat .chat-send {
    width: clamp(52px, 12.8vw, 58px);
    height: clamp(52px, 12.8vw, 58px);
    border-radius: 50%;
    background: linear-gradient(135deg, #ff4da6 8%, #b86cff 56%, #ff9b38 100%);
    box-shadow: 0 12px 26px rgba(255, 92, 170, 0.35);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease, opacity 0.18s ease;
}
#tab-chat .chat-send:hover {
    transform: translateY(-1px) scale(1.06);
    filter: brightness(1.08);
    box-shadow: 0 0 0 6px rgba(255, 92, 170, 0.12), 0 16px 34px rgba(255, 92, 170, 0.46);
}
#tab-chat .chat-send:active {
    transform: scale(0.93);
}

@media (max-width: 420px) {
    #page-club.active #tab-chat #clubChatMessages.chat-messages {
        padding: 12px 0 6px;
    }
    #tab-chat .club-chat-message {
        max-width: min(88%, 440px);
    }
}

@media (max-height: 740px) {
    #page-club.active #tab-chat.club-tab-content.active #clubChatUser:not(.hidden) .club-chat-composer {
        bottom: calc(62px + env(safe-area-inset-bottom, 0px));
    }
    body.visner-club-chat-immersive #page-club.active #tab-chat.club-tab-content.active #clubChatUser:not(.hidden) .club-chat-composer {
        bottom: max(8px, env(safe-area-inset-bottom, 0px));
    }
    #page-club.active #tab-chat.club-tab-content.active #clubChatUser:not(.hidden) .chat-messages {
        padding-bottom: calc(clamp(66px, 9.2vh, 86px) + 92px + env(safe-area-inset-bottom, 0px));
    }
    body.visner-club-chat-immersive #page-club.active #tab-chat.club-tab-content.active #clubChatUser:not(.hidden) .chat-messages {
        padding-bottom: calc(96px + env(safe-area-inset-bottom, 0px));
    }
}
#tab-chat .club-chat-message {
    animation: clubMsgIn 0.2s ease both;
    transform-origin: center center;
    width: auto;
    max-width: min(82%, 520px);
    gap: 10px;
    align-items: flex-end;
    margin-top: 4px;
}
#tab-chat .club-chat-message.chat-message--theirs {
    align-self: flex-start;
    margin-right: auto;
}
#tab-chat .club-chat-message.chat-message--mine {
    align-self: flex-end;
    margin-left: auto;
}
#tab-chat .club-chat-message.club-chat-message--continued {
    margin-top: 8px;
}
#tab-chat .club-chat-message.club-chat-message--break {
    margin-top: 16px;
}
@keyframes clubMsgIn {
    from {
        opacity: 0;
        transform: translate3d(0, 8px, 0) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1);
    }
}
#tab-chat .club-chat-message .chat-avatar {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
    margin-bottom: 2px;
    border-radius: 50%;
}
#tab-chat .club-chat-message .chat-bubble {
    position: relative;
    width: fit-content;
    max-width: 100%;
    padding: 14px 16px 13px;
    border-radius: 26px;
    border: 1px solid rgba(255, 255, 255, 0.14);
}
#tab-chat .club-chat-message .chat-bubble::before {
    content: none;
}
#tab-chat .club-chat-message.chat-message--theirs .chat-bubble {
    background: rgba(18, 16, 28, 0.52);
    -webkit-backdrop-filter: blur(18px) saturate(1.25);
    backdrop-filter: blur(18px) saturate(1.25);
    margin-left: 0;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.07), 0 8px 28px rgba(0, 0, 0, 0.35);
}
#tab-chat .club-chat-message.chat-message--theirs .chat-bubble::after {
    content: none;
}
#tab-chat .club-chat-message.chat-message--mine .chat-bubble {
    background: linear-gradient(135deg, #8b5cff 0%, #ff4dad 48%, #ff9f42 100%);
    border-color: rgba(255, 255, 255, 0.22);
    margin-right: 0;
    box-shadow:
        0 0 0 1px rgba(255, 140, 220, 0.25),
        0 6px 26px rgba(255, 90, 180, 0.42),
        0 0 40px rgba(140, 80, 255, 0.22);
}
#tab-chat .club-chat-message.chat-message--mine .chat-bubble::after {
    content: none;
}
#tab-chat .club-chat-message.chat-message--mine:hover .chat-bubble,
#tab-chat .club-chat-message.chat-message--mine:focus-within .chat-bubble {
    filter: brightness(1.06);
    border-color: rgba(255, 255, 255, 0.32);
}
#tab-chat .club-chat-author {
    font-size: 11px;
    line-height: 1.2;
    margin-bottom: 5px;
    opacity: 0.88;
}
#tab-chat .club-chat-message .chat-text {
    font-size: 15px;
    line-height: 1.47;
}
#tab-chat .club-chat-message .chat-meta-row {
    margin-top: 6px;
    font-size: 10px;
    opacity: 0.72;
}
#tab-chat .club-chat-message.club-chat-message--sticker-only {
    max-width: min(92%, 320px);
}
#tab-chat .club-chat-message.club-chat-message--sticker-only .chat-bubble {
    background: transparent !important;
    border: none !important;
    border-color: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
}
#tab-chat .club-chat-message.club-chat-message--sticker-only.chat-message--mine:hover .chat-bubble,
#tab-chat .club-chat-message.club-chat-message--sticker-only.chat-message--mine:focus-within .chat-bubble {
    background: transparent !important;
    border-color: transparent;
}
#tab-chat .club-chat-message.club-chat-message--sticker-only.chat-message--theirs .chat-bubble {
    background: transparent !important;
}
#tab-chat .club-chat-message.club-chat-message--sticker-only .club-chat-author {
    margin-bottom: 3px;
}
/* Стикер без текстового пузыря: только картинки + время под ними */
#tab-chat .club-chat-sticker-stack {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    align-items: flex-end;
    margin: 0;
    padding: 0;
}
#tab-chat .club-chat-message.club-chat-message--sticker-only .club-chat-sticker-stack {
    justify-content: center;
}
#tab-chat .club-chat-message.chat-message--mine.club-chat-message--sticker-only .club-chat-sticker-stack {
    justify-content: flex-end;
}
#tab-chat .club-chat-message.chat-message--theirs.club-chat-message--sticker-only .club-chat-sticker-stack {
    justify-content: flex-start;
}
#tab-chat .club-chat-sticker-pack {
    display: inline-flex;
    line-height: 0;
}
#tab-chat .club-chat-sticker-only-meta {
    margin-top: 4px;
    text-align: center;
    padding: 0 4px;
}
#tab-chat .club-chat-message.chat-message--mine .club-chat-sticker-only-meta {
    text-align: right;
}
#tab-chat .club-chat-message.chat-message--theirs .club-chat-sticker-only-meta {
    text-align: left;
}
#tab-chat .club-chat-message.club-chat-message--sticker-only .club-chat-sticker-only-meta .chat-time {
    font-size: 10px;
    opacity: 0.72;
}
#tab-chat .club-chat-message.club-chat-message--sticker-mixed .club-chat-caption-row {
    margin-bottom: 8px;
}
#tab-chat .visner-inline-sticker--solo {
    display: block;
    max-height: min(280px, 44vh);
    max-width: min(240px, 78vw);
    width: auto;
    height: auto;
    object-fit: contain;
}
#socialDmPanel .chat-message.club-chat-message--sticker-only .chat-bubble {
    background: transparent !important;
    border-color: transparent;
    box-shadow: none;
    padding: 6px 6px 8px;
}
#socialDmPanel .chat-message.club-chat-message--sticker-only.chat-message--mine .chat-bubble {
    background: transparent !important;
    border-color: transparent;
}
#socialDmPanel .chat-message .chat-bubble {
    position: relative;
}
#socialDmPanel .chat-message .club-chat-actions {
    position: absolute;
    right: 8px;
    top: -12px;
    display: inline-flex;
    gap: 4px;
    opacity: 0;
    transform: translateY(2px);
    transition: opacity 0.18s ease, transform 0.18s ease;
    pointer-events: none;
    z-index: 2;
}
#socialDmPanel .chat-message:hover .club-chat-actions,
#socialDmPanel .chat-message.social-dm-message--actions-open .club-chat-actions {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
#socialDmPanel .club-chat-action-btn {
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(16, 16, 21, 0.92);
    color: #fff;
    border-radius: 999px;
    padding: 3px 7px;
    font-size: 12px;
    cursor: pointer;
}
#socialDmPanel .club-chat-action-btn--menu {
    padding-left: 9px;
    padding-right: 9px;
}
.visner-message-menu-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.visner-message-menu-actions .cta-button,
.visner-message-menu-actions .pp-mini-btn {
    width: 100%;
    margin: 0;
}
.forward-dm-recipient-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: min(52vh, 360px);
    overflow-y: auto;
}
.forward-dm-recipient-list button {
    width: 100%;
    text-align: left;
}

/* Контекстное меню сообщения (у пузыря), без отдельной «вкладки» */
.visner-chat-ctx-host {
    position: fixed;
    inset: 0;
    z-index: 12050;
    pointer-events: none;
}
.visner-chat-ctx-host:not(.hidden) {
    pointer-events: auto;
}
.visner-chat-ctx-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.28);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    pointer-events: auto;
}
.visner-chat-ctx-reactions {
    position: fixed;
    z-index: 12052;
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(22, 22, 28, 0.82);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.45);
    pointer-events: auto;
}
.visner-chat-ctx-reactions button {
    border: none;
    background: transparent;
    color: #fff;
    font-size: 18px;
    line-height: 1;
    padding: 4px 6px;
    border-radius: 10px;
    cursor: pointer;
    opacity: 0.92;
}
.visner-chat-ctx-reactions button:hover {
    background: rgba(255, 255, 255, 0.08);
}
.visner-chat-ctx-panel {
    position: fixed;
    z-index: 12052;
    min-width: 200px;
    max-width: min(260px, calc(100vw - 24px));
    border-radius: 16px;
    background: rgba(24, 24, 30, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    overflow: hidden;
    pointer-events: auto;
}
.visner-chat-ctx-meta {
    padding: 10px 14px 8px;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.45);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    text-align: center;
}
.visner-chat-ctx-body {
    padding: 4px 0 6px;
}
.visner-chat-ctx-item {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 11px 14px;
    border: none;
    background: transparent;
    color: rgba(255, 255, 255, 0.92);
    font-size: 15px;
    text-align: left;
    cursor: pointer;
    font-family: inherit;
}
.visner-chat-ctx-item:hover {
    background: rgba(255, 255, 255, 0.06);
}
.visner-chat-ctx-item i {
    width: 20px;
    text-align: center;
    opacity: 0.75;
    font-size: 15px;
}
.visner-chat-ctx-item--danger {
    color: #ff6b7d;
}
.visner-chat-ctx-item--danger i {
    color: #ff6b7d;
    opacity: 1;
}
.visner-chat-ctx-divider {
    height: 1px;
    margin: 4px 10px;
    background: rgba(255, 255, 255, 0.08);
}
.visner-chat-ctx-hint {
    padding: 8px 14px 4px;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.35;
}
@keyframes visnerMsgDissolve {
    to {
        opacity: 0;
        filter: blur(12px);
        transform: scale(0.94);
    }
}
#tab-chat .club-chat-message--dissolving,
#socialDmPanel .chat-message--dissolving {
    animation: visnerMsgDissolve 0.44s ease forwards;
    pointer-events: none;
}

.club-look-comment-reply {
    margin-left: 8px;
    padding: 2px 8px;
    font-size: 11px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(16, 16, 21, 0.75);
    color: #fff;
    cursor: pointer;
}
.club-look-comment-reply:hover {
    border-color: rgba(255, 105, 180, 0.45);
}
#tab-chat .chat-attach-img-wrap {
    position: relative;
    border: none;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.04);
    max-width: 280px;
}
#tab-chat .chat-attach-img-meta {
    display: none;
}
#tab-chat .chat-attach-time-pill {
    background: rgba(0, 0, 0, 0.48);
}
#tab-chat .chat-attach-img-meta i,
#tab-chat .chat-attach-file-fallback {
    display: none;
}
#tab-chat .club-chat-actions {
    position: absolute;
    right: 10px;
    top: -13px;
    display: inline-flex;
    gap: 4px;
    opacity: 0;
    transform: translateY(2px);
    transition: opacity 0.18s ease, transform 0.18s ease;
    pointer-events: none;
}
#tab-chat .club-chat-message:hover .club-chat-actions {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
#tab-chat .club-chat-message.club-chat-message--actions-open .club-chat-actions {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
#tab-chat .club-chat-action-btn {
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(16, 16, 21, 0.92);
    color: #fff;
    border-radius: 999px;
    padding: 3px 7px;
    font-size: 12px;
    cursor: pointer;
}
#tab-chat .club-chat-action-btn--menu {
    padding-left: 9px;
    padding-right: 9px;
}
#tab-chat .club-chat-reactions {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
#tab-chat .club-chat-reaction-chip {
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(12, 10, 22, 0.45);
    -webkit-backdrop-filter: blur(14px) saturate(1.2);
    backdrop-filter: blur(14px) saturate(1.2);
    color: rgba(255, 255, 255, 0.94);
    border-radius: 999px;
    font-size: 11px;
    padding: 5px 10px;
    cursor: pointer;
    animation: clubReactionIn 0.18s ease both;
    transition: transform 0.16s ease, background 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 4px 16px rgba(0, 0, 0, 0.25);
}
#tab-chat .club-chat-reaction-chip:hover {
    transform: translateY(-1px) scale(1.03);
    border-color: rgba(255, 140, 220, 0.45);
    box-shadow: 0 0 18px rgba(255, 100, 200, 0.28);
}
#tab-chat .club-chat-reaction-chip.is-mine {
    border-color: rgba(255, 160, 220, 0.55);
    background: linear-gradient(135deg, rgba(255, 91, 166, 0.42), rgba(163, 99, 255, 0.38));
    box-shadow: 0 0 16px rgba(255, 120, 200, 0.35);
}
@keyframes clubReactionIn {
    from { opacity: 0; transform: scale(0.92); }
    to { opacity: 1; transform: scale(1); }
}
#tab-chat .club-chat-typing {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 4px 7px;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.74);
}
#tab-chat .club-chat-typing.hidden {
    display: none;
}
#tab-chat .club-chat-typing-label {
    min-width: 92px;
}
#tab-chat .club-chat-typing-dots {
    display: inline-flex;
    gap: 4px;
}
#tab-chat .club-chat-typing-dots i {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.82);
    animation: clubTypingDots 1.1s infinite ease-in-out;
}
#tab-chat .club-chat-typing-dots i:nth-child(2) { animation-delay: 0.12s; }
#tab-chat .club-chat-typing-dots i:nth-child(3) { animation-delay: 0.24s; }
@keyframes clubTypingDots {
    0%, 80%, 100% { transform: translateY(0); opacity: 0.35; }
    40% { transform: translateY(-2px); opacity: 1; }
}
/* ——— Отзывы на странице товара ——— */
.pp-reviews-block {
    padding: 16px 0 28px;
    margin-top: 4px;
    border-top: none;
    background: transparent;
    border: none;
    box-shadow: none;
    backdrop-filter: none;
}
.pp-eyebrow {
    margin: 0 22px 16px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(255, 143, 190, 0.65);
}
.pp-buyer-photos {
    padding: 0;
}
/* «В образе» — одна крупная карточка, свайп по настроению */
.pp-look-section.pp-buyer-photos {
    margin: 12px 16px 22px;
    padding: 0;
    border-radius: 20px;
    position: relative;
    overflow: visible;
    isolation: isolate;
    background: rgba(255, 255, 255, 0.03);
    border: none;
    box-shadow: 0 20px 48px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.pp-look-shell {
    padding: 18px 0 16px;
}
.pp-look-kicker {
    margin: 0 20px 12px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.38);
}
.pp-look-carousel {
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 0 0 4px;
}
.pp-look-carousel::-webkit-scrollbar {
    display: none;
}
.pp-look-track {
    display: flex;
    gap: 12px;
    padding: 0 20px 8px;
    width: max-content;
}
.pp-look-slide {
    flex: 0 0 min(calc(100vw - 72px), 340px);
    width: min(calc(100vw - 72px), 340px);
    scroll-snap-align: center;
}
.pp-look-card {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 18px;
    overflow: hidden;
    cursor: pointer;
    text-align: left;
    font: inherit;
    color: inherit;
    background: linear-gradient(180deg, #16141a 0%, #0c0b0f 100%);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.pp-look-card:active {
    transform: scale(0.985);
}
.pp-look-photo {
    position: relative;
    aspect-ratio: 4 / 5;
    background: #0a090c;
}
.pp-look-photo::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(ellipse 90% 80% at 50% 50%, transparent 40%, rgba(4, 3, 6, 0.5) 100%);
}
.pp-look-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: brightness(0.9) contrast(1.06) saturate(0.93);
}
.pp-look-caption {
    margin: 0;
    padding: 14px 16px 16px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.88);
    line-height: 1.35;
}
.pp-look-hint {
    margin: 4px 20px 0;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.32);
}
.pp-reviews-summary {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px 18px;
    margin: 0 20px 12px;
    border-radius: 0;
    background: transparent;
    border: none;
}
.pp-reviews-summary-left {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    flex: 1;
}
.pp-reviews-summary-star {
    font-size: 22px;
    line-height: 1;
    color: rgba(255, 105, 180, 0.85);
    filter: none;
}
.pp-reviews-summary-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.pp-reviews-summary-rating {
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #fff;
    line-height: 1.1;
}
.pp-reviews-summary-count {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.45);
    font-weight: 500;
}
.pp-reviews-summary-avatars {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}
.pp-reviews-avatar-pile {
    display: flex;
    align-items: center;
}
.pp-reviews-avatar-pile span {
    width: 32px;
    height: 26px;
    border-radius: 6px;
    margin-left: -8px;
    border: 2px solid #0a0a0a;
    background: linear-gradient(145deg, #3a3530, #1f1c1a);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.85);
    overflow: hidden;
    flex-shrink: 0;
}
.pp-reviews-avatar-pile span.pp-reviews-avatar-pile--photo {
    padding: 0;
}
.pp-reviews-avatar-pile span.pp-reviews-avatar-pile--photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.pp-reviews-avatar-pile span:first-child {
    margin-left: 0;
}
.pp-reviews-summary-extra {
    font-size: 13px;
    font-weight: 700;
    color: #fff;
    margin-left: 4px;
}
.pp-reviews-summary-more {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 0;
    border: none;
    background: none;
    font: inherit;
    font-size: 12px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.55);
    cursor: pointer;
    white-space: nowrap;
}
.pp-reviews-summary-more i {
    font-size: 10px;
    opacity: 0.8;
}
.pp-review-compose-head {
    padding: 0 20px;
}
.pp-review-compose-head .pp-section-label {
    margin: 12px 0 8px;
}
.pp-reviews-empty {
    padding: 4px 22px 2px;
    margin: 0;
}
.pp-reviews-empty-text {
    margin: 0;
    padding: 8px 4px 12px;
    font-size: 14px;
    line-height: 1.5;
    font-weight: 500;
    text-align: center;
    color: rgba(255, 255, 255, 0.48);
}
.pp-reviews-scroll {
    display: flex;
    gap: 16px;
    padding: 4px 20px 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.pp-reviews-scroll:not(.hidden) + .pp-reviews-empty {
    display: none !important;
}
.pp-reviews-scroll.hidden,
.pp-reviews-summary.hidden {
    display: none;
}
.pp-reviews-scroll::-webkit-scrollbar {
    display: none;
}
.pp-reviews-list-host {
    display: contents;
}
.pp-review-card {
    text-align: left;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: none;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
}
.pp-review-card:not(.pp-review-card--slide) {
    padding: 18px 18px 20px;
    margin-bottom: 14px;
}
.pp-review-card--slide {
    position: relative;
    flex: 0 0 min(280px, 82vw);
    width: min(280px, 82vw);
    scroll-snap-align: start;
    border-radius: 18px;
    overflow: hidden;
    border: none;
    background: rgba(18, 16, 22, 0.92);
    padding: 0;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.3);
}
.pp-review-card--slide::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: var(--pp-review-bg, none);
    background-size: cover;
    background-position: center;
    opacity: 0.12;
    pointer-events: none;
}
.pp-review-card-inner {
    position: relative;
    z-index: 1;
    padding: 18px 18px 20px;
}
.pp-review-card-head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}
.pp-review-avatar {
    width: 44px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.92);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.1);
    flex-shrink: 0;
    overflow: hidden;
    box-sizing: border-box;
}
.pp-review-avatar.pp-review-avatar--photo {
    padding: 0;
    background: #1a1a1a;
}
.pp-review-avatar.pp-review-avatar--photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.pp-review-name {
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pp-review-verified {
    color: rgba(255, 143, 190, 0.85);
    font-size: 14px;
    flex-shrink: 0;
}
.pp-review-card-stars {
    color: rgba(255, 143, 190, 0.75);
    font-size: 12px;
    margin-bottom: 10px;
    letter-spacing: 2px;
}
.pp-review-card-text {
    font-size: 13px;
    line-height: 1.45;
    color: rgba(255, 255, 255, 0.88);
}
.pp-review-card--slide .pp-review-card-text {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pp-review-card-meta {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.35);
    margin-top: 10px;
}
.pp-review-hint {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.45);
    margin: 12px 0;
    line-height: 1.45;
}
.pp-review-composer {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0 20px 12px;
}
.pp-review-composer textarea,
#ppReviewText {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    display: block;
    min-height: 96px;
    padding: 14px 16px;
    margin: 0 0 12px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(0, 0, 0, 0.35);
    color: #fff;
    font-family: inherit;
    font-size: 15px;
    line-height: 1.45;
    resize: vertical;
    -webkit-appearance: none;
    appearance: none;
}
.pp-review-composer textarea:focus,
#ppReviewText:focus {
    outline: none;
    border-color: rgba(255, 105, 180, 0.45);
    box-shadow: 0 0 0 2px rgba(255, 20, 147, 0.12);
}
.pp-review-stars-pick {
    display: flex;
    gap: 6px;
    margin-bottom: 8px;
}
.pp-review-stars-pick button {
    background: none;
    border: none;
    color: #555;
    font-size: 22px;
    cursor: pointer;
    padding: 4px;
    line-height: 1;
}
.pp-review-stars-pick button.is-on {
    color: rgba(255, 105, 180, 0.95);
}
.pp-mini-btn {
    padding: 12px 18px;
    border-radius: 12px;
    border: 1px solid rgba(255, 105, 180, 0.45);
    background: rgba(255, 20, 147, 0.12);
    color: #ffb8e0;
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    font-family: inherit;
}

/* ——— Регистрация / личный кабинет ——— */
.register-avatar-row {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}
.register-avatar-preview {
    width: 144px;
    height: 144px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border);
    background: rgba(255, 255, 255, 0.06);
}
.auth-mode-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 18px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    overflow: hidden;
    background: rgba(0, 0, 0, 0.22);
}
.auth-tab {
    flex: 1;
    padding: 12px 14px;
    font-size: 13px;
    font-weight: 700;
    border: none;
    background: transparent;
    color: rgba(255, 255, 255, 0.48);
    cursor: pointer;
    font-family: inherit;
    transition: background 0.2s ease, color 0.2s ease;
}
.auth-tab.active {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}
.auth-pane.hidden {
    display: none;
}
.register-avatar-btn {
    font-size: 12px;
    color: var(--secondary);
    cursor: pointer;
    text-decoration: underline;
}
.register-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 16px;
}
.register-note {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.45;
    margin-top: 12px;
}

.account-panel {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 100%;
    max-width: var(--container);
    padding-left: env(safe-area-inset-left, 0px);
    padding-right: env(safe-area-inset-right, 0px);
    box-sizing: border-box;
    transform: translateX(-50%) translateX(105%);
    z-index: 2750;
    background:
        radial-gradient(circle at 78% 18%, rgba(255, 0, 166, 0.26), transparent 44%),
        radial-gradient(circle at 86% 38%, rgba(158, 0, 255, 0.22), transparent 42%),
        radial-gradient(circle at 84% 52%, rgba(255, 74, 184, 0.18), transparent 40%),
        #05050a;
    display: flex;
    flex-direction: column;
    opacity: 0;
    pointer-events: none;
    transition: transform 0.48s cubic-bezier(0.22, 0.99, 0.28, 1), opacity 0.38s ease;
    box-shadow: -12px 0 48px rgba(0, 0, 0, 0.5);
}
.account-panel.is-open {
    transform: translateX(-50%) translateX(0);
    opacity: 1;
    pointer-events: auto;
    /* Выше сайдбара (3000) и оверлея, иначе тапы уходят «под» панель */
    z-index: 3200;
}
.account-panel-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    padding-top: max(12px, env(safe-area-inset-top, 0px));
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
    flex-shrink: 0;
    background: rgba(6, 6, 10, 0.84);
    backdrop-filter: blur(16px);
}
.account-panel-header span {
    flex: 1;
    font-weight: 800;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}
.account-panel-header .pp-icon-btn {
    width: 46px;
    height: 46px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(8, 8, 14, 0.72);
}
.account-panel-header .pp-icon-btn:last-child {
    border-radius: 14px;
    border-color: rgba(255, 95, 200, 0.6);
    box-shadow: 0 0 16px rgba(255, 54, 180, 0.24);
}
.account-tabs {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 6px;
    padding: 10px 10px max(10px, env(safe-area-inset-bottom, 0px));
    flex-shrink: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(8, 8, 10, 0.96);
}
.account-tab {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 8px 4px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.78);
    font-size: 9px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    line-height: 1.15;
    text-align: center;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.account-tab i {
    font-size: 16px;
    opacity: 0.92;
}
.account-tab.active {
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    border-color: transparent;
    color: #fff;
}
.account-panel-body {
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: env(safe-area-inset-bottom, 0px);
    position: relative;
}
.account-panel-body::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(120% 55% at 100% 10%, rgba(250, 0, 157, 0.24), transparent 60%),
        radial-gradient(80% 60% at 100% 26%, rgba(255, 90, 204, 0.15), transparent 62%);
    mix-blend-mode: screen;
    z-index: 0;
}
.acc-pane {
    display: none;
    padding: 12px 14px 0;
    position: relative;
    z-index: 1;
}
.acc-pane.active {
    display: block;
}
#accPaneProfile.active {
    display: flex;
    flex-direction: column;
    min-height: 100%;
}
.acc-cabinet-screen {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 100%;
    padding-top: 12px;
}
.acc-cabinet-top {
    display: grid;
    grid-template-columns: 146px 1fr;
    gap: 14px;
    align-items: center;
    padding: 2px 0;
}
.acc-cabinet-logo-wrap {
    width: 146px;
    height: 146px;
    border-radius: 999px;
    background: radial-gradient(circle at 50% 50%, rgba(255, 228, 154, 0.08), rgba(255, 191, 87, 0.03));
    border: 3px solid rgba(255, 183, 75, 0.92);
    box-shadow: 0 0 22px rgba(255, 190, 88, 0.48), inset 0 0 20px rgba(255, 180, 74, 0.22);
    padding: 7px;
}
.acc-cabinet-logo {
    width: 100%;
    height: 100%;
    border-radius: 999px;
    object-fit: cover;
    border: 2px solid rgba(10, 10, 14, 0.85);
    opacity: 1 !important;
}
.acc-cabinet-welcome h2 {
    margin: 0 0 4px;
    font-size: 28px;
    line-height: 1;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: none;
}
.acc-cabinet-member {
    margin: 0 0 4px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    border-radius: 999px;
    border: 1px solid rgba(255, 198, 96, 0.54);
    background: rgba(18, 12, 12, 0.75);
    color: rgba(255, 218, 132, 0.98);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.02em;
}
.acc-cabinet-welcome {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    min-height: 0;
    gap: 0;
    padding-top: 2px;
}
.acc-cabinet-welcome h2,
.acc-cabinet-welcome .acc-cabinet-member,
.acc-cabinet-welcome p {
    width: auto;
    text-align: left;
}
.acc-cabinet-welcome .acc-cabinet-member {
    min-width: 0;
}
.acc-cabinet-member i {
    font-size: 12px;
}
.acc-cabinet-welcome p {
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: 15px;
    line-height: 1.32;
    max-width: 300px;
}
.acc-cabinet-welcome p strong {
    color: #ff58bd;
}

.acc-cabinet-welcome > h2,
.acc-cabinet-welcome > .acc-cabinet-member,
.acc-cabinet-welcome > p {
    margin-left: 0;
    margin-right: 0;
}

.acc-cabinet-welcome > h2 {
    margin-bottom: 5px;
}

.acc-cabinet-welcome > .acc-cabinet-member {
    margin-bottom: 5px;
    align-self: flex-start;
}

.acc-cabinet-welcome > p {
    margin-top: 0;
}
.acc-cabinet-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border: 1px solid rgba(255, 71, 187, 0.45);
    border-radius: 12px;
    background: rgba(9, 8, 18, 0.72);
    overflow: hidden;
}
.acc-cabinet-stat {
    border: 0;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
    background: transparent;
    color: #fff;
    min-height: 58px;
    padding: 8px 6px 7px;
    display: grid;
    grid-template-columns: auto auto;
    grid-template-rows: auto auto;
    align-items: center;
    justify-content: center;
    column-gap: 8px;
    row-gap: 2px;
    cursor: pointer;
}
.acc-cabinet-stat:last-child {
    border-right: 0;
}
.acc-cabinet-stat i {
    font-size: 16px;
    color: #ff53be;
    grid-column: 1;
    grid-row: 1;
}
.acc-cabinet-stat strong {
    font-size: 21px;
    line-height: 1;
    grid-column: 2;
    grid-row: 1;
}
.acc-cabinet-stat span {
    font-size: 10px;
    color: rgba(255, 255, 255, 0.82);
    grid-column: 1 / span 2;
    grid-row: 2;
}
.acc-cabinet-block {
    border: 1px solid rgba(255, 114, 211, 0.36);
    border-radius: 12px;
    background: rgba(10, 10, 19, 0.75);
    padding: 9px 10px 4px;
}
.acc-cabinet-block h3 {
    margin: 0 0 8px;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #f24fb9;
    display: flex;
    align-items: center;
    gap: 10px;
}
.acc-cabinet-row {
    min-height: 38px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    font-size: 12px;
    line-height: 1.25;
}
.acc-cabinet-row:first-of-type {
    border-top: 0;
}
.acc-cabinet-row span {
    color: rgba(255, 255, 255, 0.82);
}
.acc-cabinet-row strong {
    color: #fff;
    font-weight: 600;
    text-align: right;
}
.acc-cabinet-edit {
    min-height: 46px;
    border-radius: 12px;
    border: 1px solid rgba(255, 143, 226, 0.5);
    background: linear-gradient(130deg, #ff4fad, #6d4dff);
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 14px;
    cursor: pointer;
}
.acc-cabinet-edit i:first-child {
    margin-right: 10px;
}
.acc-cabinet-edit span {
    flex: 1;
    text-align: left;
}
.acc-cabinet-bottom-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
    margin-top: auto;
    padding-bottom: env(safe-area-inset-bottom, 0px);
}
.acc-cabinet-media-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 4px;
}
.acc-cabinet-media {
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.04);
    border-radius: 10px;
    overflow: hidden;
    padding: 0;
    aspect-ratio: 1;
    cursor: pointer;
}
.acc-cabinet-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 1 !important;
    display: block;
}
.acc-cabinet-media-empty {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.7);
    padding: 8px 4px 10px;
}
.acc-cabinet-media.acc-cabinet-media--add {
    display: flex;
    align-items: center;
    justify-content: center;
    border-style: dashed;
    border-color: rgba(255, 255, 255, 0.28);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.85);
    font-size: 28px;
    cursor: pointer;
}
.acc-cabinet-media.acc-cabinet-media--add:hover {
    border-color: rgba(255, 193, 203, 0.55);
    color: #ffb8d9;
}
.acc-cabinet-action {
    min-height: 60px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(11, 11, 22, 0.78);
    color: #fff;
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 9px 10px;
    cursor: pointer;
    text-align: left;
}
.acc-cabinet-action > i:first-child {
    color: #ff57c0;
    font-size: 16px;
}
.acc-cabinet-action span strong {
    display: block;
    font-size: 13px;
    line-height: 1.05;
}
.acc-cabinet-action span small {
    display: block;
    margin-top: 4px;
    color: rgba(255, 255, 255, 0.7);
    font-size: 9px;
    line-height: 1.15;
}
.acc-cabinet-action > i:last-child {
    margin-left: auto;
    color: rgba(255, 255, 255, 0.7);
}
@media (max-width: 520px) {
    .acc-pane {
        padding: 10px 12px 0;
    }
    .acc-cabinet-top {
        grid-template-columns: 120px 1fr;
        gap: 12px;
        padding: 0;
    }
    .acc-cabinet-logo-wrap {
        width: 120px;
        height: 120px;
    }
    .acc-cabinet-welcome h2 {
        font-size: 24px;
    }
    .acc-cabinet-welcome {
        min-height: 0;
        padding-top: 0;
    }
    .acc-cabinet-welcome .acc-cabinet-member {
        min-width: 0;
    }
    .acc-cabinet-welcome p {
        max-width: 210px;
        font-size: 13px;
    }
    .acc-cabinet-member {
        font-size: 12px;
    }
    .acc-cabinet-block h3 {
        font-size: 16px;
    }
    .acc-cabinet-stat strong {
        font-size: 18px;
    }
    .acc-cabinet-edit {
        font-size: 13px;
        min-height: 44px;
    }
    .acc-cabinet-action {
        min-height: 56px;
    }
    .acc-cabinet-action span strong {
        font-size: 12px;
    }
    .acc-cabinet-action span small {
        font-size: 9px;
    }
    .acc-cabinet-media-grid {
        gap: 6px;
    }
}

/* По запросу: убрать нижнюю навигацию в кабинете */
.account-panel .account-tabs {
    display: none !important;
}
.acc-photo-hero-wrap {
    max-width: 320px;
    margin: 0 auto 14px;
}
.acc-avatar-hero {
    width: 100%;
    max-width: 320px;
    aspect-ratio: 4 / 3;
    max-height: 280px;
    height: auto;
    border-radius: 14px;
    object-fit: cover;
    border: 2px solid var(--border);
    display: block;
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.06);
}
.acc-photo-strip-view,
.acc-photo-strip-edit {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    margin-bottom: 16px;
}
.acc-photo-edit-card {
    display: flex;
    position: relative;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0;
    max-width: 96px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.03);
    border-radius: 12px;
    padding: 7px;
    cursor: pointer;
}
.acc-photo-edit-card.is-main {
    border-color: rgba(255, 143, 190, 0.75);
    box-shadow: 0 0 0 1px rgba(255, 105, 180, 0.22) inset;
}
.acc-photo-thumb {
    width: 76px;
    height: 76px;
    border-radius: 10px;
    object-fit: cover;
    border: 2px solid rgba(255, 255, 255, 0.14);
    display: block;
}
.acc-photo-thumb.is-main {
    border-color: rgba(255, 143, 190, 0.9);
    box-shadow: 0 0 0 2px rgba(255, 105, 180, 0.2);
}
.acc-photo-edit-actions {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    width: 100%;
}
.acc-main-badge {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 143, 190, 0.95);
    text-align: center;
}
.acc-photo-main-check {
    position: absolute;
    right: 4px;
    top: 4px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #ff4cae, #a64cff);
    color: #fff;
    font-size: 10px;
    box-shadow: 0 0 10px rgba(255, 77, 179, 0.45);
}
.acc-photo-action-menu {
    position: fixed;
    z-index: 5500;
    width: min(92vw, 320px);
    max-height: min(78vh, 520px);
    overflow-y: auto;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(9, 8, 16, 0.96);
    box-shadow: 0 22px 60px rgba(0, 0, 0, 0.55);
    padding: 6px;
    backdrop-filter: blur(12px);
}
.acc-photo-action-btn {
    width: 100%;
    min-height: 38px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(255, 255, 255, 0.94);
    text-align: left;
    font-size: 13px;
    padding: 8px 10px;
    margin-bottom: 6px;
    cursor: pointer;
}
.acc-photo-action-btn:last-child {
    margin-bottom: 0;
}
.acc-photo-action-btn--danger {
    border-color: rgba(255, 92, 92, 0.4);
    color: #ff9c9c;
}
.acc-icon-picker {
    margin: 0 0 12px;
}
.acc-icon-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}
.acc-icon-card {
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.92);
    border-radius: 12px;
    min-height: 112px;
    padding: 10px 8px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    text-align: center;
}
.acc-icon-card.is-main {
    border-color: rgba(255, 143, 190, 0.88);
    box-shadow: 0 0 0 2px rgba(255, 105, 180, 0.18) inset;
}
.acc-icon-card img {
    width: 62px;
    height: 62px;
    border-radius: 10px;
    object-fit: cover;
    background: rgba(0, 0, 0, 0.18);
    flex-shrink: 0;
    opacity: 1 !important;
    visibility: visible !important;
}
.acc-icon-card span {
    font-size: 13px;
    line-height: 1.2;
    font-weight: 700;
}
.acc-field {
    margin-bottom: 14px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.55);
}
.acc-field strong {
    display: block;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.35);
    margin-bottom: 6px;
}
.account-panel .acc-field-value {
    display: block;
    font-size: 15px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.94);
    line-height: 1.4;
    word-break: break-word;
}
.acc-order-card {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 105, 180, 0.15);
    border-radius: 14px;
    padding: 14px;
    margin-bottom: 12px;
    text-align: left;
}
.acc-order-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 8px;
}
.acc-order-status {
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(46, 204, 113, 0.15);
    color: var(--success);
    white-space: nowrap;
}
.acc-order-status.preorder {
    background: rgba(241, 196, 15, 0.12);
    color: #f4d03f;
}
.acc-order-status.ship {
    background: rgba(52, 152, 219, 0.15);
    color: #5dade2;
}
.acc-order-status.cancel {
    background: rgba(255, 80, 80, 0.14);
    color: #ff9f9f;
}
.acc-order-main {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 4px;
}
.acc-order-photo-btn {
    width: 56px;
    height: 56px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 10px;
    padding: 0;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.03);
    cursor: pointer;
    flex-shrink: 0;
}
.acc-order-photo-btn img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.acc-order-title-link {
    border: 0;
    background: transparent;
    padding: 0;
    text-align: left;
    width: 100%;
    font-size: 13px;
    color: #bbb;
    line-height: 1.35;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.acc-order-cancel-timer {
    margin-top: 10px;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.62);
}
.acc-order-cancel-btn[disabled] {
    opacity: 0.55;
    cursor: not-allowed;
}
.order-detail-gallery {
    margin-top: 12px;
}
.order-detail-main-photo {
    width: 100%;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.03);
    cursor: pointer;
}
.order-detail-main-photo img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    display: block;
}
.order-detail-thumbs {
    margin-top: 8px;
    display: flex;
    gap: 8px;
    overflow-x: auto;
}
.order-detail-thumb {
    width: 56px;
    height: 56px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 10px;
    padding: 0;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.03);
    cursor: pointer;
    flex: 0 0 auto;
}
.order-detail-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.order-detail-thumb.is-active {
    border-color: rgba(255, 20, 147, 0.55);
    box-shadow: 0 0 0 2px rgba(255, 20, 147, 0.15) inset;
}
.acc-empty {
    text-align: center;
    color: #666;
    padding: 36px 16px;
    font-size: 14px;
}
.acc-look-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-top: 12px;
}
.acc-look-card {
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid var(--border);
    border-radius: 14px;
    overflow: hidden;
    cursor: pointer;
    text-align: left;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.acc-look-card:hover {
    border-color: rgba(255, 20, 147, 0.45);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}
.acc-look-card:focus-visible {
    outline: 2px solid var(--secondary);
    outline-offset: 2px;
}
.acc-look-card-head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 10px 6px;
}
.acc-look-card-head .social-member-avatar {
    width: 40px;
    height: 40px;
}
.acc-look-card-author {
    flex: 1;
    min-width: 0;
}
.acc-look-card-name {
    font-weight: 700;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.92);
    line-height: 1.25;
}
.acc-look-card-nick {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.45);
    margin-top: 2px;
}
.acc-look-card img:not(.social-member-avatar):not(.visner-inline-sticker) {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 0;
    border: none;
    display: block;
}
.acc-look-card-body {
    padding: 0 10px 10px;
}
.acc-look-card p {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.72);
    margin: 0 0 6px;
    line-height: 1.35;
}
.acc-look-card time {
    font-size: 10px;
    color: rgba(255, 255, 255, 0.38);
}
.club-user-gate {
    background: rgba(255, 20, 147, 0.08);
    border: 1px solid rgba(255, 105, 180, 0.25);
    border-radius: 14px;
    padding: 18px;
    text-align: center;
    margin-bottom: 16px;
}
.club-user-gate p {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.55);
    line-height: 1.5;
    margin-bottom: 12px;
}
.look-upload-preview {
    max-width: 100%;
    max-height: 200px;
    border-radius: 12px;
    margin-top: 10px;
    display: none;
}
.look-upload-preview.show {
    display: block;
}

/* ===== CLUB LOOKS FEED (PREMIUM SOCIAL) ===== */
.club-looks-shell {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    background: #000;
}
/* Заголовок «Лента образов» и лента: разделение при прокрутке (не «смешиваются» с карточками) */
#tab-gallery.club-tab-content .club-looks-padded {
    position: relative;
    z-index: 4;
    isolation: isolate;
    background: #000;
}
#tab-gallery.club-tab-content .club-looks-feed-ig {
    position: relative;
    z-index: 1;
    margin-top: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}
html[data-theme='minimal'] #tab-gallery.club-tab-content .club-looks-padded {
    background: linear-gradient(180deg, #fbf8f3 0%, #f5efe6 52%, #ebe4da 100%);
    box-shadow: 0 12px 28px rgba(44, 40, 36, 0.07);
}
html[data-theme='minimal'] #tab-gallery.club-tab-content .club-looks-feed-ig {
    border-top-color: rgba(44, 40, 36, 0.12);
}
.club-looks-padded {
    padding: 10px max(14px, env(safe-area-inset-left, 0px)) 0 max(14px, env(safe-area-inset-right, 0px));
}
.club-looks-page-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 0 0 16px;
    padding: 14px 16px 14px;
    border-radius: 16px;
    background: #1a1a1f;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
.club-looks-page-head-text {
    min-width: 0;
}
.club-looks-page-title {
    margin: 0;
    font-size: clamp(18px, 3.8vw, 22px);
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.96);
    line-height: 1.2;
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.club-looks-page-title-sparks {
    display: inline-flex;
    gap: 4px;
    font-size: 0.72em;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    background: linear-gradient(120deg, #e879f9, #a855f7);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: drop-shadow(0 0 6px rgba(232, 121, 249, 0.45));
}
.club-looks-page-title-sparks span {
    display: inline-block;
}
.club-looks-page-sub {
    margin: 6px 0 0;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.45;
    max-width: 48ch;
}
.club-looks-add-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(0, 0, 0, 0.35);
    color: rgba(255, 255, 255, 0.92);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, transform 0.18s ease, box-shadow 0.2s ease;
}
.club-looks-add-btn .fas.fa-plus {
    color: #ff5eb3;
    font-size: 13px;
}
.club-looks-add-btn:hover {
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(255, 94, 179, 0.35);
    box-shadow: 0 0 16px rgba(255, 94, 179, 0.12);
    transform: translateY(-1px);
}
.club-looks-add-btn__open,
.club-looks-add-btn__close {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.club-looks-add-btn__close {
    display: none;
}
.club-looks-add-btn[aria-expanded="true"] .club-looks-add-btn__open {
    display: none;
}
.club-looks-add-btn[aria-expanded="true"] .club-looks-add-btn__close {
    display: inline-flex;
}
.club-looks-composer-panel {
    margin: 0 0 20px;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(165deg, rgba(18, 17, 26, 0.92), rgba(10, 10, 16, 0.96));
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
    animation: clubLookIn 0.28s ease both;
    /* Чтобы scrollIntoView не прятал форму под sticky-шапкой и полосой табов клуба */
    scroll-margin-top: calc(var(--visner-club-tabs-sticky-top, calc(env(safe-area-inset-top, 0px) + 58px)) + 56px);
    scroll-margin-bottom: max(24px, env(safe-area-inset-bottom, 0px));
}
.club-looks-composer-panel.hidden {
    display: none !important;
}
.club-looks-composer-panel .club-look-composer {
    border: none;
    box-shadow: none;
    background: transparent;
    border-radius: 0;
}
.club-look-composer {
    display: grid;
    gap: 10px;
    padding: 12px;
    border-radius: 18px;
    background: linear-gradient(145deg, rgba(21, 20, 30, 0.66), rgba(14, 14, 22, 0.76));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
.club-look-dropzone {
    position: relative;
    display: grid;
    justify-items: center;
    text-align: center;
    gap: 7px;
    padding: 12px 12px 10px;
    border-radius: 13px;
    border: 1px dashed rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.025);
    cursor: pointer;
    transition: border-color 0.22s ease, background 0.22s ease, transform 0.22s ease;
}
.club-look-dropzone:hover,
.club-look-dropzone.is-active {
    border-color: rgba(255, 138, 205, 0.54);
    background: rgba(255, 255, 255, 0.045);
    transform: translateY(-1px);
}
.club-look-dropzone p {
    margin: 0;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.75);
}
.club-look-drop-icon {
    width: 36px;
    height: 36px;
    border-radius: 11px;
    display: grid;
    place-items: center;
    color: #fff;
    background: linear-gradient(135deg, rgba(255, 94, 174, 0.5), rgba(141, 102, 240, 0.48));
    box-shadow: 0 7px 16px rgba(165, 91, 214, 0.2);
}
.club-look-pick-btn {
    margin-top: 1px;
}
.club-look-caption-wrap {
    position: relative;
    display: grid;
    gap: 6px;
}
.club-look-caption-toolbar {
    display: flex;
    align-items: center;
    gap: 8px;
}
.club-look-caption {
    min-height: 66px;
    resize: vertical;
    background: rgba(255, 255, 255, 0.042);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    line-height: 1.45;
}
.club-look-publish-btn {
    position: relative !important;
    left: auto !important;
    bottom: auto !important;
    width: auto;
    min-width: 160px;
    align-self: flex-end;
    justify-self: end;
    min-height: 40px;
    padding: 9px 18px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.07);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, transform 0.18s ease;
}
.club-look-publish-btn:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.11);
    border-color: rgba(255, 200, 230, 0.35);
}
.club-looks-feed-ig {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    width: 100%;
    margin: 0;
    padding: 0 max(10px, env(safe-area-inset-left, 0px)) 12px max(10px, env(safe-area-inset-right, 0px));
    align-items: start;
}
.club-looks-feed-ig > .club-looks-empty {
    grid-column: 1 / -1;
}
.acc-look-card {
    background: linear-gradient(150deg, rgba(20, 19, 30, 0.88), rgba(12, 12, 20, 0.92));
    border: 1px solid rgba(255, 255, 255, 0.11);
    border-radius: 18px;
    box-shadow: 0 16px 30px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.05);
    overflow: hidden;
    transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
    animation: clubLookIn 0.24s ease both;
}
.acc-look-card:hover {
    transform: translateY(-4px) scale(1.012);
    border-color: rgba(255, 132, 206, 0.5);
    box-shadow: 0 24px 38px rgba(0, 0, 0, 0.4);
}
.acc-look-card--ig {
    cursor: default;
    border-radius: 0;
    background: #000;
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.09);
    box-shadow: none;
    animation: none;
}
.acc-look-card--ig:hover {
    transform: none;
    border-color: rgba(255, 255, 255, 0.09);
    box-shadow: none;
}

/* Лента образов — сетка 2 колонки (макет VISNER CLUB) */
.acc-look-card--grid {
    cursor: default;
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
    border-radius: 16px;
    background: linear-gradient(165deg, rgba(16, 14, 24, 0.96), rgba(8, 8, 14, 0.98));
    border: 1px solid rgba(168, 85, 247, 0.35);
    box-shadow:
        0 0 0 1px rgba(139, 92, 246, 0.06),
        0 10px 28px rgba(0, 0, 0, 0.38),
        0 0 22px rgba(139, 92, 246, 0.1);
    animation: clubLookIn 0.26s ease both;
}
.acc-look-card--grid:hover {
    transform: translateY(-2px);
    border-color: rgba(236, 96, 169, 0.48);
    box-shadow:
        0 0 0 1px rgba(236, 96, 169, 0.18),
        0 14px 34px rgba(0, 0, 0, 0.42),
        0 0 30px rgba(168, 85, 247, 0.16);
}
.club-look-grid-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 9px 10px 8px;
    flex-shrink: 0;
}
.club-look-grid-user {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    flex: 1;
    text-align: left;
    border: none;
    background: transparent;
    padding: 0;
    color: inherit;
    font: inherit;
    cursor: pointer;
}
.club-look-grid-user:disabled {
    cursor: default;
}
.club-look-grid-user .social-member-avatar,
.club-look-grid-user .social-member-avatar[style] {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    max-width: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
    border-radius: 50%;
    flex-shrink: 0;
    object-fit: cover;
}
.club-look-grid-user-text {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-width: 0;
}
.club-look-grid-handle {
    font-size: 12px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.94);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 22vw;
}
.club-look-grid-handle-heart {
    font-size: 10px;
    color: #ff5eb3;
    opacity: 0.95;
    flex-shrink: 0;
}
.club-look-grid-head-meta {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}
.club-look-grid-time {
    font-size: 10px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.48);
    white-space: nowrap;
}
.club-look-grid-more {
    width: 32px;
    height: 32px;
    margin: 0 -4px 0 0;
    border: none;
    border-radius: 10px;
    background: transparent;
    color: rgba(255, 255, 255, 0.85);
    font-size: 14px;
    cursor: pointer;
    display: grid;
    place-items: center;
}
.club-look-grid-media {
    position: relative;
    width: 100%;
    background: #0a0a0a;
    flex-shrink: 0;
}
.club-look-grid-media img {
    width: 100%;
    display: block;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    background: #111;
    cursor: pointer;
}
.club-look-grid-media .club-look-grid-ph {
    aspect-ratio: 3 / 4;
    min-height: 0;
    width: 100%;
}
.club-look-grid-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    padding: 0 10px 0;
}
.club-look-grid-title {
    margin: 10px 0 6px;
    font-size: 13px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.96);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.club-look-grid-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-bottom: 4px;
}
.club-look-grid-tag {
    display: inline-block;
    padding: 3px 8px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.88);
    background: rgba(88, 28, 135, 0.55);
    border: 1px solid rgba(168, 85, 247, 0.35);
}
.club-look-grid-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 0 12px;
    margin-top: auto;
}
.club-look-grid-foot-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    min-height: 34px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.88);
    font-size: 13px;
    cursor: pointer;
    font-family: inherit;
    transition:
        border-color 0.18s ease,
        background 0.18s ease,
        box-shadow 0.18s ease;
}
.club-look-grid-foot-btn:hover {
    border-color: rgba(255, 170, 210, 0.35);
    background: rgba(255, 255, 255, 0.09);
}
.club-look-grid-foot-btn.is-on {
    border-color: rgba(236, 96, 169, 0.55);
    background: linear-gradient(145deg, rgba(236, 96, 169, 0.22), rgba(152, 95, 235, 0.2));
    color: #fff;
    box-shadow: 0 0 12px rgba(236, 96, 169, 0.25);
}
.club-look-grid-foot-btn--bookmark {
    margin-left: auto;
    padding: 0 11px;
}
.club-look-grid-act-num {
    font-size: 11px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.82);
    min-width: 1ch;
}
.club-look-grid-foot-btn.is-on .club-look-grid-act-num {
    color: #fff;
}

.ig-post-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px max(12px, env(safe-area-inset-left, 0px)) 8px max(12px, env(safe-area-inset-right, 0px));
    background: #000;
}
.ig-post-head-main {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    flex: 1;
    text-align: left;
    cursor: pointer;
    border: none;
    background: transparent;
    padding: 0;
    color: inherit;
    font: inherit;
}
.ig-post-head-main:focus-visible {
    outline: 2px solid rgba(168, 130, 255, 0.85);
    outline-offset: 2px;
    border-radius: 8px;
}
.ig-post-head-main .social-member-avatar,
.ig-post-head-main .social-member-avatar[style] {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    max-width: 32px !important;
    min-height: 32px !important;
    max-height: 32px !important;
    border-radius: 50%;
    flex-shrink: 0;
    object-fit: cover;
    box-sizing: border-box;
    overflow: hidden;
}
.ig-post-user {
    font-size: 14px;
    font-weight: 700;
    color: #fafafa;
    line-height: 1.2;
}
.ig-post-sub {
    margin-top: 2px;
    font-size: 12px;
    font-weight: 400;
    color: rgba(245, 245, 245, 0.55);
    line-height: 1.25;
}
.ig-post-more {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    margin: -6px -4px -6px 0;
    border: none;
    border-radius: 10px;
    background: transparent;
    color: rgba(255, 255, 255, 0.92);
    font-size: 16px;
    cursor: pointer;
    display: grid;
    place-items: center;
    opacity: 0.85;
}
.ig-post-more:hover {
    opacity: 1;
}
.ig-post-media {
    position: relative;
    display: block;
    width: 100%;
    background: #0a0a0a;
}
.ig-post-media img {
    width: 100%;
    display: block;
    max-height: min(72vh, 720px);
    min-height: 260px;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    background: #111;
    cursor: pointer;
}
/* Файлы стикеров в блоке медиа (не обычное фото look) — компактно, без «полноэкранной» подложки */
.ig-post-media img[src*="stickers/"] {
    width: auto;
    max-width: min(220px, 90vw);
    max-height: min(220px, 44vh);
    min-height: 0;
    margin: 0 auto;
    aspect-ratio: auto;
    object-fit: contain;
    background: transparent;
    cursor: default;
}
.ig-post-media .acc-look-card-ph {
    width: 100%;
    max-height: min(72vh, 720px);
    min-height: 260px;
    aspect-ratio: 1 / 1;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02));
}
.acc-look-card-ph {
    width: 100%;
    aspect-ratio: 4 / 5;
    min-height: clamp(268px, 52vw, 420px);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02));
}
.visner-look-toolbar {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
    padding: 8px max(10px, env(safe-area-inset-left, 0px)) 6px max(10px, env(safe-area-inset-right, 0px));
    background: #000;
}
.visner-look-actions-main {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: 4px;
    flex: 1;
    min-width: 0;
}
.visner-look-act {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    padding: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.92);
    font-size: 17px;
    cursor: pointer;
    flex-shrink: 0;
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.15s ease;
    font-family: inherit;
}
.visner-look-act i {
    line-height: 1;
    pointer-events: none;
}
.visner-look-act:hover {
    border-color: rgba(255, 170, 210, 0.42);
    background: rgba(255, 255, 255, 0.09);
    transform: translateY(-1px);
}
.visner-look-act.is-on {
    border-color: rgba(236, 96, 169, 0.55);
    background: linear-gradient(145deg, rgba(236, 96, 169, 0.28), rgba(152, 95, 235, 0.24));
    color: #fff;
    box-shadow: 0 0 0 1px rgba(255, 140, 200, 0.16), 0 6px 18px rgba(100, 30, 90, 0.25);
}
.visner-look-act--solo {
    margin-left: auto;
    flex-shrink: 0;
}
.ig-post-body {
    padding: 2px max(14px, env(safe-area-inset-left, 0px)) 18px max(14px, env(safe-area-inset-right, 0px));
    background: #000;
}
.ig-post-likes {
    margin: 0 0 6px;
    font-size: 14px;
    font-weight: 600;
    color: #fafafa;
    line-height: 1.35;
}
.ig-post-likes strong {
    font-weight: 700;
}
.ig-post-likes span {
    font-weight: 600;
    color: rgba(255, 255, 255, 0.55);
}
.ig-post-likes--muted {
    font-weight: 500;
    color: rgba(255, 255, 255, 0.42);
}
.ig-post-caption-wrap {
    position: relative;
    margin-bottom: 6px;
}
.ig-post-caption {
    margin: 0;
    font-size: 14px;
    line-height: 1.45;
    color: rgba(250, 250, 250, 0.92);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    overflow: hidden;
}
.ig-post-caption-wrap.is-expanded .ig-post-caption {
    -webkit-line-clamp: unset;
    line-clamp: unset;
    display: block;
    overflow: visible;
}
.ig-post-name-inline {
    font-weight: 700;
    color: #fafafa;
    margin-right: 6px;
}
.ig-caption-more {
    margin-top: 4px;
    padding: 0;
    border: none;
    background: none;
    color: rgba(255, 255, 255, 0.45);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}
.ig-caption-more:hover {
    color: rgba(255, 255, 255, 0.65);
}
.ig-post-comment-preview {
    margin: 4px 0 0;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.35;
}
.ig-post-time {
    margin: 10px 0 0;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.38);
}
.acc-look-card img:not(.social-member-avatar):not(.visner-inline-sticker) {
    aspect-ratio: 4 / 5;
    min-height: 280px;
    background: rgba(0, 0, 0, 0.45);
}
.acc-look-card--ig .ig-post-media img {
    aspect-ratio: 1 / 1;
    min-height: 260px;
}
.acc-look-card-body {
    padding: 10px 12px 12px;
}
.acc-look-card-head {
    padding: 12px 12px 8px;
}
.club-look-actions {
    margin-top: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.club-look-action-btn {
    border: 1px solid rgba(255, 255, 255, 0.13);
    border-radius: 999px;
    background: rgba(19, 19, 28, 0.72);
    color: #fff;
    font-size: 12px;
    padding: 5px 11px;
    cursor: pointer;
    transition: transform 0.16s ease, border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}
.club-look-action-btn:hover {
    transform: translateY(-1px);
    border-color: rgba(255, 255, 255, 0.3);
    box-shadow: 0 8px 14px rgba(0, 0, 0, 0.25);
}
.club-look-action-btn.is-active {
    background: linear-gradient(135deg, rgba(255, 101, 177, 0.42), rgba(141, 98, 239, 0.42));
    border-color: rgba(255, 170, 216, 0.52);
}
.club-look-comment-line {
    margin-top: 8px;
    font-size: 11px;
    color: rgba(255, 255, 255, 0.58);
}
.club-looks-empty {
    margin: 4px max(14px, env(safe-area-inset-left, 0px)) 28px max(14px, env(safe-area-inset-right, 0px));
    text-align: center;
    padding: clamp(22px, 5vw, 36px) clamp(14px, 4vw, 22px) clamp(28px, 6vw, 40px);
    border-radius: 18px;
    border: 1px solid rgba(168, 85, 247, 0.42);
    background: linear-gradient(165deg, rgba(14, 12, 22, 0.96), rgba(6, 6, 10, 0.98));
    box-shadow:
        0 0 0 1px rgba(139, 92, 246, 0.12),
        0 0 40px rgba(139, 92, 246, 0.14),
        0 18px 48px rgba(0, 0, 0, 0.45),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
.club-looks-empty-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.club-looks-empty-visual-wrap {
    position: relative;
    width: 100%;
    max-width: min(152px, 42vw);
    margin: 0 auto clamp(10px, 2.8vw, 14px);
}
.club-looks-empty-visual-glow {
    position: absolute;
    inset: -6px -8px -10px -8px;
    border-radius: 50%;
    background: radial-gradient(ellipse 85% 70% at 50% 55%, rgba(168, 85, 247, 0.32), rgba(255, 94, 179, 0.06) 50%, transparent 72%);
    filter: blur(6px);
    pointer-events: none;
    z-index: 0;
}
.club-looks-empty-star {
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 8px rgba(255, 200, 255, 0.9);
    opacity: 0.85;
    z-index: 2;
    pointer-events: none;
}
.club-looks-empty-star--1 {
    top: 8%;
    right: 12%;
    transform: scale(0.9);
}
.club-looks-empty-star--2 {
    top: 22%;
    left: 8%;
    width: 4px;
    height: 4px;
    opacity: 0.65;
}
.club-looks-empty-star--3 {
    bottom: 28%;
    right: 6%;
    width: 5px;
    height: 5px;
}
.club-looks-empty-visual {
    position: relative;
    z-index: 1;
    margin: 0 auto;
    padding: clamp(5px, 1.4vw, 8px);
    border-radius: 14px;
    background: linear-gradient(155deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.03));
    border: 1px solid rgba(167, 139, 250, 0.45);
    box-shadow:
        0 0 18px rgba(139, 92, 246, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
}
.club-looks-empty-bag-img {
    display: block;
    width: auto;
    height: auto;
    max-width: min(136px, 38vw);
    /* vmin в альбоме даёт крошечную высоту — только vw + clamp */
    max-height: min(124px, max(84px, 30vw));
    min-width: 72px;
    min-height: 56px;
    margin: 0 auto;
    border-radius: 10px;
    object-fit: contain;
    object-position: center bottom;
    opacity: 1;
    visibility: visible;
}
.club-looks-empty-line1 {
    margin: 0 0 6px;
    font-size: 17px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.95);
    letter-spacing: 0.01em;
}
.club-looks-empty-spark {
    display: inline;
}
.club-looks-empty-line2 {
    margin: 0 0 12px;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: 0.02em;
    background: linear-gradient(92deg, #ff7eb8 0%, #e879f9 45%, #c084fc 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: drop-shadow(0 0 12px rgba(232, 121, 249, 0.25));
}
.club-looks-empty-sub {
    margin: 0 auto 4px;
    max-width: 34ch;
    font-size: 12px;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.48);
}
.club-looks-empty-cta {
    margin-top: 18px;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.18);
    display: grid;
    place-items: center;
    cursor: pointer;
    font-size: 26px;
    color: #fff;
    background: linear-gradient(145deg, #ff5eb3 0%, #d946ef 48%, #a855f7 100%);
    box-shadow:
        0 12px 32px rgba(168, 85, 247, 0.38),
        0 0 24px rgba(255, 94, 179, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.25);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.club-looks-empty-cta:hover {
    transform: scale(1.04);
    box-shadow:
        0 14px 36px rgba(168, 85, 247, 0.45),
        0 0 28px rgba(255, 94, 179, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.3);
}
.club-looks-empty-cta-label {
    margin: 14px 0 0;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    background: linear-gradient(92deg, #ff7eb8, #e879f9, #c084fc);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

/* Minimal theme: убираем чёрный фон IG-ленты в CLUB */
html[data-theme='minimal'] .club-looks-shell {
    background: transparent;
}
html[data-theme='minimal'] .club-looks-page-head {
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(44, 40, 36, 0.1);
    border-radius: 16px;
    padding: 12px 14px;
    box-shadow: 0 8px 20px rgba(44, 40, 36, 0.06);
}
html[data-theme='minimal'] .club-looks-page-title {
    color: rgba(44, 40, 36, 0.92);
}
html[data-theme='minimal'] .club-looks-page-sub {
    color: rgba(44, 40, 36, 0.52);
}
html[data-theme='minimal'] .club-looks-add-btn .fas.fa-plus {
    color: #b5658c;
}
html[data-theme='minimal'] .club-looks-feed-ig {
    gap: 10px;
}
html[data-theme='minimal'] .club-looks-page-title-sparks {
    background: linear-gradient(120deg, #a87888, #8a7aa0);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: none;
}
html[data-theme='minimal'] .acc-look-card--grid {
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(44, 40, 36, 0.12);
    box-shadow: 0 10px 22px rgba(44, 40, 36, 0.08);
}
html[data-theme='minimal'] .acc-look-card--grid:hover {
    box-shadow: 0 12px 26px rgba(44, 40, 36, 0.1);
}
html[data-theme='minimal'] .club-look-grid-handle,
html[data-theme='minimal'] .club-look-grid-title {
    color: rgba(44, 40, 36, 0.92);
}
html[data-theme='minimal'] .club-look-grid-time {
    color: rgba(44, 40, 36, 0.48);
}
html[data-theme='minimal'] .club-look-grid-more {
    color: rgba(44, 40, 36, 0.65);
}
html[data-theme='minimal'] .club-look-grid-tag {
    background: rgba(124, 107, 138, 0.22);
    border-color: rgba(44, 40, 36, 0.14);
    color: rgba(44, 40, 36, 0.88);
}
html[data-theme='minimal'] .club-look-grid-foot-btn {
    background: rgba(255, 255, 255, 0.78);
    border-color: rgba(44, 40, 36, 0.14);
    color: rgba(44, 40, 36, 0.82);
}
html[data-theme='minimal'] .club-look-grid-foot-btn.is-on {
    border-color: rgba(181, 101, 140, 0.45);
    background: linear-gradient(145deg, rgba(181, 101, 140, 0.18), rgba(138, 122, 160, 0.16));
    color: rgba(44, 40, 36, 0.92);
}
html[data-theme='minimal'] .club-look-grid-act-num {
    color: rgba(44, 40, 36, 0.75);
}
html[data-theme='minimal'] .acc-look-card--ig {
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(44, 40, 36, 0.12);
    border-radius: 16px;
    overflow: hidden;
}
html[data-theme='minimal'] .acc-look-card--ig .ig-post-head,
html[data-theme='minimal'] .acc-look-card--ig .ig-post-body,
html[data-theme='minimal'] .acc-look-card--ig .visner-look-toolbar {
    background: transparent;
}
html[data-theme='minimal'] .acc-look-card--ig .ig-post-user {
    color: rgba(44, 40, 36, 0.9);
}
html[data-theme='minimal'] .acc-look-card--ig .ig-post-sub {
    color: rgba(44, 40, 36, 0.55);
}
html[data-theme='minimal'] .club-looks-empty {
    border: 1px solid rgba(44, 40, 36, 0.14);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(247, 242, 236, 0.98));
    box-shadow: 0 10px 28px rgba(44, 40, 36, 0.08);
}
html[data-theme='minimal'] .club-looks-empty-visual {
    border-color: rgba(44, 40, 36, 0.14);
    box-shadow: 0 8px 20px rgba(44, 40, 36, 0.06);
    background: linear-gradient(155deg, rgba(255, 255, 255, 0.65), rgba(247, 242, 236, 0.5));
}
html[data-theme='minimal'] .club-looks-empty-visual-glow {
    opacity: 0.45;
}
html[data-theme='minimal'] .club-looks-empty-line1 {
    color: rgba(44, 40, 36, 0.9);
}
html[data-theme='minimal'] .club-looks-empty-line2 {
    background: linear-gradient(92deg, #8b5a6b, #7c6b8c);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: none;
}
html[data-theme='minimal'] .club-looks-empty-sub {
    color: rgba(44, 40, 36, 0.55);
}
html[data-theme='minimal'] .club-looks-empty-cta {
    background: linear-gradient(145deg, #c9a89a, #9a8aad);
    border-color: rgba(44, 40, 36, 0.12);
    box-shadow: 0 10px 22px rgba(44, 40, 36, 0.12);
}
html[data-theme='minimal'] .club-looks-empty-cta-label {
    background: linear-gradient(92deg, #6d5846, #5c4f68);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
html[data-theme='minimal'] .club-looks-compose-fab {
    --fab-nav-w: min(100vw, var(--container, 480px));
    background: rgba(255, 255, 255, 0.92);
    color: #6d5846;
    border-color: rgba(44, 40, 36, 0.16);
    box-shadow: 0 10px 22px rgba(44, 40, 36, 0.12);
}
.club-looks-compose-fab {
    /* Центр над 4-й вкладкой «CLUB» (та же ширина полосы, что у .bottom-nav) */
    --fab-nav-w: min(100vw - 24px, var(--container, 480px));
    position: fixed;
    left: calc(50vw + 3 * var(--fab-nav-w) / 8 - 27px);
    right: auto;
    bottom: calc(clamp(72px, 11vh, 92px) + env(safe-area-inset-bottom, 0px));
    z-index: 1080;
    width: 54px;
    height: 54px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: linear-gradient(145deg, #ff5eb3 0%, #d946ef 50%, #a855f7 100%);
    color: #fff;
    font-size: 20px;
    display: grid;
    place-items: center;
    cursor: pointer;
    box-shadow:
        0 12px 32px rgba(168, 85, 247, 0.4),
        0 0 20px rgba(255, 94, 179, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.28);
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.club-looks-compose-fab:hover {
    transform: translateY(-2px) scale(1.04);
    border-color: rgba(255, 255, 255, 0.35);
    box-shadow:
        0 14px 36px rgba(168, 85, 247, 0.48),
        0 0 26px rgba(255, 94, 179, 0.3),
        inset 0 1px 0 rgba(255, 255, 255, 0.32);
}
.club-looks-compose-fab.hidden {
    display: none !important;
}
@media (max-width: 560px) {
    .club-look-composer {
        padding: 11px;
        gap: 9px;
    }
    .club-look-dropzone {
        padding: 11px 10px 9px;
    }
    .club-look-caption {
        min-height: 60px;
    }
    .ig-post-media img {
        min-height: 220px;
    }
    .club-looks-page-head {
        margin-bottom: 14px;
    }
}
.club-look-comments-panel {
    transform: translateX(-50%) translateY(105%);
}
.club-look-comments-panel.is-open {
    transform: translateX(-50%) translateY(0);
}
.club-look-comments-body {
    display: flex;
    flex-direction: column;
    min-height: 0;
    padding: 10px 12px 14px;
}
.club-look-comments-list {
    flex: 1;
    overflow-y: auto;
    min-height: 120px;
    padding-right: 2px;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}
.club-look-comment-item {
    padding: 9px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.club-look-comment-item:last-child {
    border-bottom: none;
}
.club-look-comment-author {
    font-size: 12px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.9);
}
.club-look-comment-text {
    margin-top: 4px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.82);
    line-height: 1.4;
}
.club-look-comments-panel .club-look-comment-text .visner-inline-sticker {
    max-height: clamp(92px, 20vw, 148px);
    max-width: min(280px, 90vw);
    width: auto;
    height: auto;
    object-fit: contain;
    vertical-align: middle;
    display: inline-block;
    margin: 4px 0;
}
@media (max-width: 420px) {
    .club-look-comments-panel .club-look-comment-text .visner-inline-sticker {
        max-height: clamp(96px, 28vw, 156px);
        max-width: min(300px, 92vw);
    }
}
.club-look-comment-meta {
    margin-top: 4px;
    font-size: 10px;
    color: rgba(255, 255, 255, 0.44);
}
.club-look-comment-mention {
    color: #f5b6ff;
    font-weight: 700;
}
.club-look-comments-compose {
    margin-top: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
}
.club-look-comments-compose .chat-input {
    min-height: 42px;
}
.club-look-comment-delete {
    margin-left: 8px;
    border: 1px solid rgba(255, 120, 120, 0.32);
    background: rgba(255, 70, 90, 0.12);
    color: #ffb3be;
    border-radius: 999px;
    font-size: 10px;
    padding: 2px 7px;
    cursor: pointer;
}
.club-look-comment-edit {
    margin-left: 6px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.9);
    border-radius: 999px;
    font-size: 10px;
    padding: 2px 7px;
    cursor: pointer;
}
.club-look-comments-more {
    width: 100%;
    margin: 2px 0 10px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.82);
    border-radius: 10px;
    font-size: 12px;
    padding: 7px 10px;
    cursor: pointer;
}
.club-look-mentions {
    position: absolute;
    left: 0;
    right: 56px;
    bottom: calc(100% + 6px);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(14, 14, 20, 0.92);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.34);
    overflow: hidden;
    z-index: 2;
}
.club-look-mentions.hidden {
    display: none;
}
.club-look-mention-item {
    width: 100%;
    border: none;
    background: transparent;
    color: rgba(255, 255, 255, 0.9);
    text-align: left;
    padding: 9px 10px;
    font-size: 13px;
    cursor: pointer;
}
.club-look-mention-item:hover,
.club-look-mention-item.is-active {
    background: rgba(255, 255, 255, 0.08);
}
.look-image-modal-content {
    width: min(100vw, 980px);
    max-height: 100vh;
    margin: 0 auto;
    display: grid;
    place-items: center;
    background: transparent;
    box-shadow: none;
    border: none;
    padding: 0;
}
.look-image-modal-content img {
    width: 100%;
    max-height: 92vh;
    object-fit: contain;
    border-radius: 0;
    background: #000;
    user-select: none;
    -webkit-user-drag: none;
    touch-action: none;
    cursor: zoom-in;
    transform-origin: center center;
    transition: transform 0.18s ease;
}
@keyframes clubLookIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ========== VISNER messenger — glass + neon (клуб + ЛС), капсулы без хвостов ========== */
.visner-messenger {
    --vm-edge: 18px;
    --vm-capsule: 26px;
    position: relative;
    background:
        radial-gradient(ellipse 120% 80% at 50% -20%, rgba(120, 60, 255, 0.22), transparent 55%),
        radial-gradient(ellipse 90% 60% at 100% 40%, rgba(255, 60, 140, 0.12), transparent 50%),
        linear-gradient(168deg, #020208 0%, #070518 42%, #100828 100%);
    background-color: #030206;
    border-radius: 0;
    min-height: 0;
    position: relative;
}
.visner-messenger::before {
    content: '';
    pointer-events: none;
    position: absolute;
    inset: 0;
    z-index: 0;
    opacity: 0.055;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='128' height='128'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='128' height='128' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
    mix-blend-mode: overlay;
}
.visner-messenger > * {
    position: relative;
    z-index: 1;
}

.visner-messenger__topbar {
    display: grid;
    grid-template-columns: 44px 1fr 44px;
    align-items: center;
    gap: 8px;
    padding: max(8px, env(safe-area-inset-top, 0px)) 14px 12px;
    min-height: 52px;
    box-sizing: border-box;
    background: rgba(8, 8, 18, 0.48);
    -webkit-backdrop-filter: blur(22px) saturate(1.35);
    backdrop-filter: blur(22px) saturate(1.35);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
}

.visner-messenger__nav-btn {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.92);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    flex-shrink: 0;
    transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
}
.visner-messenger__nav-btn:hover {
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 180, 230, 0.45);
    box-shadow: 0 0 20px rgba(255, 100, 200, 0.22);
}
.visner-messenger__nav-btn > i {
    pointer-events: none;
    font-size: 16px;
}

.visner-messenger__title-wrap {
    text-align: center;
    min-width: 0;
    padding: 0 4px;
}

.visner-messenger__title {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: 0.06em;
    background: linear-gradient(105deg, #ffd700 0%, #ff69b4 38%, #c07cff 72%, #ff9f42 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    line-height: 1.25;
}

.visner-messenger__subtitle {
    margin: 4px 0 0;
    font-size: 12px;
    line-height: 1.25;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.46);
}

.visner-messenger__messages-wrap {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.visner-messenger-empty {
    text-align: center;
    color: rgba(255, 255, 255, 0.42);
    padding: 32px 20px;
    font-size: 14px;
    line-height: 1.5;
}

.visner-chat-date-sep {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px 16px;
    margin: 10px 0;
}
.visner-chat-date-sep span {
    font-size: 11px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.2;
    color: rgba(255, 255, 255, 0.55);
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
    backdrop-filter: blur(16px) saturate(1.2);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.chat-avatar-spacer {
    width: 36px;
    flex-shrink: 0;
    align-self: flex-end;
}

#socialDmPanel .chat-message.club-chat-message--continued {
    margin-top: 8px;
}
#socialDmPanel .chat-message.club-chat-message--break {
    margin-top: 16px;
}

#tab-chat .club-chat-message,
#socialDmPanel .chat-message {
    max-width: min(82%, 520px);
    margin-top: 8px;
}
#tab-chat .club-chat-message.club-chat-message--break,
#socialDmPanel .chat-message.club-chat-message--break {
    margin-top: 16px;
}
#tab-chat .club-chat-message.club-chat-message--continued,
#socialDmPanel .chat-message.club-chat-message--continued {
    margin-top: 8px;
}

/* ЛС: открытая панель без transform — иначе любой fixed внутри цепляется к панели и смещается. Закрытая уезжает вправо. */
#socialDmPanel.social-dm-panel.account-panel {
    left: 0 !important;
    right: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
#socialDmPanel.social-dm-panel.account-panel:not(.is-open) {
    transform: translateX(100%) !important;
}
#socialDmPanel.social-dm-panel.account-panel.is-open {
    transform: none !important;
}

#socialDmPanel .chat-message {
    animation: clubMsgIn 0.2s ease both;
    transform-origin: center center;
}

/* ЛС: те же капсулы (перекрывает общие правила product-theme) */
#socialDmPanel .chat-message .chat-bubble {
    padding: 14px 16px 13px;
    border-radius: var(--vm-capsule, 26px) !important;
    border: 1px solid rgba(255, 255, 255, 0.14);
}
#socialDmPanel .chat-message.chat-message--theirs .chat-bubble {
    background: rgba(18, 16, 28, 0.52);
    -webkit-backdrop-filter: blur(18px) saturate(1.25);
    backdrop-filter: blur(18px) saturate(1.25);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.07), 0 8px 28px rgba(0, 0, 0, 0.35);
}
#socialDmPanel .chat-message.chat-message--mine .chat-bubble {
    background: linear-gradient(135deg, #8b5cff 0%, #ff4dad 48%, #ff9f42 100%);
    border-color: rgba(255, 255, 255, 0.22);
    box-shadow:
        0 0 0 1px rgba(255, 140, 220, 0.25),
        0 6px 26px rgba(255, 90, 180, 0.42),
        0 0 40px rgba(140, 80, 255, 0.22);
}
#socialDmPanel .chat-message.chat-message--mine:hover .chat-bubble,
#socialDmPanel .chat-message.chat-message--mine:focus-within .chat-bubble {
    filter: brightness(1.06);
}

.chat-msg-row {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 10px;
    max-width: 100%;
}
.chat-msg-row .chat-text {
    flex: 1;
    min-width: 0;
    font-size: 15px;
    line-height: 22px;
    color: rgba(255, 255, 255, 0.97);
}
.chat-msg-row .chat-time {
    flex-shrink: 0;
    font-size: 11px;
    line-height: 15px;
    color: rgba(255, 255, 255, 0.5);
    align-self: flex-end;
    padding-left: 8px;
    white-space: nowrap;
}

.chat-bubble-footer {
    display: flex;
    justify-content: flex-end;
    margin-top: 6px;
}
.chat-message--theirs .chat-bubble-footer {
    justify-content: flex-start;
}
.chat-bubble-footer .chat-time {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.48);
}

#tab-chat .club-chat-message .chat-avatar,
#socialDmPanel .chat-message .chat-avatar,
#tab-chat .club-chat-message .chat-avatar--letter {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
}

#tab-chat .club-chat-author {
    font-size: 12px;
    font-weight: 600;
    color: rgba(210, 180, 255, 0.92);
    margin-bottom: 6px;
}

.visner-messenger__composer.club-chat-composer {
    margin-top: 0;
    border-radius: 28px !important;
    padding: 10px 12px !important;
    background: rgba(12, 10, 22, 0.42) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    -webkit-backdrop-filter: blur(22px) saturate(1.35);
    backdrop-filter: blur(22px) saturate(1.35);
    box-shadow: 0 -8px 48px rgba(0, 0, 0, 0.55), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

#tab-chat .chat-input-wrapper--club .chat-input,
#socialDmPanel .chat-input-wrapper--club .chat-input {
    min-height: 52px;
    border-radius: 26px;
    padding: 12px 16px;
    font-size: 15px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: #fff;
}

#tab-chat .chat-send,
#socialDmPanel .chat-send {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, #a855f7 0%, #ec4899 45%, #fb923c 100%);
    border: none;
    box-shadow:
        0 0 0 1px rgba(255, 200, 240, 0.35),
        0 8px 28px rgba(236, 72, 153, 0.55),
        0 0 36px rgba(168, 85, 247, 0.35);
}

.social-dm-panel.visner-messenger--dm {
    background:
        radial-gradient(ellipse 120% 80% at 50% -20%, rgba(120, 60, 255, 0.18), transparent 55%),
        linear-gradient(168deg, #020208 0%, #070518 42%, #100828 100%);
}

.social-dm-panel .account-panel-header.visner-messenger__topbar {
    display: grid;
    grid-template-columns: 44px 1fr 44px;
    align-items: center;
    gap: 8px;
    padding-left: 12px;
    padding-right: 12px;
    background: rgba(8, 8, 18, 0.52);
    -webkit-backdrop-filter: blur(22px) saturate(1.35);
    backdrop-filter: blur(22px) saturate(1.35);
}

.social-dm-panel .account-panel-header .visner-messenger__title-wrap {
    flex: unset;
    width: auto;
}

.social-dm-panel .account-panel-header span#socialDmHeaderTitle.visner-messenger__title,
.social-dm-panel .account-panel-header span.visner-messenger__title {
    flex: none !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    text-transform: none !important;
    letter-spacing: 0.04em !important;
    display: block;
    background: linear-gradient(105deg, #ffd700 0%, #ff69b4 40%, #c07cff 78%, #ffb347 100%);
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}

.social-dm-panel .account-panel-header span#socialDmHeaderSub.visner-messenger__subtitle,
.social-dm-panel .account-panel-header span.visner-messenger__subtitle {
    display: block;
    margin-top: 4px;
    font-weight: 400;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.48);
    text-transform: none;
    letter-spacing: normal;
}

#socialDmPanel .visner-messenger__scroll.chat-messages {
    padding: 16px var(--vm-edge, 18px) 12px;
    gap: 0;
}

#socialDmPanel .club-chat-composer {
    border-radius: 28px;
    padding: 10px 12px;
    background: rgba(12, 10, 22, 0.42);
    border: 1px solid rgba(255, 255, 255, 0.12);
    -webkit-backdrop-filter: blur(22px) saturate(1.35);
    backdrop-filter: blur(22px) saturate(1.35);
    box-shadow: 0 -8px 48px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.chat-attach-img-wrap {
    border-radius: 18px;
}

.social-dm-panel .account-panel-header.visner-messenger__topbar .visner-messenger__nav-btn {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
    border-radius: 14px;
}

@media (max-width: 420px) {
    #tab-chat .club-chat-message,
    #socialDmPanel .chat-message {
        max-width: min(88%, 440px);
    }
}

/* VISNER FIX: личные сообщения — скролл только списка сообщений, композер закреплен снизу панели */
#socialDmPanel.social-dm-panel {
    height: 100dvh;
    max-height: 100dvh;
    overflow: hidden;
}
/*
 * APK WebView: не использовать height:auto здесь — панель схлопывалась по контенту («окно» по центру,
 * чёрные поля сверху/снизу, без скролла ленты). Удерживаем высоту viewport + те же top/bottom, что у .account-panel.
 */
html.visner-android-webview #socialDmPanel.social-dm-panel {
    height: 100dvh !important;
    max-height: 100dvh !important;
    min-height: 100dvh !important;
}
#socialDmPanel .account-panel-body.visner-messenger__dm-body {
    flex: 1;
    min-height: 0;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    padding-bottom: 0 !important;
}
/* Перебиваем глобальное .chat-messages { height:400px } и margin из club-social — иначе ЛС не заполняет колонку. */
#socialDmPanel #socialDmMessages.visner-messenger__scroll.chat-messages {
    flex: 1 1 0% !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: none !important;
    margin-bottom: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y !important;
    overscroll-behavior-y: contain !important;
    padding-bottom: calc(16px + var(--visner-bottom-edge-inset)) !important;
}
#socialDmPanel.is-open .club-chat-composer.visner-messenger__composer {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: none !important;
    flex-shrink: 0 !important;
    z-index: 5 !important;
}

/* ——— ЛС: футуристичный композер (только #socialDmPanel), glass + neon ——— */
#socialDmPanel .visner-dm-composer-host.club-chat-composer {
    border-radius: 0;
    padding: 0;
    background:
        linear-gradient(180deg, rgba(6, 10, 28, 0.97) 0%, rgba(8, 14, 42, 0.98) 45%, rgba(10, 18, 48, 1) 100%);
    border: none;
    border-top: 1px solid rgba(120, 90, 255, 0.18);
    box-shadow:
        0 -12px 48px rgba(0, 0, 0, 0.55),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    -webkit-backdrop-filter: blur(24px) saturate(1.45);
    backdrop-filter: blur(24px) saturate(1.45);
}

#socialDmPanel .visner-dm-composer-host .club-chat-pending:not(.hidden) {
    padding: 10px 14px 0;
}

#socialDmPanel .visner-dm-composer {
    padding: 14px 14px calc(14px + env(safe-area-inset-bottom, 0px));
}

#socialDmPanel .visner-dm-composer__input-strip {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-height: 52px;
}

#socialDmPanel .visner-dm-composer__tool {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.88);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        0 4px 16px rgba(0, 0, 0, 0.35);
    transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}
#socialDmPanel .visner-dm-composer__tool:active {
    transform: scale(0.96);
}
#socialDmPanel .visner-dm-composer__tool:hover {
    border-color: rgba(180, 140, 255, 0.45);
    background: rgba(140, 90, 255, 0.14);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.14),
        0 0 22px rgba(138, 92, 255, 0.28);
}

#socialDmPanel .visner-dm-composer__field-shell {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px 6px 14px;
    border-radius: 22px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.09) 0%, rgba(40, 30, 80, 0.22) 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.14),
        0 8px 28px rgba(0, 0, 0, 0.35),
        0 0 0 1px rgba(120, 80, 220, 0.15);
    -webkit-backdrop-filter: blur(18px) saturate(1.35);
    backdrop-filter: blur(18px) saturate(1.35);
}

#socialDmPanel .visner-dm-composer--typing .visner-dm-composer__field-shell {
    border-color: rgba(255, 130, 200, 0.35);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.16),
        0 8px 32px rgba(255, 90, 180, 0.18),
        0 0 36px rgba(130, 80, 255, 0.22);
}

#socialDmPanel .visner-dm-composer__input {
    flex: 1;
    min-width: 0;
    border: none;
    background: transparent;
    color: rgba(255, 255, 255, 0.95);
    font-size: 15px;
    line-height: 1.35;
    padding: 8px 4px;
    outline: none;
}
#socialDmPanel .visner-dm-composer__input::placeholder {
    color: rgba(255, 255, 255, 0.38);
}

#socialDmPanel .visner-dm-composer__mic-inside {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.07);
    color: rgba(200, 190, 255, 0.95);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}
#socialDmPanel .visner-dm-composer__mic-inside:hover {
    background: rgba(140, 100, 255, 0.22);
    box-shadow: 0 0 18px rgba(160, 100, 255, 0.35);
}
#socialDmPanel .visner-dm-composer__mic-inside:active {
    transform: scale(0.94);
}

/* При вводе текста микрофон скрывается (состояние --typing задаётся из JS) */
#socialDmPanel .visner-dm-composer--typing .visner-dm-composer__mic-inside {
    display: none !important;
}

#socialDmPanel .visner-dm-composer__send-fab {
    flex-shrink: 0;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    padding: 0;
    background: linear-gradient(145deg, rgba(255, 180, 120, 0.35) 0%, rgba(255, 70, 160, 0.55) 45%, rgba(255, 120, 90, 0.65) 100%);
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.18) inset,
        0 6px 24px rgba(255, 80, 140, 0.45),
        0 0 40px rgba(255, 120, 80, 0.35);
    transition: transform 0.18s ease, box-shadow 0.22s ease, filter 0.2s ease;
}
#socialDmPanel .visner-dm-composer__send-fab > i {
    font-size: 17px;
    margin-left: 2px;
}
#socialDmPanel .visner-dm-composer--typing .visner-dm-composer__send-fab {
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.22) inset,
        0 8px 32px rgba(255, 100, 180, 0.55),
        0 0 52px rgba(255, 140, 100, 0.42),
        0 0 64px rgba(180, 100, 255, 0.35);
    filter: saturate(1.08);
}
#socialDmPanel .visner-dm-composer__send-fab:active:not(:disabled) {
    transform: scale(0.94);
}
#socialDmPanel .visner-dm-composer__send-fab:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    filter: grayscale(0.3);
}

#socialDmPanel .visner-dm-composer:not(.visner-dm-composer--recording) .visner-dm-composer__voice-strip {
    display: none !important;
}

#socialDmPanel .visner-dm-composer.visner-dm-composer--recording .visner-dm-composer__input-strip {
    display: none !important;
}

#socialDmPanel .visner-dm-composer__voice-strip {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    grid-template-rows: auto auto;
    gap: 10px 12px;
    align-items: center;
    width: 100%;
    padding-top: 4px;
}

#socialDmPanel .visner-dm-composer__voice-cancel {
    grid-column: 1;
    grid-row: 1;
    appearance: none;
    border: none;
    background: transparent;
    color: rgba(255, 140, 180, 0.95);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    padding: 8px 4px;
}
#socialDmPanel .visner-dm-composer__voice-cancel:active {
    opacity: 0.75;
}

#socialDmPanel .visner-dm-composer__wave {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 3px;
    height: 36px;
    padding: 0 8px;
}
#socialDmPanel .visner-dm-composer__wave span {
    width: 3px;
    border-radius: 2px;
    background: linear-gradient(180deg, #c9b6ff 0%, #ff6ec7 50%, #ffb347 100%);
    opacity: 0.85;
    animation: visnerDmWaveBar 0.9s ease-in-out infinite;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(1) {
    animation-delay: 0s;
    height: 10px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(2) {
    animation-delay: 0.07s;
    height: 18px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(3) {
    animation-delay: 0.14s;
    height: 26px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(4) {
    animation-delay: 0.21s;
    height: 14px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(5) {
    animation-delay: 0.28s;
    height: 22px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(6) {
    animation-delay: 0.35s;
    height: 12px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(7) {
    animation-delay: 0.42s;
    height: 24px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(8) {
    animation-delay: 0.49s;
    height: 16px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(9) {
    animation-delay: 0.56s;
    height: 20px;
}
#socialDmPanel .visner-dm-composer__wave span:nth-child(10) {
    animation-delay: 0.63s;
    height: 11px;
}

@keyframes visnerDmWaveBar {
    0%,
    100% {
        transform: scaleY(0.35);
        opacity: 0.55;
    }
    50% {
        transform: scaleY(1);
        opacity: 1;
    }
}

@media (prefers-reduced-motion: reduce) {
    #socialDmPanel .visner-dm-composer__wave span {
        animation: none;
        opacity: 0.75;
    }
}

#socialDmPanel .visner-dm-composer__voice-timer {
    grid-column: 3;
    grid-row: 1;
    font-variant-numeric: tabular-nums;
    font-size: 15px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.92);
    text-shadow: 0 0 18px rgba(180, 120, 255, 0.45);
}

#socialDmPanel .visner-dm-composer__voice-stop-wrap {
    grid-column: 4;
    grid-row: 1;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: radial-gradient(circle at 30% 25%, rgba(255, 200, 255, 0.35), transparent 55%),
        linear-gradient(145deg, rgba(120, 80, 255, 0.55) 0%, rgba(255, 60, 160, 0.65) 55%, rgba(255, 160, 90, 0.55) 100%);
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.2) inset,
        0 8px 28px rgba(255, 80, 160, 0.45),
        0 0 48px rgba(140, 80, 255, 0.45);
    transition: transform 0.15s ease;
}
#socialDmPanel .visner-dm-composer__voice-stop-wrap:active {
    transform: scale(0.94);
}

#socialDmPanel .visner-dm-composer__voice-stop-inner {
    width: 26px;
    height: 26px;
    border-radius: 8px;
    background: rgba(8, 10, 28, 0.88);
    border: 1px solid rgba(255, 255, 255, 0.25);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 11px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

#socialDmPanel .visner-dm-composer__voice-hint {
    grid-column: 1 / -1;
    grid-row: 2;
    margin: 0;
    text-align: center;
    font-size: 11px;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.42);
}


/* VISNER look detail modal: image + overlay description */
#lookImageModal.modal {
    align-items: stretch;
    justify-content: center;
    overflow: hidden;
}
#lookImageModal .look-image-modal-content {
    position: relative;
    width: min(100vw, 760px);
    height: 100vh;
    max-height: 100vh;
    margin: 0 auto;
    display: block;
    padding: 0;
    overflow: hidden;
    background: #08080d;
    border: none;
    border-radius: 0;
    box-shadow: none;
    color: #fff;
}
.look-detail-topbar {
    position: fixed;
    top: max(10px, env(safe-area-inset-top, 0px));
    left: 50%;
    transform: translateX(-50%);
    z-index: 40;
    width: min(calc(100vw - 24px), 736px);
    min-height: 54px;
    display: grid;
    grid-template-columns: 46px 1fr 46px;
    align-items: center;
    gap: 8px;
    pointer-events: none;
}
.look-detail-top-title {
    justify-self: center;
    color: rgba(255,255,255,.96);
    font-size: 15px;
    line-height: 1;
    letter-spacing: .22em;
    font-weight: 800;
    text-transform: uppercase;
    text-shadow: 0 2px 12px rgba(0,0,0,.42);
    pointer-events: none;
}
.look-detail-top-btn {
    pointer-events: auto;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.22);
    background: rgba(22,24,32,.58);
    color: #fff;
    display: inline-grid;
    place-items: center;
    cursor: pointer;
    box-shadow: 0 10px 26px rgba(0,0,0,.22);
    backdrop-filter: blur(16px) saturate(1.25);
    -webkit-backdrop-filter: blur(16px) saturate(1.25);
}
.look-detail-scroll {
    height: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}
.look-detail-scroll::-webkit-scrollbar { display: none; }
.look-detail-hero {
    position: relative;
    width: 100%;
    min-height: 62vh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: max(94px, calc(env(safe-area-inset-top, 0px) + 84px));
    background: radial-gradient(circle at 50% 20%, rgba(210,75,180,.26), transparent 58%), #08080d;
}
.look-detail-hero img#lookImageModalImg {
    width: min(88vw, 620px);
    max-height: 58vh;
    object-fit: contain;
    border-radius: 24px;
    background: rgba(255,255,255,.05);
    user-select: none;
    -webkit-user-drag: none;
    touch-action: pan-y;
    cursor: default;
    transform: none !important;
    transition: none;
    box-shadow: 0 26px 74px rgba(0,0,0,.36);
}
.look-detail-info {
    position: relative;
    z-index: 5;
    margin-top: -210px;
    padding: 138px max(18px, env(safe-area-inset-left, 0px)) max(28px, calc(env(safe-area-inset-bottom, 0px) + 18px)) max(18px, env(safe-area-inset-right, 0px));
    color: #fff;
    background: linear-gradient(to top, rgba(8,8,13,.98) 0%, rgba(8,8,13,.90) 46%, rgba(8,8,13,.48) 78%, rgba(8,8,13,0) 100%);
}
.look-detail-author-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
}
.look-detail-avatar { width: 44px; height: 44px; flex: 0 0 44px; }
.look-detail-avatar img, .look-detail-avatar .avatar, .look-detail-avatar > * {
    width: 44px !important;
    height: 44px !important;
}
.look-detail-author {
    font-size: 14px;
    line-height: 1.1;
    font-weight: 800;
    color: rgba(255,255,255,.96);
}
.look-detail-time {
    margin-top: 3px;
    font-size: 11px;
    line-height: 1.15;
    font-weight: 700;
    color: rgba(255,255,255,.68);
}
.look-detail-title {
    margin: 0 0 8px;
    color: #fff;
    font-size: clamp(20px, 5.4vw, 28px);
    line-height: .98;
    font-weight: 900;
    letter-spacing: -.04em;
}
.look-detail-description {
    margin: 0 0 14px;
    color: rgba(255,255,255,.84);
    font-size: 13px;
    line-height: 1.42;
    font-weight: 500;
    white-space: pre-wrap;
}
.look-detail-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.look-detail-action {
    min-height: 38px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.20);
    background: rgba(255,255,255,.10);
    color: rgba(255,255,255,.94);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 14px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    backdrop-filter: blur(14px) saturate(1.18);
    -webkit-backdrop-filter: blur(14px) saturate(1.18);
}
.look-detail-action.is-on {
    border-color: rgba(255,110,206,.62);
    background: linear-gradient(135deg, rgba(236,96,169,.72), rgba(152,95,235,.52));
    color: #fff;
}
.look-detail-save { padding-right: 16px; }
@media (min-width: 760px) {
    #lookImageModal .look-image-modal-content { border-radius: 28px; height: min(100vh, 920px); }
    .look-detail-topbar { position: fixed; top: max(14px, env(safe-area-inset-top, 0px)); width: min(calc(100vw - 28px), 732px); }
}

/* VISNER look detail final layout fix: compact text, fixed header, image-safe overlap */
#lookImageModal .look-image-modal-content {
    overflow: hidden !important;
}
#lookImageModal .look-detail-topbar {
    position: fixed !important;
    top: max(10px, env(safe-area-inset-top, 0px)) !important;
    z-index: 80 !important;
}
#lookImageModal .look-detail-scroll {
    position: absolute !important;
    inset: 0 !important;
    height: auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
}
#lookImageModal .look-detail-scroll::-webkit-scrollbar {
    display: none !important;
}
#lookImageModal .look-detail-hero {
    min-height: 55vh !important;
    padding-top: max(82px, calc(env(safe-area-inset-top, 0px) + 76px)) !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    padding-bottom: 92px !important;
    box-sizing: border-box !important;
    align-items: flex-start !important;
}
#lookImageModal .look-detail-hero img#lookImageModalImg {
    width: min(86vw, 560px) !important;
    max-width: 100% !important;
    max-height: 46vh !important;
    object-fit: contain !important;
    display: block !important;
    margin: 0 auto !important;
}
#lookImageModal .look-detail-info {
    position: relative !important;
    z-index: 8 !important;
    margin-top: -118px !important;
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 72px 18px max(34px, calc(env(safe-area-inset-bottom, 0px) + 22px)) 18px !important;
    overflow: visible !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
}
#lookImageModal .look-detail-author-row {
    margin-bottom: 12px !important;
}
#lookImageModal .look-detail-avatar,
#lookImageModal .look-detail-avatar img,
#lookImageModal .look-detail-avatar .avatar,
#lookImageModal .look-detail-avatar > * {
    width: 36px !important;
    height: 36px !important;
    flex-basis: 36px !important;
}
#lookImageModal .look-detail-author {
    font-size: 13px !important;
    line-height: 1.15 !important;
}
#lookImageModal .look-detail-time {
    font-size: 10.5px !important;
    line-height: 1.15 !important;
}
#lookImageModal .look-detail-title {
    max-width: 100% !important;
    margin: 0 0 8px !important;
    font-size: clamp(17px, 4.2vw, 22px) !important;
    line-height: 1.16 !important;
    letter-spacing: -0.015em !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
}
#lookImageModal .look-detail-description {
    max-width: 100% !important;
    margin: 0 0 14px !important;
    font-size: clamp(12px, 3.15vw, 14px) !important;
    line-height: 1.48 !important;
    font-weight: 500 !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
}
#lookImageModal .look-detail-actions {
    position: relative !important;
    z-index: 10 !important;
    gap: 8px !important;
    padding-bottom: 4px !important;
}
#lookImageModal .look-detail-action {
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
}
@media (min-width: 760px) {
    #lookImageModal .look-detail-topbar {
        width: min(calc(100vw - 28px), 732px) !important;
    }
    #lookImageModal .look-detail-info {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }
}

/* VISNER look detail v3: scroll-under-photo + author alignment fix */
#lookImageModal .look-image-modal-content {
    overflow: hidden !important;
}
#lookImageModal .look-detail-topbar {
    position: fixed !important;
    top: max(10px, env(safe-area-inset-top, 0px)) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 120 !important;
    width: min(calc(100vw - 24px), 736px) !important;
}
#lookImageModal .look-detail-scroll {
    position: absolute !important;
    inset: 0 !important;
    height: auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
}
#lookImageModal .look-detail-scroll::-webkit-scrollbar { display: none !important; }
#lookImageModal .look-detail-hero {
    position: sticky !important;
    top: 0 !important;
    z-index: 40 !important;
    min-height: 52vh !important;
    height: 52vh !important;
    padding-top: max(78px, calc(env(safe-area-inset-top, 0px) + 72px)) !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    padding-bottom: 18px !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-hero img#lookImageModalImg {
    width: min(86vw, 560px) !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: calc(52vh - max(92px, calc(env(safe-area-inset-top, 0px) + 86px))) !important;
    object-fit: contain !important;
    display: block !important;
    margin: 0 auto !important;
    border-radius: 22px !important;
}
#lookImageModal .look-detail-info {
    position: relative !important;
    z-index: 20 !important;
    margin-top: -72px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: 76px 18px max(38px, calc(env(safe-area-inset-bottom, 0px) + 26px)) 18px !important;
    overflow: visible !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
    min-height: 58vh !important;
}
#lookImageModal .look-detail-author-row {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
    margin-bottom: 12px !important;
}
#lookImageModal .look-detail-avatar {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    flex: 0 0 38px !important;
    border-radius: 50% !important;
    overflow: hidden !important;
    display: block !important;
}
#lookImageModal .look-detail-avatar img,
#lookImageModal .look-detail-avatar .avatar,
#lookImageModal .look-detail-avatar > * {
    width: 38px !important;
    height: 38px !important;
    max-width: 38px !important;
    max-height: 38px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    overflow: hidden !important;
    display: block !important;
    flex: 0 0 38px !important;
}
#lookImageModal .look-detail-author-row > div:not(.look-detail-avatar) {
    min-width: 0 !important;
    flex: 1 1 auto !important;
    padding-left: 0 !important;
}
#lookImageModal .look-detail-author,
#lookImageModal .look-detail-time {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}
#lookImageModal .look-detail-author {
    font-size: 13px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
}
#lookImageModal .look-detail-time {
    margin-top: 3px !important;
    font-size: 10.5px !important;
    line-height: 1.15 !important;
}
#lookImageModal .look-detail-title {
    max-width: 100% !important;
    margin: 0 0 8px !important;
    font-size: clamp(17px, 4.1vw, 22px) !important;
    line-height: 1.14 !important;
    letter-spacing: -0.012em !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
}
#lookImageModal .look-detail-description {
    max-width: 100% !important;
    margin: 0 0 14px !important;
    font-size: clamp(12px, 3.05vw, 14px) !important;
    line-height: 1.46 !important;
    font-weight: 500 !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
}
#lookImageModal .look-detail-actions {
    position: relative !important;
    z-index: 25 !important;
    gap: 8px !important;
    padding-bottom: 4px !important;
}
#lookImageModal .look-detail-action {
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-info {
    color: #161616 !important;
    background: linear-gradient(to top, rgba(255,255,255,.98) 0%, rgba(255,255,255,.93) 48%, rgba(255,255,255,.54) 78%, rgba(255,255,255,0) 100%) !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-title,
html[data-theme='minimal'] #lookImageModal .look-detail-author {
    color: #111 !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-description {
    color: rgba(20,20,20,.78) !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-time {
    color: rgba(20,20,20,.56) !important;
}
@media (min-width: 760px) {
    #lookImageModal .look-detail-hero {
        height: min(52vh, 470px) !important;
        min-height: min(52vh, 470px) !important;
    }
    #lookImageModal .look-detail-info {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }
}

/* VISNER look detail: edge-to-edge photo + visible working top buttons */
#lookImageModal .look-image-modal-content {
    overflow: hidden !important;
}
#lookImageModal .look-detail-topbar {
    position: fixed !important;
    top: max(10px, env(safe-area-inset-top, 0px)) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: min(calc(100vw - 24px), 736px) !important;
    height: 46px !important;
    padding: 0 10px !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    z-index: 999 !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-top-btn {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    background: rgba(18,18,24,.72) !important;
    color: #fff !important;
    box-shadow: 0 10px 28px rgba(0,0,0,.28) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    pointer-events: auto !important;
    cursor: pointer !important;
}
#lookImageModal .look-detail-top-btn i {
    font-size: 15px !important;
    line-height: 1 !important;
    color: inherit !important;
}
#lookImageModal .look-detail-top-title {
    flex: 1 1 auto !important;
    text-align: center !important;
    padding: 0 10px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .28em !important;
    color: rgba(255,255,255,.92) !important;
    text-shadow: 0 4px 18px rgba(0,0,0,.45) !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-scroll {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
}
#lookImageModal .look-detail-hero {
    position: sticky !important;
    top: 0 !important;
    z-index: 40 !important;
    width: 100% !important;
    min-height: 52vh !important;
    height: 52vh !important;
    padding: max(66px, calc(env(safe-area-inset-top, 0px) + 60px)) 0 0 0 !important;
    box-sizing: border-box !important;
    display: block !important;
    overflow: hidden !important;
    border-radius: 0 !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-hero img#lookImageModalImg {
    width: 100% !important;
    max-width: none !important;
    height: 100% !important;
    max-height: none !important;
    min-height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
    display: block !important;
    margin: 0 !important;
    border-radius: 0 !important;
    transform-origin: center center !important;
}
#lookImageModal .look-detail-info {
    margin-top: -92px !important;
    padding-top: 92px !important;
    z-index: 60 !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-top-btn {
    background: rgba(255,255,255,.72) !important;
    border-color: rgba(40,32,24,.13) !important;
    color: rgba(36,31,26,.88) !important;
    box-shadow: 0 10px 28px rgba(64,48,35,.16) !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-top-title {
    color: rgba(36,31,26,.86) !important;
    text-shadow: 0 3px 18px rgba(255,255,255,.74) !important;
}


/* VISNER look detail hotfix: fixed back/share buttons + restore accepted photo scroll behavior */
#lookImageModal .look-image-modal-content {
    overflow: hidden !important;
}
#lookImageModal .look-detail-topbar {
    position: fixed !important;
    top: max(10px, env(safe-area-inset-top, 0px)) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: min(calc(100vw - 24px), 736px) !important;
    height: 46px !important;
    padding: 0 10px !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    z-index: 9999 !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-top-btn {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    background: rgba(18,18,24,.72) !important;
    color: #fff !important;
    box-shadow: 0 10px 28px rgba(0,0,0,.28) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    pointer-events: auto !important;
    cursor: pointer !important;
}
#lookImageModal .look-detail-top-btn i {
    font-size: 15px !important;
    line-height: 1 !important;
    color: inherit !important;
}
#lookImageModal .look-detail-top-title {
    flex: 1 1 auto !important;
    text-align: center !important;
    padding: 0 10px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .28em !important;
    color: rgba(255,255,255,.92) !important;
    text-shadow: 0 4px 18px rgba(0,0,0,.45) !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-scroll {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    overscroll-behavior: contain !important;
}
#lookImageModal .look-detail-scroll::-webkit-scrollbar { display: none !important; }
#lookImageModal .look-detail-hero {
    position: sticky !important;
    top: 0 !important;
    z-index: 80 !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    padding: max(64px, calc(env(safe-area-inset-top, 0px) + 58px)) 0 0 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: block !important;
    overflow: hidden !important;
    border-radius: 0 !important;
    background: rgba(6,6,10,.94) !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-hero img#lookImageModalImg {
    width: 100% !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    object-fit: contain !important;
    object-position: center top !important;
    display: block !important;
    margin: 0 !important;
    border-radius: 0 !important;
}
#lookImageModal .look-detail-info {
    position: relative !important;
    z-index: 20 !important;
    margin-top: 0 !important;
    padding: 18px 18px max(38px, calc(env(safe-area-inset-bottom, 0px) + 26px)) 18px !important;
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 70vh !important;
    overflow: visible !important;
    background: linear-gradient(to bottom, rgba(12,14,20,.96) 0%, rgba(12,14,20,.98) 38%, rgba(12,14,20,1) 100%) !important;
}
#lookImageModal .look-detail-author-row {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
    margin: 0 0 12px !important;
}
#lookImageModal .look-detail-avatar {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    flex: 0 0 38px !important;
    border-radius: 50% !important;
    overflow: hidden !important;
}
#lookImageModal .look-detail-avatar img,
#lookImageModal .look-detail-avatar .avatar,
#lookImageModal .look-detail-avatar > * {
    width: 38px !important;
    height: 38px !important;
    max-width: 38px !important;
    max-height: 38px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    display: block !important;
}
#lookImageModal .look-detail-author-meta {
    min-width: 0 !important;
    flex: 1 1 auto !important;
}
#lookImageModal .look-detail-author,
#lookImageModal .look-detail-time {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    max-width: 100% !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-hero {
    background: rgba(250,247,241,.96) !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-info {
    background: linear-gradient(to bottom, rgba(255,255,255,.97) 0%, rgba(255,255,255,.99) 45%, #fff 100%) !important;
    color: #161616 !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-top-btn {
    background: rgba(255,255,255,.72) !important;
    border-color: rgba(40,32,24,.13) !important;
    color: rgba(36,31,26,.88) !important;
    box-shadow: 0 10px 28px rgba(64,48,35,.16) !important;
}
html[data-theme='minimal'] #lookImageModal .look-detail-top-title {
    color: rgba(36,31,26,.86) !important;
    text-shadow: 0 3px 18px rgba(255,255,255,.74) !important;
}

/* VISNER: compact opened look + back/share buttons (original theme) */
#lookImageModal .look-image-modal-content {
    overflow: hidden !important;
}
#lookImageModal .look-detail-topbar {
    position: fixed !important;
    top: max(12px, env(safe-area-inset-top, 0px)) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: min(calc(100vw - 24px), 720px) !important;
    height: 52px !important;
    padding: 0 12px !important;
    display: grid !important;
    grid-template-columns: 46px 1fr 46px !important;
    align-items: center !important;
    gap: 10px !important;
    z-index: 2147483647 !important;
    pointer-events: none !important;
    box-sizing: border-box !important;
}
#lookImageModal .look-detail-top-btn {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    border: 1px solid rgba(255,255,255,.22) !important;
    background: rgba(7,8,13,.72) !important;
    color: #fff !important;
    box-shadow: 0 12px 30px rgba(0,0,0,.42) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    pointer-events: auto !important;
    opacity: 1 !important;
    visibility: visible !important;
}
#lookImageModal .look-detail-top-btn i {
    color: inherit !important;
    font-size: 17px !important;
    line-height: 1 !important;
}
#lookImageModal .look-detail-top-title {
    display: block !important;
    text-align: center !important;
    color: rgba(255,255,255,.95) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: .34em !important;
    text-shadow: 0 4px 18px rgba(0,0,0,.65) !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-scroll {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    overscroll-behavior: contain !important;
}
#lookImageModal .look-detail-scroll::-webkit-scrollbar { display: none !important; }
#lookImageModal .look-detail-hero {
    position: relative !important;
    top: auto !important;
    z-index: 1 !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: max(66px, calc(env(safe-area-inset-top, 0px) + 60px)) 0 0 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    background: rgba(6,7,12,.96) !important;
    border-radius: 0 !important;
    pointer-events: auto !important;
}
#lookImageModal .look-detail-hero img#lookImageModalImg {
    width: 100% !important;
    height: auto !important;
    max-height: 38vh !important;
    min-height: 0 !important;
    object-fit: contain !important;
    object-position: center center !important;
    display: block !important;
    margin: 0 auto !important;
    border-radius: 0 !important;
}
#lookImageModal .look-detail-info {
    position: relative !important;
    z-index: 2 !important;
    margin-top: 0 !important;
    padding: 18px 18px max(44px, calc(env(safe-area-inset-bottom, 0px) + 30px)) 18px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}
#lookImageModal .look-detail-title {
    margin-top: 14px !important;
    font-size: clamp(22px, 6.2vw, 30px) !important;
    line-height: 1.08 !important;
}
#lookImageModal .look-detail-description {
    margin-top: 12px !important;
    font-size: 15px !important;
    line-height: 1.45 !important;
}

/* VISNER: Instagram-like opened look animation, buttons tap feedback, swipe-back support */
#lookImageModal.open .look-image-modal-content {
    animation: visnerLookOpen .22s cubic-bezier(.2,.72,.22,1) both !important;
    will-change: transform, opacity !important;
}
#lookImageModal.is-closing .look-image-modal-content {
    animation: visnerLookClose .18s ease both !important;
}
#lookImageModal .look-detail-top-btn {
    transition: transform .16s ease, background .16s ease, opacity .16s ease !important;
    -webkit-tap-highlight-color: transparent !important;
}
#lookImageModal .look-detail-top-btn:active {
    transform: scale(.92) !important;
    opacity: .86 !important;
}
#lookImageModal .look-detail-scroll {
    touch-action: pan-y pinch-zoom !important;
}
@keyframes visnerLookOpen {
    from { opacity: 0; transform: translateY(14px) scale(.985); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes visnerLookClose {
    from { opacity: 1; transform: translateY(0) scale(1); }
    to { opacity: 0; transform: translateY(18px) scale(.985); }
}

/* VISNER FINAL: Instagram-style opened look, compact photo, normal text */
#lookImageModal.modal.open {
    display: flex !important;
    align-items: stretch !important;
    justify-content: center !important;
    padding: 0 !important;
    background: rgba(0,0,0,.94) !important;
}
#lookImageModal .look-image-modal-content {
    position: relative !important;
    width: min(100vw, 430px) !important;
    max-width: 430px !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    margin: 0 auto !important;
    padding: 0 !important;
    overflow: hidden !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #05070b !important;
    color: #fff !important;
    box-shadow: none !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
}
#lookImageModal .look-detail-topbar {
    position: absolute !important;
    top: max(10px, env(safe-area-inset-top, 0px)) !important;
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    width: 100% !important;
    height: 48px !important;
    padding: 0 12px !important;
    display: grid !important;
    grid-template-columns: 40px 1fr 40px !important;
    align-items: center !important;
    gap: 8px !important;
    z-index: 99999 !important;
    pointer-events: none !important;
    box-sizing: border-box !important;
}
#lookImageModal .look-detail-top-btn {
    pointer-events: auto !important;
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    border-radius: 50% !important;
    border: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    background: rgba(0,0,0,.48) !important;
    color: #fff !important;
    box-shadow: 0 8px 22px rgba(0,0,0,.35) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    opacity: 1 !important;
    visibility: visible !important;
}
#lookImageModal .look-detail-top-btn i {
    font-size: 16px !important;
    line-height: 1 !important;
    color: currentColor !important;
}
#lookImageModal .look-detail-top-title {
    display: block !important;
    text-align: center !important;
    color: rgba(255,255,255,.96) !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    letter-spacing: .28em !important;
    text-transform: uppercase !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.65) !important;
    pointer-events: none !important;
}
#lookImageModal .look-detail-scroll {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    overscroll-behavior: contain !important;
    background: #05070b !important;
}
#lookImageModal .look-detail-scroll::-webkit-scrollbar { display: none !important; }
#lookImageModal .look-detail-hero {
    position: relative !important;
    top: auto !important;
    z-index: 1 !important;
    width: 100% !important;
    height: min(48dvh, 430px) !important;
    min-height: 310px !important;
    max-height: 430px !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    background: #090a0e !important;
    border-radius: 0 !important;
    pointer-events: auto !important;
}
#lookImageModal .look-detail-hero img#lookImageModalImg {
    width: 100% !important;
    height: 100% !important;
    min-height: 100% !important;
    max-height: none !important;
    object-fit: cover !important;
    object-position: center center !important;
    display: block !important;
    margin: 0 !important;
    border-radius: 0 !important;
    background: #090a0e !important;
}
#lookImageModal .look-detail-info {
    position: relative !important;
    z-index: 2 !important;
    width: 100% !important;
    min-height: auto !important;
    margin: 0 !important;
    padding: 14px 14px max(36px, calc(env(safe-area-inset-bottom, 0px) + 24px)) !important;
    box-sizing: border-box !important;
    overflow: visible !important;
    background: #05070b !important;
    color: #fff !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
}
#lookImageModal .look-detail-author-row {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 0 10px !important;
    min-width: 0 !important;
}
#lookImageModal .look-detail-avatar,
#lookImageModal .look-detail-avatar img,
#lookImageModal .look-detail-avatar .avatar,
#lookImageModal .look-detail-avatar > * {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    max-width: 36px !important;
    max-height: 36px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}
#lookImageModal .look-detail-author {
    font-size: 14px !important;
    line-height: 1.2 !important;
    font-weight: 700 !important;
    color: #fff !important;
    letter-spacing: 0 !important;
}
#lookImageModal .look-detail-time {
    margin-top: 2px !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    font-weight: 500 !important;
    color: rgba(255,255,255,.62) !important;
}
#lookImageModal .look-detail-title {
    margin: 8px 0 6px !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
    font-size: 16px !important;
    line-height: 1.35 !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    color: #fff !important;
    text-transform: none !important;
}
#lookImageModal .look-detail-description {
    margin: 0 !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
    font-size: 14px !important;
    line-height: 1.42 !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    color: rgba(255,255,255,.86) !important;
    white-space: pre-line !important;
}
#lookImageModal .look-detail-actions {
    display: flex !important;
    align-items: center !important;
    gap: 18px !important;
    margin: 10px 0 8px !important;
}
#lookImageModal .look-detail-action {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}
@media (max-height: 720px) {
    #lookImageModal .look-detail-hero {
        height: 42dvh !important;
        min-height: 260px !important;
    }
}

/* VISNER final look detail polish: Instagram-like compact layout */
#lookImageModal .look-image-modal-content {
    width: min(100vw, 430px) !important;
    max-width: 430px !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    margin: 0 auto !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: #0b0f14 !important;
}
#lookImageModal .look-detail-topbar {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    width: 100% !important;
    height: max(58px, calc(env(safe-area-inset-top, 0px) + 52px)) !important;
    padding: env(safe-area-inset-top, 0px) 12px 0 !important;
    display: grid !important;
    grid-template-columns: 44px 1fr 44px !important;
    align-items: center !important;
    z-index: 1000 !important;
    background: rgba(8, 11, 15, .96) !important;
    border-bottom: 1px solid rgba(255,255,255,.06) !important;
    box-sizing: border-box !important;
    pointer-events: auto !important;
}
#lookImageModal .look-detail-top-title {
    color: rgba(255,255,255,.92) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: .32em !important;
    text-align: center !important;
    text-shadow: none !important;
}
#lookImageModal .look-detail-top-btn {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.08) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    color: #fff !important;
    box-shadow: none !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
}
#lookImageModal .look-detail-scroll {
    position: absolute !important;
    inset: 0 !important;
    padding-top: max(58px, calc(env(safe-area-inset-top, 0px) + 52px)) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
    background: #0b0f14 !important;
}
#lookImageModal .look-detail-hero {
    position: relative !important;
    top: auto !important;
    z-index: 1 !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #06080b !important;
    display: block !important;
    overflow: hidden !important;
    pointer-events: auto !important;
}
#lookImageModal .look-detail-hero img#lookImageModalImg {
    width: 100% !important;
    height: min(56vh, 470px) !important;
    max-height: min(56vh, 470px) !important;
    object-fit: cover !important;
    object-position: center center !important;
    display: block !important;
    margin: 0 !important;
    border-radius: 0 !important;
}
#lookImageModal .look-detail-info {
    display: flex !important;
    flex-direction: column !important;
    position: relative !important;
    z-index: 2 !important;
    margin-top: 0 !important;
    min-height: 0 !important;
    padding: 10px 14px max(28px, calc(env(safe-area-inset-bottom, 0px) + 22px)) !important;
    background: #0b0f14 !important;
    color: #fff !important;
    box-sizing: border-box !important;
}
#lookImageModal .look-detail-actions {
    order: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    margin: 0 0 10px !important;
    padding: 0 !important;
}
#lookImageModal .look-detail-action {
    min-width: 0 !important;
    min-height: 32px !important;
    height: 32px !important;
    padding: 0 2px !important;
    border: 0 !important;
    background: transparent !important;
    color: rgba(255,255,255,.92) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    box-shadow: none !important;
}
#lookImageModal .look-detail-action i {
    font-size: 23px !important;
    margin-right: 6px !important;
}
#lookImageModal .look-detail-save { margin-left: auto !important; }
#lookImageModal .look-detail-save span { display: none !important; }
#lookImageModal .look-detail-author-row {
    order: 2 !important;
    margin: 0 0 7px !important;
    gap: 9px !important;
}
#lookImageModal .look-detail-avatar,
#lookImageModal .look-detail-avatar img,
#lookImageModal .look-detail-avatar .avatar,
#lookImageModal .look-detail-avatar > * {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    max-width: 34px !important;
    max-height: 34px !important;
}
#lookImageModal .look-detail-author {
    font-size: 13.5px !important;
    line-height: 1.15 !important;
    color: #fff !important;
    font-weight: 800 !important;
}
#lookImageModal .look-detail-time {
    font-size: 11px !important;
    color: rgba(255,255,255,.55) !important;
    margin-top: 2px !important;
}
#lookImageModal .look-detail-title {
    order: 3 !important;
    margin: 4px 0 6px !important;
    color: #fff !important;
    font-size: 14.5px !important;
    line-height: 1.34 !important;
    letter-spacing: 0 !important;
    font-weight: 800 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}
#lookImageModal .look-detail-description {
    order: 4 !important;
    margin: 0 !important;
    color: rgba(255,255,255,.88) !important;
    font-size: 14px !important;
    line-height: 1.42 !important;
    font-weight: 500 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}
#lookImageModal.look-detail-expanded .look-detail-description,
#lookImageModal .look-detail-description.is-expanded {
    display: block !important;
    -webkit-line-clamp: unset !important;
    overflow: visible !important;
}
#lookImageModal .look-detail-readmore {
    order: 5 !important;
    align-self: flex-start !important;
    margin: 4px 0 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: rgba(255,255,255,.52) !important;
    font: inherit !important;
    font-size: 14px !important;
    line-height: 1.35 !important;
    cursor: pointer !important;
}
#lookImageModal .look-detail-tags {
    order: 6 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 7px !important;
    margin: 12px 0 0 !important;
    color: #8ab4ff !important;
    font-size: 13px !important;
    line-height: 1.25 !important;
    font-weight: 600 !important;
}
#lookImageModal .look-detail-tags span { white-space: nowrap !important; }
@media (max-width: 420px) {
    #lookImageModal .look-detail-hero img#lookImageModalImg {
        height: 48vh !important;
        max-height: 48vh !important;
    }
}

/* VISNER ORIGINAL FINAL HOTFIX: opened look actions seamless + spacing parity */
html[data-theme="original"] #lookImageModal .look-detail-actions,
html:not([data-theme="minimal"]) #lookImageModal .look-detail-actions {
    order: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 18px !important;
    margin: 0 !important;
    padding: 10px 18px 6px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: #0b0f14 !important;
    background-image: none !important;
    border: 0 !important;
    border-top: 0 !important;
    border-bottom: 0 !important;
    box-shadow: none !important;
    outline: 0 !important;
}
html[data-theme="original"] #lookImageModal .look-detail-info,
html:not([data-theme="minimal"]) #lookImageModal .look-detail-info {
    background: #0b0f14 !important;
    border: 0 !important;
    border-top: 0 !important;
    box-shadow: none !important;
    margin: 0 !important;
    padding-top: 10px !important;
}
html[data-theme="original"] #lookImageModal .look-detail-action,
html:not([data-theme="minimal"]) #lookImageModal .look-detail-action {
    min-width: 0 !important;
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 4px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: transparent !important;
    box-shadow: none !important;
    color: rgba(255,255,255,.94) !important;
    font: 700 15px/1 -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif !important;
}
html[data-theme="original"] #lookImageModal .look-detail-action i,
html:not([data-theme="minimal"]) #lookImageModal .look-detail-action i {
    font-size: 24px !important;
    margin-right: 7px !important;
}
html[data-theme="original"] #lookImageModal .look-detail-save,
html:not([data-theme="minimal"]) #lookImageModal .look-detail-save {
    margin-left: auto !important;
    margin-right: 0 !important;
}
html[data-theme="original"] #lookImageModal .look-detail-save span,
html:not([data-theme="minimal"]) #lookImageModal .look-detail-save span {
    display: none !important;
}
html[data-theme="original"] #lookImageModal .look-detail-action.is-on,
html[data-theme="original"] #lookImageModal .look-detail-action.is-on i,
html:not([data-theme="minimal"]) #lookImageModal .look-detail-action.is-on,
html:not([data-theme="minimal"]) #lookImageModal .look-detail-action.is-on i {
    color: #ff5bd7 !important;
    text-shadow: 0 0 14px rgba(255, 91, 215, .42) !important;
}


/* VISNER account media + carousel + canceled order swipe */
.acc-cabinet-media { position: relative; touch-action: manipulation; }
.acc-cabinet-media-count {
    position: absolute; right: 6px; top: 6px; display: inline-flex; align-items: center; gap: 4px;
    padding: 3px 7px; border-radius: 999px; font-size: 11px; font-weight: 800;
    color: #fff; background: rgba(0,0,0,.55); backdrop-filter: blur(8px);
}
.club-look-preview-grid { display:none; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 6px; width:100%; margin-top:10px; }
.club-look-preview-grid.show { display:grid; }
.club-look-preview-item { position:relative; aspect-ratio:1; border-radius:10px; overflow:hidden; border:1px solid rgba(255,255,255,.14); }
.club-look-preview-item img { width:100%; height:100%; object-fit:cover; display:block; }
.club-look-preview-item span { position:absolute; right:5px; top:5px; min-width:18px; height:18px; border-radius:99px; display:grid; place-items:center; font-size:10px; font-weight:800; color:#fff; background:rgba(0,0,0,.55); }
.club-look-carousel { position:relative; width:100%; height:100%; overflow:hidden; background:#050508; }
.club-look-carousel-track { width:100%; height:100%; display:flex; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.club-look-carousel-track::-webkit-scrollbar { display:none; }
.club-look-carousel-track img { flex:0 0 100%; width:100%; height:100%; object-fit:cover; scroll-snap-align:center; display:block; }
.club-look-carousel-badge, .look-detail-carousel-badge { position:absolute; right:10px; top:10px; z-index:2; display:inline-flex; align-items:center; gap:5px; padding:5px 8px; border-radius:999px; color:#fff; background:rgba(0,0,0,.55); backdrop-filter: blur(8px); font-size:12px; font-weight:800; }
.club-look-carousel-dots, .look-detail-carousel-dots { position:absolute; left:0; right:0; bottom:10px; z-index:2; display:flex; justify-content:center; gap:5px; pointer-events:auto; }
.club-look-carousel-dots span, .look-detail-carousel-dots button { width:6px; height:6px; border-radius:50%; border:0; padding:0; background:rgba(255,255,255,.45); }
.club-look-carousel-dots .is-active, .look-detail-carousel-dots button.is-active { background:#ff4fd8; box-shadow:0 0 10px rgba(255,79,216,.7); }
.look-detail-hero { position:relative; }
.look-detail-carousel-dots button { cursor:pointer; }
.acc-order-card.is-canceled { position:relative; transition: transform .18s ease, box-shadow .18s ease; touch-action: pan-y; }
.acc-order-card.is-canceled.swipe-ready { transform: translateX(-12px); box-shadow: 0 0 0 1px rgba(255,80,80,.35), 0 12px 34px rgba(255,80,80,.12); }
.acc-order-swipe-hint { margin-top:10px; font-size:12px; color:rgba(255,150,150,.85); text-align:center; }

/* VISNER carousel swipe fix: feed + detail */
.club-look-carousel,
.look-detail-hero.has-carousel {
  touch-action: pan-y;
  -webkit-user-select: none;
  user-select: none;
}
.club-look-carousel-track {
  overscroll-behavior-x: contain;
  scroll-behavior: smooth;
}
.club-look-carousel-track img,
.look-detail-hero.has-carousel img#lookImageModalImg {
  -webkit-user-drag: none;
  user-drag: none;
}


/* VISNER smoothness + collections + offline hotfix */
html { scroll-behavior: smooth; }
body, .page, .account-panel, .modal-content, .card, .acc-look-card, .club-look-grid-media, .look-image-modal-content { -webkit-font-smoothing: antialiased; }
.card, .product-page, .account-panel, .modal-content, .acc-look-card, .acc-order-card, .club-look-carousel, .look-detail-hero, .look-detail-actions, .navbar, button {
  transition: transform .22s cubic-bezier(.2,.8,.2,1), opacity .22s ease, background-color .22s ease, border-color .22s ease, box-shadow .22s ease, color .22s ease;
}
.bottom-nav {
  transition: opacity .22s ease, background-color .22s ease, border-color .22s ease, box-shadow .22s ease, color .22s ease;
}
.card-gallery-view, .card-media, .product-gallery, #ppGalleryTouch, #ppHeroStack, .club-look-carousel, .look-detail-hero { touch-action: pan-y pinch-zoom; overscroll-behavior: contain; }
.club-look-carousel-track { display:flex; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; -webkit-overflow-scrolling:touch; scrollbar-width:none; overscroll-behavior-x:contain; }
.club-look-carousel-track::-webkit-scrollbar { display:none; }
.club-look-carousel-track img { flex:0 0 100%; width:100%; scroll-snap-align:center; transform:translateZ(0); backface-visibility:hidden; }
#ppHeroStack, #ppHeroStack img, #lookImageModalImg, .card-gallery-main-img { transform: translateZ(0); backface-visibility:hidden; will-change: transform; }
.visner-offline-catalog { grid-column:1/-1; min-height:260px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:10px; padding:28px 20px; border:1px dashed rgba(255,255,255,.18); border-radius:24px; background:rgba(18,20,28,.55); color:rgba(255,255,255,.88); }
.visner-offline-catalog .visner-offline-face { font-size:42px; line-height:1; filter:drop-shadow(0 10px 24px rgba(255,74,194,.22)); }
.visner-offline-catalog strong { font-size:20px; }
.visner-offline-catalog p { max-width:320px; margin:0; font-size:14px; line-height:1.35; color:rgba(255,255,255,.62); }
.account-tab[data-acc="collections"] i, .acc-cabinet-stat .fa-bookmark, .look-detail-save.is-saved, .club-look-grid-foot-btn--bookmark.is-saved { color:#ff4ad2; }
.acc-cabinet-stats { grid-template-columns: repeat(4, minmax(0,1fr)); }
.acc-collections-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:12px; padding:8px 0 18px; }
.acc-section-title { display:flex; align-items:center; gap:10px; font-weight:900; font-size:18px; margin:8px 0 14px; color:#ff4ad2; text-transform:uppercase; letter-spacing:.04em; }
.acc-collection-card { appearance:none; border:1px solid rgba(255,74,210,.22); background:rgba(16,20,30,.68); border-radius:18px; padding:8px; color:inherit; text-align:left; overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,.18); }
.acc-collection-card:active { transform:scale(.98); }
.acc-collection-media { display:block; position:relative; aspect-ratio:1/1; border-radius:14px; overflow:hidden; background:rgba(255,255,255,.06); margin-bottom:8px; }
.acc-collection-media img { width:100%; height:100%; object-fit:cover; display:block; }
.acc-collection-media em { position:absolute; right:8px; top:8px; display:inline-flex; align-items:center; gap:4px; padding:4px 7px; border-radius:999px; background:rgba(0,0,0,.58); color:#fff; font-style:normal; font-size:11px; }
.acc-collection-card strong { display:block; font-size:13px; line-height:1.25; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.acc-collection-card small { display:block; margin-top:3px; opacity:.62; font-size:11px; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior:auto; } *, *::before, *::after { transition:none !important; animation:none !important; } }

/* VISNER hotfix: compact one-row account media + reliable collection thumbs */
.acc-cabinet-block .acc-cabinet-media-grid {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 7px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  padding: 2px 2px 8px !important;
  margin-bottom: 0 !important;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}
.acc-cabinet-block .acc-cabinet-media {
  width: 74px !important;
  height: 74px !important;
  min-width: 74px !important;
  flex: 0 0 74px !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 12px !important;
  scroll-snap-align: start;
}
.acc-cabinet-block .acc-cabinet-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.acc-cabinet-block .acc-cabinet-media.acc-cabinet-media--add {
  font-size: 22px !important;
}
.acc-cabinet-block .acc-cabinet-media-empty {
  min-width: 180px;
  align-self: center;
}
.acc-collection-media img {
  opacity: 1 !important;
  visibility: visible !important;
  background: rgba(255,255,255,.06);
}
@media (max-width: 430px) {
  .acc-cabinet-block .acc-cabinet-media {
    width: 70px !important;
    height: 70px !important;
    min-width: 70px !important;
    flex-basis: 70px !important;
  }
}

/* ——— Профиль друга (модалка, макет 1:1) ——— */
.modal-content.modal-content--visner-member {
  max-width: min(400px, 100%);
  max-height: 88vh;
  overflow-x: hidden;
  overflow-y: auto;
  text-align: left;
  padding: 22px 20px 26px;
  background: #1c1c1e !important;
  background-image: none !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 18px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.45);
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.modal-content.modal-content--visner-member .close-btn {
  color: #fff !important;
  opacity: 0.92;
  font-size: 28px;
  line-height: 1;
  padding: 8px 12px;
}

.visner-member-profile {
  color: #fff;
  font-size: 14px;
  line-height: 1.45;
  padding-top: 8px;
}

.visner-member-profile__guest-note,
.visner-member-profile__privacy-note {
  margin: 0 0 14px;
  font-size: 13px;
  color: #a1a1a1;
  line-height: 1.35;
}

.visner-member-profile__top {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.visner-member-profile__avatar-wrap {
  position: relative;
  flex-shrink: 0;
}

.visner-member-profile__avatar-wrap .social-member-avatar,
.visner-member-profile__avatar-wrap img.social-member-avatar,
.visner-member-profile__avatar-wrap .social-member-avatar--fallback {
  display: block;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.08);
}

.visner-member-profile__online-dot {
  position: absolute;
  right: 4px;
  bottom: 4px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #2ecc71;
  border: 3px solid #1c1c1e;
  box-sizing: border-box;
}

.visner-member-profile__intro {
  flex: 1;
  min-width: 0;
}

.visner-member-profile__username {
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.01em;
  margin: 0 0 8px;
}

.visner-member-profile__status-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 12px 5px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: #2ecc71;
  background: rgba(46, 204, 113, 0.18);
  margin-bottom: 10px;
}

.visner-member-profile__status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #2ecc71;
  flex-shrink: 0;
}

.visner-member-profile__fullname {
  font-size: 15px;
  font-weight: 500;
  color: #fff;
  margin-bottom: 6px;
}

.visner-member-profile__bio {
  margin: 0;
  font-size: 13px;
  color: #a1a1a1;
  line-height: 1.4;
}

.visner-member-profile__rule {
  border: none;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  margin: 16px 0;
}

.visner-member-profile__contacts {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.visner-member-profile__contact-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: #fff;
  min-width: 0;
}

.visner-member-profile__contact-icon {
  width: 22px;
  flex-shrink: 0;
  text-align: center;
  color: #7b52ab;
  font-size: 15px;
}

.visner-member-profile__at {
  font-weight: 800;
  font-size: 16px;
  line-height: 1;
}

.visner-member-profile__contact-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.visner-member-profile__contact-empty {
  margin: 0;
  font-size: 13px;
  color: #6e6e73;
}

.visner-member-profile__stats {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 0;
  text-align: center;
}

.visner-member-profile__stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 4px 6px;
  min-width: 0;
}

.visner-member-profile__stat strong {
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  margin-top: 2px;
}

.visner-member-profile__stat span:last-child {
  font-size: 11px;
  color: #a1a1a1;
  text-transform: lowercase;
}

.visner-member-profile__stat-div {
  width: 1px;
  align-self: stretch;
  background: rgba(255, 255, 255, 0.12);
  margin: 6px 0;
}

.visner-member-profile__stat-icon {
  font-size: 18px;
  margin-bottom: 2px;
}

.visner-member-profile__stat-icon--purple {
  color: #7b52ab;
}

.visner-member-profile__stat-icon--pink {
  color: #f03e9b;
}

.visner-member-profile__stat-icon--yellow {
  color: #f5c542;
}

.visner-member-profile__mutual {
  margin-bottom: 8px;
}

.visner-member-profile__mutual-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
}

.visner-member-profile__mutual-link {
  appearance: none;
  border: none;
  background: transparent;
  padding: 0;
  font: inherit;
  font-weight: 600;
  font-size: 13px;
  color: #7b52ab;
  cursor: pointer;
}

.visner-member-profile__mutual-link.is-open {
  opacity: 0.75;
}

.visner-member-profile__mutual-row,
.visner-member-profile__mutual-rest {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.visner-member-profile__mutual-rest {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed rgba(255, 255, 255, 0.08);
}

.visner-member-profile__mutual-avatar {
  appearance: none;
  border: none;
  padding: 0;
  margin: 0;
  border-radius: 50%;
  cursor: pointer;
  background: transparent;
  line-height: 0;
}

.visner-member-profile__mutual-avatar .social-member-avatar,
.visner-member-profile__mutual-avatar img {
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.12);
}

.visner-member-profile__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 18px;
}

.visner-member-profile__btn-primary {
  appearance: none;
  border: none;
  border-radius: 14px;
  width: 100%;
  padding: 14px 16px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  cursor: pointer;
  background: linear-gradient(180deg, #ff4eb5 0%, #f03e9b 55%, #e0197a 100%);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12) inset, 0 6px 22px rgba(240, 62, 155, 0.45);
}

.visner-member-profile__btn-primary:active {
  transform: scale(0.99);
}

.visner-member-profile__btn-secondary {
  appearance: none;
  border-radius: 14px;
  width: 100%;
  padding: 13px 16px;
  font-size: 15px;
  font-weight: 600;
  color: #fff;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.visner-member-profile__btn-ghost {
  appearance: none;
  border-radius: 12px;
  width: 100%;
  padding: 11px 16px;
  font-size: 14px;
  font-weight: 600;
  color: #e8e8ed;
  cursor: pointer;
  background: transparent;
  border: 1px solid rgba(123, 82, 171, 0.45);
}

.visner-member-profile__footer-note {
  margin: 14px 0 0;
  text-align: center;
  font-size: 12px;
  color: #6e6e73;
}

@media (prefers-reduced-motion: reduce) {
  .visner-member-profile__btn-primary:active {
    transform: none;
  }
}
