/* Randly — глобальные стили (public). Тема: data-theme на <html> */

:root {
    color-scheme: light;
    --font-sans: "DM Sans", system-ui, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, monospace;

    --bg-page: #e8f4fc;
    --bg-elevated: #ffffff;
    --bg-muted: #d8eaf8;
    --text-primary: #0d1b2a;
    --text-muted: #5a6d7e;
    --border-subtle: rgba(13, 27, 42, 0.09);
    --accent: #229ed9;
    --accent-soft: rgba(34, 158, 217, 0.22);
    --accent-hot: #34b7f1;
    --accent-hot-soft: rgba(52, 183, 241, 0.28);
    --shadow-lg: 0 22px 60px rgba(13, 57, 82, 0.12);
    --radius-xl: 20px;
    --radius-full: 9999px;
    --top-bar-height: 64px;
    /* Кружок превью: постоянный размер на десктопе; на телефоне — ниже в @media */
    --circle-preview-size: 380px;
}

@media (max-width: 520px) {
    :root {
        --circle-preview-size: min(
            320px,
            calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - 1.25rem)
        );
    }

    .recorder-placeholder__ring {
        width: 80px;
        height: 80px;
    }
}

@media (max-width: 380px) {
    :root {
        --circle-preview-size: min(
            288px,
            calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - 1rem)
        );
    }
}

[data-theme="dark"] {
    color-scheme: dark;
    --bg-page: #0e1113;
    --bg-elevated: #171b20;
    --bg-muted: #212830;
    --bg-interactive: #2c3540;
    --bg-interactive-strong: #384452;
    --text-primary: #e9eef2;
    --text-muted: #95a3b0;
    --border-subtle: transparent;
    --accent: #56b9ff;
    --accent-soft: rgba(86, 185, 255, 0.14);
    --accent-hot: #87ceff;
    --accent-hot-soft: rgba(135, 206, 255, 0.12);
    --shadow-lg: 0 22px 56px rgba(0, 0, 0, 0.52);
}

[data-theme="dark"] body.site-body {
    background:
        radial-gradient(980px 460px at 10% -12%, color-mix(in srgb, var(--accent-soft) 55%, transparent), transparent),
        radial-gradient(760px 420px at 100% 0%, color-mix(in srgb, var(--accent-hot-soft) 48%, transparent), transparent),
        var(--bg-page);
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }
}

/* Прокрутка на <html>: одинаково в light/dark; полоса не «пропадает» в тёмном color-scheme */
html.intro-rules-done {
    scrollbar-gutter: stable;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: color-mix(in srgb, var(--text-muted) 50%, transparent) transparent;
}

html:not(.intro-rules-done) {
    overflow: hidden;
}

body.site-body {
    margin: 0;
    min-height: 100vh;
    min-height: 100dvh;
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.5;
    background: radial-gradient(1200px 600px at 10% -10%, var(--accent-soft), transparent),
        radial-gradient(900px 500px at 100% 0%, var(--accent-hot-soft), transparent),
        var(--bg-page);
    color: var(--text-primary);
}

html.intro-rules-done body.site-body {
    overflow-x: clip;
}

html:not(.intro-rules-done) body.site-body {
    overflow: hidden;
}

html.intro-rules-done::-webkit-scrollbar {
    width: 10px;
}

html.intro-rules-done::-webkit-scrollbar-track {
    background: transparent;
}

html.intro-rules-done::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--text-muted) 48%, transparent);
    border-radius: var(--radius-full);
}

html.intro-rules-done::-webkit-scrollbar-thumb:hover {
    background: color-mix(in srgb, var(--accent) 42%, var(--text-muted));
}

.site-shell {
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
}

/* Контент под топ-баром: pull-to-refresh на телефоне и в Telegram Mini App */
.site-pull-shell {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    position: relative;
}

.site-pull-indicator {
    flex-shrink: 0;
    height: 52px;
    margin-bottom: -52px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 10px;
    pointer-events: none;
    z-index: 5;
    opacity: 0;
    transition: opacity 0.32s ease-out;
}

.site-pull-shell.site-pull-shell--pulling .site-pull-indicator {
    opacity: 1;
}

.site-pull-spinner {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 2.5px solid color-mix(in srgb, var(--accent) 24%, transparent);
    border-top-color: var(--accent);
    border-right-color: color-mix(in srgb, var(--accent) 45%, transparent);
    transition:
        border-color 0.28s ease,
        box-shadow 0.28s ease;
}

.site-pull-shell.site-pull-shell--pulling .site-pull-spinner {
    animation: site-pull-spin 0.72s linear infinite;
}

.site-pull-shell.site-pull-shell--threshold .site-pull-spinner {
    border-top-color: var(--accent-hot);
    border-right-color: color-mix(in srgb, var(--accent-hot) 55%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 26%, transparent);
}

@keyframes site-pull-spin {
    to {
        transform: rotate(360deg);
    }
}

.site-pull-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

@media (prefers-reduced-motion: reduce) {
    .site-pull-shell.site-pull-shell--pulling .site-pull-spinner {
        animation-duration: 1.65s;
    }

    .site-pull-spinner {
        transition:
            border-color 0.2s ease,
            box-shadow 0.2s ease;
    }
}

/* Top bar */

.top-bar {
    position: sticky;
    top: 0;
    z-index: 40;
    height: var(--top-bar-height);
    --top-bar-icon-btn-size: 2.35rem;
    border-bottom: 1px solid var(--border-subtle);
    backdrop-filter: blur(14px);
    background: color-mix(in srgb, var(--bg-elevated) 82%, transparent);
}

.top-bar__inner {
    max-width: 1120px;
    margin: 0 auto;
    padding: 0 max(1.25rem, env(safe-area-inset-left)) 0 max(1.25rem, env(safe-area-inset-right));
    height: 100%;
    display: flex;
    align-items: center;
    gap: 1rem;
}

/* Telegram Mini App: заметный отступ сверху (часть клиентов почти не задаёт --tg-*) */
html.telegram-mini-app .top-bar {
    height: auto;
    min-height: var(--top-bar-height);
    padding-top: max(
        calc(52px + env(safe-area-inset-top, 0px)),
        calc(40px + var(--tg-content-safe-area-inset-top, 0px)),
        calc(36px + var(--tg-safe-area-inset-top, 0px)),
        env(safe-area-inset-top),
        var(--tg-content-safe-area-inset-top, 0px),
        var(--tg-safe-area-inset-top, 0px)
    );
    box-sizing: border-box;
}

html.telegram-mini-app .top-bar__inner {
    height: auto;
    min-height: var(--top-bar-height);
}

.top-bar__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    text-decoration: none;
    color: inherit;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.top-bar__logo {
    height: 55px;
    width: auto;
    max-width: min(160px, 38vw);
    flex-shrink: 0;
    display: block;
    object-fit: contain;
}

.top-bar__title {
    font-size: 2rem;
}

.top-bar__nav {
    flex: 1;
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.top-bar__link {
    padding: 0.45rem 0.85rem;
    border-radius: var(--radius-full);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text-muted);
    text-decoration: none;
    border: 1px solid transparent;
    transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

.top-bar__link--muted {
    opacity: 0.45;
    cursor: not-allowed;
}

.top-bar__link--current {
    color: var(--text-primary);
    border-color: color-mix(in srgb, var(--accent) 35%, transparent);
    background: color-mix(in srgb, var(--accent) 12%, var(--bg-muted));
}

[data-theme="dark"] .top-bar__link--current {
    border-color: color-mix(in srgb, var(--accent) 42%, transparent);
    background: color-mix(in srgb, var(--accent) 16%, var(--bg-muted));
}

.top-bar__actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.top-bar__stats--desktop {
    display: none;
}

@media (min-width: 768px) {
    .top-bar__stats--desktop {
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
        flex-shrink: 0;
        font-size: 0.76rem;
        font-weight: 500;
        color: var(--text-muted);
        white-space: nowrap;
    }

    .top-bar__stat-num {
        font-weight: 700;
        font-variant-numeric: tabular-nums;
        color: var(--text-primary);
    }

    .top-bar__stat-sep {
        opacity: 0.35;
        user-select: none;
    }

    .top-bar .theme-toggle.theme-toggle--desktop {
        width: var(--top-bar-icon-btn-size);
        height: var(--top-bar-icon-btn-size);
        min-width: var(--top-bar-icon-btn-size);
        min-height: var(--top-bar-icon-btn-size);
        box-sizing: border-box;
        flex-shrink: 0;
        padding: 0;
    }

    .top-bar .theme-toggle.theme-toggle--desktop .theme-toggle__icon {
        font-size: 1.28rem;
    }
}

.theme-toggle {
    width: 42px;
    height: 42px;
    border-radius: var(--radius-full);
    border: 1px solid var(--border-subtle);
    background: var(--bg-muted);
    cursor: pointer;
    display: grid;
    place-items: center;
    position: relative;
    transition: transform 0.12s ease, box-shadow 0.15s ease;
}

.theme-toggle:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.theme-toggle__icon {
    position: absolute;
    font-size: 1.05rem;
    line-height: 1;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.theme-toggle__icon--sun {
    color: #f59e0b;
    opacity: 1;
    transform: scale(1);
}

.theme-toggle__icon--moon {
    color: color-mix(in srgb, #93c5fd 92%, var(--text-muted));
    opacity: 0;
    transform: scale(0.6);
}

[data-theme="dark"] .theme-toggle__icon--sun {
    opacity: 0;
    transform: scale(0.6);
}

[data-theme="dark"] .theme-toggle__icon--moon {
    opacity: 1;
    transform: scale(1);
}

/* Mobile drawer & burger — только ≤767px; на десктопе см. min-width:768 ниже */
.top-bar__mobile-cluster {
    display: none;
}

.mobile-menu-trigger {
    display: none;
}

.mobile-menu {
    display: none;
}

@media (max-width: 767px) {
    .top-bar__nav--desktop {
        display: none !important;
    }

    .top-bar__auth--desktop {
        display: none !important;
    }

    .theme-toggle--desktop {
        display: none !important;
    }

    .top-bar__mobile-cluster {
        display: inline-flex;
        align-items: center;
        gap: 0.45rem;
        flex-shrink: 0;
    }

    .btn.btn--sm.top-bar__btn-login-mobile {
        min-height: 44px;
        padding-inline: 0.95rem;
        padding-block: 0;
        touch-action: manipulation;
        flex-shrink: 0;
        white-space: nowrap;
    }

    .mobile-menu-trigger:focus-visible {
        outline: 2px solid var(--accent);
        outline-offset: 3px;
    }

    .mobile-menu-trigger {
        display: inline-grid;
        place-items: center;
        width: 44px;
        height: 44px;
        padding: 0;
        margin: 0;
        border: 1px solid var(--border-subtle);
        border-radius: var(--radius-full);
        background: var(--bg-muted);
        color: var(--text-primary);
        cursor: pointer;
        flex-shrink: 0;
        touch-action: manipulation;
        transition:
            transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1),
            box-shadow 0.2s ease,
            border-color 0.2s ease,
            background 0.2s ease;
    }

    .mobile-menu-trigger:hover {
        transform: scale(1.04);
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
    }

    .mobile-menu-trigger:active {
        transform: scale(0.96);
    }

    .mobile-menu-trigger.is-open {
        border-color: color-mix(in srgb, var(--accent) 45%, transparent);
        background: color-mix(in srgb, var(--accent) 14%, var(--bg-muted));
    }

    .mobile-menu-trigger__bars {
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 5px;
        width: 18px;
        pointer-events: none;
    }

    .mobile-menu-trigger__bars span {
        display: block;
        height: 2px;
        width: 100%;
        border-radius: 2px;
        background: currentColor;
        transition:
            transform 0.35s cubic-bezier(0.65, 0, 0.35, 1),
            opacity 0.25s ease,
            translate 0.35s cubic-bezier(0.65, 0, 0.35, 1);
        transform-origin: center;
    }

    .mobile-menu-trigger.is-open .mobile-menu-trigger__bars span:nth-child(1) {
        translate: 0 7px;
        transform: rotate(45deg);
    }

    .mobile-menu-trigger.is-open .mobile-menu-trigger__bars span:nth-child(2) {
        opacity: 0;
        transform: scaleX(0);
    }

    .mobile-menu-trigger.is-open .mobile-menu-trigger__bars span:nth-child(3) {
        translate: 0 -7px;
        transform: rotate(-45deg);
    }

    .mobile-menu {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 100;
        pointer-events: none;
        visibility: hidden;
        transition: visibility 0s linear 0.45s;
    }

    .mobile-menu.is-open {
        pointer-events: auto;
        visibility: visible;
        transition-delay: 0s;
    }

    .mobile-menu__backdrop {
        position: absolute;
        inset: 0;
        border: none;
        padding: 0;
        margin: 0;
        cursor: pointer;
        background: rgba(15, 23, 42, 0.42);
        backdrop-filter: blur(6px);
        -webkit-backdrop-filter: blur(6px);
        opacity: 0;
        transition: opacity 0.38s cubic-bezier(0.33, 1, 0.68, 1);
    }

    [data-theme="dark"] .mobile-menu__backdrop {
        background: rgba(0, 0, 0, 0.55);
    }

    .mobile-menu.is-open .mobile-menu__backdrop {
        opacity: 1;
    }

    .mobile-menu__panel {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        width: min(20rem, calc(100vw - 2.5rem));
        max-width: 100%;
        padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom))
            max(1rem, env(safe-area-inset-left));
        background: color-mix(in srgb, var(--bg-elevated) 96%, transparent);
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        border-left: 1px solid var(--border-subtle);
        box-shadow: -24px 0 48px rgba(0, 0, 0, 0.12);
        transform: translateX(104%);
        transition: transform 0.42s cubic-bezier(0.33, 1, 0.68, 1);
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    .mobile-menu.is-open .mobile-menu__panel {
        transform: translateX(0);
    }

    [data-theme="dark"] .mobile-menu__panel {
        border-left-color: transparent;
        box-shadow: -28px 0 56px rgba(0, 0, 0, 0.45);
        background: color-mix(in srgb, var(--bg-elevated) 98%, transparent);
    }

    .mobile-menu__head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding-bottom: 0.25rem;
        border-bottom: 1px solid var(--border-subtle);
    }

    .mobile-menu__title {
        margin: 0;
        font-size: 1rem;
        font-weight: 700;
        letter-spacing: -0.02em;
    }

    .mobile-menu__close {
        width: 40px;
        height: 40px;
        display: inline-grid;
        place-items: center;
        border: none;
        border-radius: var(--radius-full);
        background: color-mix(in srgb, var(--bg-muted) 88%, transparent);
        color: var(--text-muted);
        cursor: pointer;
        transition:
            transform 0.2s ease,
            color 0.2s ease,
            background 0.2s ease;
    }

    .mobile-menu__close:hover {
        color: var(--text-primary);
        background: var(--bg-muted);
        transform: rotate(90deg);
    }

    .mobile-menu__account {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding-bottom: 0.85rem;
        margin-bottom: 0.15rem;
        border-bottom: 1px solid var(--border-subtle);
    }

    .mobile-menu__username {
        font-weight: 700;
        font-size: 0.92rem;
        letter-spacing: -0.02em;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        min-width: 0;
    }

    .mobile-menu__logout-form {
        margin: 0;
        flex-shrink: 0;
    }

    .mobile-menu__logout-btn {
        font: inherit;
        font-weight: 600;
        font-size: 0.82rem;
        padding: 0.45rem 0.85rem;
        border-radius: var(--radius-full);
        border: 1px solid var(--border-subtle);
        background: color-mix(in srgb, var(--bg-muted) 88%, transparent);
        color: var(--text-muted);
        cursor: pointer;
        transition:
            color 0.18s ease,
            border-color 0.18s ease,
            background 0.18s ease;
        touch-action: manipulation;
    }

    .mobile-menu__logout-btn:hover {
        color: var(--text-primary);
        border-color: color-mix(in srgb, var(--accent) 35%, transparent);
        background: var(--bg-muted);
    }

    .mobile-menu__stats {
        display: flex;
        flex-direction: column;
        gap: 0.4rem;
        padding: 0.15rem 0 0.85rem;
        margin-bottom: 0.15rem;
        border-bottom: 1px solid var(--border-subtle);
        opacity: 0;
        transform: translateX(12px);
        transition:
            opacity 0.38s cubic-bezier(0.33, 1, 0.68, 1) 0.04s,
            transform 0.42s cubic-bezier(0.33, 1, 0.68, 1) 0.04s;
    }

    .mobile-menu.is-open .mobile-menu__stats {
        opacity: 1;
        transform: translateX(0);
    }

    .mobile-menu__stat-row {
        display: flex;
        align-items: baseline;
        flex-wrap: wrap;
        gap: 0.25rem;
        font-size: 0.86rem;
        color: var(--text-muted);
    }

    .mobile-menu__stat-num {
        font-weight: 700;
        font-size: 1rem;
        font-variant-numeric: tabular-nums;
        color: var(--text-primary);
    }

    .mobile-menu__stat-label {
        font-weight: 500;
    }

    .mobile-menu__nav {
        display: flex;
        flex-direction: column;
        gap: 0.35rem;
        flex: 1;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }

    .mobile-menu__link {
        display: flex;
        align-items: center;
        min-height: 48px;
        padding: 0.65rem 1rem;
        border-radius: var(--radius-full);
        font-size: 0.98rem;
        font-weight: 600;
        color: var(--text-primary);
        text-decoration: none;
        border: 1px solid transparent;
        background: transparent;
        opacity: 0;
        transform: translateX(14px);
        transition:
            opacity 0.4s cubic-bezier(0.33, 1, 0.68, 1),
            transform 0.45s cubic-bezier(0.33, 1, 0.68, 1),
            border-color 0.2s ease,
            background 0.2s ease,
            color 0.2s ease;
    }

    .mobile-menu.is-open .mobile-menu__link {
        opacity: 1;
        transform: translateX(0);
    }

    .mobile-menu.is-open .mobile-menu__link:nth-child(1) {
        transition-delay: 0.06s;
    }

    .mobile-menu.is-open .mobile-menu__link:nth-child(2) {
        transition-delay: 0.11s;
    }

    .mobile-menu.is-open .mobile-menu__link:nth-child(3) {
        transition-delay: 0.16s;
    }

    .mobile-menu.is-open .mobile-menu__link:nth-child(4) {
        transition-delay: 0.21s;
    }

    .mobile-menu__link:active {
        transform: scale(0.98);
    }

    .mobile-menu__link--muted-strong {
        color: var(--accent);
        border-color: color-mix(in srgb, var(--accent) 32%, transparent);
        background: color-mix(in srgb, var(--accent) 10%, transparent);
    }

    .mobile-menu__link--current {
        border-color: color-mix(in srgb, var(--accent) 38%, transparent);
        background: color-mix(in srgb, var(--accent) 14%, var(--bg-muted));
        color: var(--text-primary);
    }

    .mobile-menu__footer {
        margin-top: auto;
        padding-top: 0.75rem;
        border-top: 1px solid var(--border-subtle);
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        opacity: 0;
        transform: translateY(10px);
        transition:
            opacity 0.38s cubic-bezier(0.33, 1, 0.68, 1) 0.14s,
            transform 0.4s cubic-bezier(0.33, 1, 0.68, 1) 0.14s;
    }

    .mobile-menu.is-open .mobile-menu__footer {
        opacity: 1;
        transform: translateY(0);
    }

    .mobile-menu__theme-label {
        font-size: 0.82rem;
        font-weight: 600;
        color: var(--text-muted);
    }

    .theme-toggle--menu {
        flex-shrink: 0;
        touch-action: manipulation;
    }

    body.mobile-menu-open {
        overflow: hidden;
        touch-action: none;
    }

    .top-bar {
        height: auto;
        min-height: var(--top-bar-height);
    }

    .top-bar__inner {
        flex-wrap: nowrap;
        align-items: center;
        row-gap: 0;
        padding-top: max(0.35rem, env(safe-area-inset-top));
        padding-bottom: 0.35rem;
        height: auto;
    }

    html.telegram-mini-app .top-bar__inner {
        padding-top: 0.35rem;
    }

    .top-bar__brand {
        flex: 1;
        min-width: 0;
    }

    .top-bar__title {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .top-bar__actions {
        gap: 0.45rem;
        flex-shrink: 0;
    }
}

@media (min-width: 768px) {
    .top-bar__mobile-cluster {
        display: none !important;
    }

    .mobile-menu-trigger {
        display: none !important;
    }

    .mobile-menu {
        display: none !important;
    }

    body.mobile-menu-open {
        overflow: unset !important;
        touch-action: unset !important;
    }
}

@media (max-width: 767px) and (prefers-reduced-motion: reduce) {
    .mobile-menu__backdrop,
    .mobile-menu__panel,
    .mobile-menu__link,
    .mobile-menu__footer,
    .mobile-menu__stats,
    .mobile-menu-trigger,
    .mobile-menu-trigger__bars span {
        transition-duration: 0.01ms !important;
        transition-delay: 0ms !important;
        animation: none !important;
    }

    .mobile-menu__link {
        opacity: 1;
        transform: none;
    }

    .mobile-menu__footer {
        opacity: 1;
        transform: none;
    }

    .mobile-menu__stats {
        opacity: 1;
        transform: none;
    }

    .mobile-menu {
        transition: none;
    }
}

/* Main */

.site-main {
    flex: 1;
    width: 100%;
    max-width: 1120px;
    margin: 0 auto;
    padding: 2rem max(1.25rem, env(safe-area-inset-left)) 3rem max(1.25rem, env(safe-area-inset-right));
    padding-bottom: max(3rem, calc(2rem + env(safe-area-inset-bottom)));
    display: flex;
    flex-direction: column;
}

.site-footer {
    border-top: 1px solid var(--border-subtle);
    padding: 2rem max(1.25rem, env(safe-area-inset-left)) max(2rem, env(safe-area-inset-bottom))
        max(1.25rem, env(safe-area-inset-right));
    background: color-mix(in srgb, var(--bg-elevated) 72%, transparent);
}

.site-footer__inner {
    max-width: 1120px;
    margin: 0 auto;
}

.site-footer__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 1.75rem 2rem;
    align-items: start;
}

.site-footer__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    color: inherit;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 0.65rem;
}

.site-footer__brand-logo {
    height: 28px;
    width: auto;
    max-width: 120px;
    object-fit: contain;
    display: block;
}

.site-footer__brand-name {
    font-size: 1.05rem;
}

.site-footer__lead {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.55;
    color: var(--text-muted);
}

.site-footer__heading {
    margin: 0 0 0.65rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--text-muted) 82%, var(--text-primary));
}

.site-footer__links {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.site-footer__links a {
    font-size: 0.88rem;
    font-weight: 500;
    color: color-mix(in srgb, var(--text-muted) 88%, var(--accent));
    text-decoration: none;
    transition: color 0.15s ease;
}

.site-footer__links a:hover {
    color: var(--accent);
}

.site-footer__fine-print {
    margin: 0 0 0.5rem;
    font-size: 0.78rem;
    line-height: 1.5;
    color: var(--text-muted);
}

.site-footer__fine-print--muted {
    opacity: 0.85;
    margin-bottom: 0;
}

.site-footer__fine-print--social-intro {
    margin-bottom: 0.65rem;
}

.site-footer__social {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.site-footer__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.55rem;
    height: 2.55rem;
    border-radius: var(--radius-full);
    font-size: 1.08rem;
    color: var(--text-muted);
    background: color-mix(in srgb, var(--bg-muted) 88%, transparent);
    border: 1px solid var(--border-subtle);
    text-decoration: none;
    transition:
        color 0.15s ease,
        background 0.15s ease,
        border-color 0.15s ease,
        transform 0.15s ease;
}

.site-footer__social-link:hover {
    color: var(--accent);
    background: color-mix(in srgb, var(--accent) 14%, var(--bg-muted));
    border-color: color-mix(in srgb, var(--accent) 38%, transparent);
    transform: translateY(-2px);
}

.site-footer__bottom {
    margin-top: 2rem;
    padding-top: 1.35rem;
    border-top: 1px solid var(--border-subtle);
    text-align: center;
}

.site-footer__copyright {
    margin: 0;
    font-size: 0.78rem;
    color: color-mix(in srgb, var(--text-muted) 94%, transparent);
}

.site-footer__recaptcha {
    margin: 0.65rem 0 0;
    font-size: 0.72rem;
    line-height: 1.45;
    color: color-mix(in srgb, var(--text-muted) 92%, transparent);
}

.site-footer__recaptcha a {
    color: color-mix(in srgb, var(--text-muted) 70%, var(--accent) 30%);
    text-decoration: underline;
    text-underline-offset: 0.12em;
}

.site-footer__recaptcha a:hover {
    color: color-mix(in srgb, var(--accent) 55%, var(--text-muted));
}

/* reCAPTCHA v3: убрать плавающий badge; при скрытии по правилам Google нужна видимая ссылка на политики — см. подвал layouts/app.blade.php */
.grecaptcha-badge {
    visibility: hidden !important;
}

/* Hero / recorder */

.hero {
    display: grid;
    gap: 2rem;
    align-items: start;
}

.hero--solo {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: calc(var(--circle-preview-size) + 4rem);
    margin-inline: auto;
    padding-block: min(5vh, 1.75rem);
    min-height: min(620px, calc(100vh - var(--top-bar-height) - 7rem));
    min-height: min(620px, calc(100dvh - var(--top-bar-height) - 7rem));
}

/* Студия: карусель запись ↔ просмотр чужих; ширина под один крупный круг */
.hero.hero--studio.hero--solo {
    max-width: min(56rem, calc(100vw - 2rem));
    align-items: stretch;
}

/* Landing (главная) */

.landing {
    width: 100%;
    max-width: 56rem;
    margin-inline: auto;
    padding-block: clamp(1rem, 3vw, 2.25rem);
    display: flex;
    flex-direction: column;
    gap: clamp(1.5rem, 4vw, 2.5rem);
    overflow-wrap: anywhere;
}

.landing-hero {
    padding: clamp(1.35rem, 4vw, 2.25rem);
    border-radius: var(--radius-xl);
}

.landing-hero__title {
    margin: 0 0 0.85rem;
    font-size: clamp(1.75rem, 4.8vw, 2.35rem);
    letter-spacing: -0.035em;
    line-height: 1.15;
    color: var(--text-primary);
}

.landing-hero__lead {
    margin: 0 0 1.35rem;
    font-size: clamp(0.96rem, 2.4vw, 1.08rem);
    line-height: 1.55;
    color: var(--text-muted);
    max-width: 44rem;
}

.landing-hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: center;
}

.landing-section-title {
    margin: 0 0 1rem;
    font-size: clamp(1.12rem, 2.8vw, 1.32rem);
    letter-spacing: -0.02em;
    color: var(--text-primary);
}

.landing-feature-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
    gap: 1rem;
}

.landing-feature {
    padding: 1.25rem 1.2rem;
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    min-height: 100%;
}

.landing-feature__icon {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: var(--radius-full);
    display: grid;
    place-items: center;
    font-size: 1rem;
    background: color-mix(in srgb, var(--accent) 18%, var(--bg-muted));
    color: color-mix(in srgb, var(--accent-hot) 82%, var(--text-primary));
}

.landing-feature__title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text-primary);
}

.landing-feature__text {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.48;
    color: var(--text-muted);
    flex: 1;
}

.landing-feature__link {
    margin-top: 0.35rem;
    font-size: 0.88rem;
    font-weight: 600;
    color: color-mix(in srgb, var(--accent) 72%, var(--text-primary));
    text-decoration: none;
    align-self: flex-start;
}

.landing-feature__link:hover {
    text-decoration: underline;
}

.landing-feature__muted {
    margin-top: 0.35rem;
    font-size: 0.86rem;
    line-height: 1.45;
    color: color-mix(in srgb, var(--text-muted) 92%, var(--text-primary));
}

.landing-trust {
    padding: 1.25rem 1.35rem;
    border-radius: var(--radius-lg);
}

.landing-trust__title {
    margin: 0 0 0.65rem;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text-primary);
}

.landing-trust__text {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.52;
    color: var(--text-muted);
}

.intro-modal.intro-modal--landing-skip {
    display: none !important;
}

/* Intro rules modal (layout) */

.intro-modal {
    position: fixed;
    inset: 0;
    z-index: 150;
    display: grid;
    place-items: center;
    padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right))
        max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
}

html.intro-rules-done #intro-rules-modal {
    display: none !important;
}

.intro-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(14, 38, 58, 0.78);
    backdrop-filter: blur(10px);
}

.intro-modal__panel {
    position: relative;
    width: 100%;
    max-width: 540px;
    max-height: min(90vh, 640px);
    overflow-y: auto;
    padding: 1.75rem 1.5rem;
    text-align: left;
}

.intro-modal__title {
    margin: 0 0 1rem;
    font-size: clamp(1.35rem, 4vw, 1.85rem);
    letter-spacing: -0.03em;
    line-height: 1.2;
    color: var(--text-primary);
}

.intro-modal__body {
    margin-bottom: 1.35rem;
}

.intro-modal__lead {
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.55;
    color: var(--text-muted);
}

.intro-modal__lead strong {
    color: color-mix(in srgb, var(--text-primary) 92%, var(--text-muted));
    font-weight: 600;
}

.intro-modal__btn {
    width: 100%;
    justify-content: center;
}

.registration-password-modal__lead strong {
    color: color-mix(in srgb, var(--accent-hot) 55%, var(--text-primary));
    font-weight: 600;
}

.registration-password-modal__secret-wrap {
    margin-top: 0.75rem;
    padding: 0.85rem 1rem;
    border-radius: var(--radius-lg, 16px);
    background: color-mix(in srgb, var(--bg-interactive-strong) 65%, transparent);
    border: 1px solid var(--border-subtle);
}

.registration-password-modal__secret {
    display: block;
    margin: 0;
    font-family: "JetBrains Mono", ui-monospace, monospace;
    font-size: clamp(0.8rem, 2.8vw, 0.95rem);
    font-weight: 500;
    line-height: 1.45;
    word-break: break-all;
    color: var(--text-primary);
}

.registration-password-modal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: stretch;
}

.registration-password-modal__copy {
    flex: 1 1 auto;
    justify-content: center;
    gap: 0.45rem;
}

.registration-password-modal__copy i {
    opacity: 0.85;
}

.registration-password-modal__ok.intro-modal__btn {
    flex: 1 1 10rem;
    width: auto;
}

@media (max-width: 420px) {
    .registration-password-modal__actions {
        flex-direction: column;
    }

    .registration-password-modal__ok.intro-modal__btn {
        flex-basis: auto;
        width: 100%;
    }
}

.card-glow {
    border-radius: 30px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-elevated);

}

.recorder-card {
    padding: 1.25rem clamp(1rem, 4vw, 1.65rem);
    width: 100%;
}

/*
 * Студия: две панели (#studio-panel-record / #studio-panel-watch) без ленты __track.
 * Переключение только через app.js (inline display), чтобы не зависеть от каскада CSS.
 */
.studio-carousel {
    width: 100%;
    max-width: 56rem;
    margin-inline: auto;
    overflow: hidden;
    box-sizing: border-box;
}

.studio-carousel__panel {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

#studio-panel-watch[hidden] {
    display: none !important;
}

.studio-watch-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: center;
    margin-top: 1rem;
    width: var(--circle-preview-size);
    max-width: 100%;
    margin-inline: auto;
    box-sizing: border-box;
}

.studio-panel__title {
    margin: 0 0 0.65rem;
    text-align: center;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.recorder-panel.card-glow,
.foreign-watch-panel.card-glow {
    padding: 1.25rem clamp(1rem, 4vw, 1.65rem);
    width: 100%;
    box-sizing: border-box;
}

.foreign-watch-panel__viewport {
    position: relative;
    box-sizing: border-box;
    width: var(--circle-preview-size);
    height: var(--circle-preview-size);
    flex-shrink: 0;
    margin: 0 auto 1rem;
    border-radius: var(--radius-full);
    overflow: hidden;
    background: var(--bg-muted);
    border: 3px solid color-mix(in srgb, var(--accent-hot, var(--accent)) 36%, var(--border-subtle));
}

.foreign-watch-panel__viewport--idle .circle-video {
    opacity: 0;
    visibility: hidden;
}

.foreign-watch-panel__viewport--has-stream {
    cursor: pointer;
}

.foreign-watch-panel__viewport--has-stream:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent) 60%, transparent);
    outline-offset: 4px;
}

.auth-gate-card {
    max-width: 28rem;
    margin-inline: auto;
    text-align: center;
}

.auth-gate-card__title {
    margin: 0 0 0.65rem;
    font-size: clamp(1.25rem, 3.5vw, 1.55rem);
    letter-spacing: -0.03em;
    color: var(--text-primary);
}

.auth-gate-card__lead {
    margin: 0 0 1.35rem;
    font-size: 0.98rem;
    line-height: 1.55;
    color: var(--text-muted);
}

.auth-gate-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: center;
}

.auth-gate-card__hint {
    margin: 1.25rem 0 0;
    font-size: 0.88rem;
}

.auth-gate-card__hint .top-bar__link {
    display: inline-flex;
}

.recorder-card__viewport {
    position: relative;
    box-sizing: border-box;
    width: var(--circle-preview-size);
    height: var(--circle-preview-size);
    flex-shrink: 0;
    margin: 0 auto 1.25rem;
    border-radius: var(--radius-full);
    overflow: hidden;
    background: var(--bg-muted);
    border: 3px solid color-mix(in srgb, var(--accent) 42%, var(--border-subtle));
}

/* Пустой <video> не перекрывает плейсхолдер и не даёт «чёрную дыру» */
.recorder-card__viewport--idle .circle-video {
    opacity: 0;
    visibility: hidden;
}

.circle-video {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: none;
    background: #000;
    opacity: 1;
    visibility: visible;
}

.circle-video--mirror {
    transform: scaleX(-1);
}

.circle-ended-overlay {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: inherit;
    background: radial-gradient(
        circle at 50% 50%,
        rgba(2, 6, 23, 0.42) 0%,
        rgba(2, 6, 23, 0.72) 62%,
        rgba(2, 6, 23, 0.82) 100%
    );
    transition:
        opacity 0.28s ease,
        visibility 0.28s ease;
}

.circle-ended-overlay.is-hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.circle-ended-overlay__replay {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: min(5rem, 42%);
    height: min(5rem, 42%);
    padding: 0;
    margin: 0;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    color: rgba(255, 255, 255, 0.94);
    background: color-mix(in srgb, var(--bg-elevated, #1e293b) 58%, transparent);
    box-shadow:
        0 0 0 1px color-mix(in srgb, #fff 14%, transparent),
        0 12px 36px rgba(0, 0, 0, 0.35);
    transition:
        transform 0.14s ease,
        background 0.14s ease,
        box-shadow 0.14s ease;
}

.circle-ended-overlay__replay:hover {
    transform: scale(1.06);
    background: color-mix(in srgb, var(--accent) 35%, var(--bg-elevated, #1e293b));
}

.circle-ended-overlay__replay:active {
    transform: scale(0.96);
}

.circle-ended-overlay__replay:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent) 75%, #fff);
    outline-offset: 3px;
}

.circle-ended-overlay__replay-icon {
    flex-shrink: 0;
    pointer-events: none;
    font-size: 1.65rem;
    line-height: 1;
}

.circle-picker-loading {
    position: absolute;
    inset: 0;
    z-index: 6;
    display: grid;
    place-items: center;
    padding: 1rem;
    box-sizing: border-box;
    background: radial-gradient(
        circle at 50% 45%,
        color-mix(in srgb, var(--bg-muted) 55%, #020617) 0%,
        rgba(2, 6, 23, 0.94) 72%
    );
    transition: opacity 0.25s ease;
}

.circle-picker-loading.is-hidden {
    display: none;
}

.circle-picker-loading__panel {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.85rem;
    max-width: 12rem;
    text-align: center;
}

.circle-picker-loading__icon-slot {
    position: relative;
    width: 3.5rem;
    height: 3.5rem;
}

.circle-picker-loading__spinner {
    position: absolute;
    inset: 0;
    margin: auto;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--radius-full);
    border: 3px solid color-mix(in srgb, var(--accent) 28%, var(--border-subtle));
    border-top-color: color-mix(in srgb, var(--accent) 88%, #fff);
    animation: circle-picker-spin 0.85s linear infinite;
}

.circle-picker-loading__check {
    position: absolute;
    inset: 0;
    margin: auto;
    width: 2.75rem;
    height: 2.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.15rem;
    line-height: 1;
    color: color-mix(in srgb, var(--accent-hot, var(--accent)) 92%, #ecfdf5);
    opacity: 0;
    transform: scale(0.35);
    pointer-events: none;
    filter: drop-shadow(0 6px 18px color-mix(in srgb, var(--accent) 45%, transparent));
}

.circle-picker-loading__label {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.35;
    color: color-mix(in srgb, var(--text-primary) 88%, var(--text-muted));
}

.circle-picker-loading--found .circle-picker-loading__spinner {
    opacity: 0;
    animation: none;
    transition: opacity 0.2s ease;
}

.circle-picker-loading--found .circle-picker-loading__check {
    opacity: 1;
    transform: scale(1);
    transition:
        opacity 0.28s cubic-bezier(0.34, 1.25, 0.64, 1),
        transform 0.45s cubic-bezier(0.34, 1.45, 0.64, 1);
}

@keyframes circle-picker-spin {
    to {
        transform: rotate(360deg);
    }
}

.recorder-card__viewport--picker-wait .recording-badge,
.recorder-card__viewport--picker-wait .preview-mirror-btn,
.foreign-watch-panel__viewport--picker-wait .recording-badge,
.foreign-watch-panel__viewport--picker-wait .preview-mirror-btn {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
    .circle-picker-loading__spinner {
        animation-duration: 1.6s;
    }

    .circle-picker-loading--found .circle-picker-loading__check {
        transition-duration: 0.05ms !important;
    }
}

.preview-mirror-btn {
    position: absolute;
    bottom: max(14px, env(safe-area-inset-bottom));
    left: 50%;
    z-index: 4;
    transform: translateX(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border-radius: var(--radius-full);
    border: 1px solid color-mix(in srgb, var(--accent) 55%, transparent);
    background: color-mix(in srgb, var(--accent) 82%, #054061);
    color: #fff;
    cursor: pointer;
    box-shadow: 0 10px 28px color-mix(in srgb, var(--accent) 42%, transparent);
    transition:
        transform 0.1s ease,
        box-shadow 0.15s ease,
        opacity 0.15s ease,
        background 0.15s ease,
        border-color 0.15s ease;
}

.preview-mirror-btn:hover {
    border-color: color-mix(in srgb, var(--accent-hot) 70%, transparent);
    box-shadow: 0 12px 32px color-mix(in srgb, var(--accent) 48%, transparent);
}

.preview-mirror-btn:active {
    transform: translateX(-50%) scale(0.96);
}

.preview-mirror-btn:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent) 65%, transparent);
    outline-offset: 3px;
}

.preview-mirror-btn[aria-pressed="false"] {
    border-color: color-mix(in srgb, var(--border-subtle) 85%, transparent);
    background: color-mix(in srgb, var(--bg-elevated) 88%, rgba(0, 0, 0, 0.35));
    color: color-mix(in srgb, var(--text-primary) 92%, var(--accent));
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.18);
}

.preview-mirror-btn__icon {
    flex-shrink: 0;
    pointer-events: none;
    font-size: 1.05rem;
    line-height: 1;
}

.recorder-placeholder {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.85rem;
    color: var(--text-muted);
    pointer-events: none;
    background: radial-gradient(circle at 50% 42%, color-mix(in srgb, var(--accent-soft) 65%, transparent), transparent 62%);
}

.recorder-placeholder.is-hidden {
    display: none;
}

.recorder-card__viewport--has-blob {
    cursor: pointer;
}

.recorder-card__viewport--has-blob:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent) 60%, transparent);
    outline-offset: 4px;
}

.recorder-placeholder__ring {
    width: 96px;
    height: 96px;
    border-radius: var(--radius-full);
    border: 3px dashed color-mix(in srgb, var(--accent) 50%, transparent);
    flex-shrink: 0;
}

.recorder-placeholder__hint {
    margin: 0;
    max-width: 12rem;
    padding: 0 1rem;
    text-align: center;
    font-size: clamp(0.74rem, 2.8vw, 0.82rem);
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: 0.02em;
    color: color-mix(in srgb, var(--text-muted) 88%, var(--text-primary));
}

.recording-badge {
    position: absolute;
    top: 14px;
    left: 50%;
    z-index: 3;
    transform: translateX(-50%);
    padding: 0.35rem 0.75rem;
    border-radius: var(--radius-full);
    min-width: 3.35rem;
    text-align: center;
    font-size: 0.84rem;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
    background: color-mix(in srgb, var(--accent) 88%, #054061);
    color: #fff;
    box-shadow: 0 10px 28px color-mix(in srgb, var(--accent) 45%, transparent);
}

.recorder-card__toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    justify-content: center;
    width: var(--circle-preview-size);
    max-width: 100%;
    margin-inline: auto;
    box-sizing: border-box;
}

.recorder-card__toolbar-start {
    flex: 1 1 100%;
}

.recorder-post-actions {
    flex: 1 1 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 0.5rem;
    align-items: stretch;
}

.recorder-post-actions.is-hidden {
    display: none !important;
}

.recorder-post-actions__btn {
    flex: 1 1 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.42rem;
    min-width: 0;
    padding: 0.52rem 0.65rem;
    font-size: 0.86rem;
}

.recorder-post-actions__icon {
    flex-shrink: 0;
    font-size: 1rem;
    line-height: 1;
    opacity: 0.95;
}

.recorder-post-actions__label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.recorder-card__hint {
    margin: 1rem 0 0;
    text-align: center;
    min-height: 1.25rem;
    font-size: 0.85rem;
    color: var(--text-muted);
}

.studio-record-bridge {
    display: flex;
    justify-content: center;
    margin-top: 0.45rem;
    width: var(--circle-preview-size);
    max-width: 100%;
    margin-inline: auto;
    box-sizing: border-box;
}

.studio-record-bridge .btn {
    font-weight: 600;
    width: 100%;
    box-sizing: border-box;
}

/* Buttons */

.btn {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    text-decoration: none;
    border: 1px solid transparent;
    border-radius: var(--radius-full);
    padding: 0.65rem 1.25rem;
    font-family: inherit;
    font-weight: 600;
    font-size: 0.92rem;
    line-height: 1.2;
    cursor: pointer;
    transition: transform 0.1s ease, box-shadow 0.15s ease, opacity 0.15s ease;
    touch-action: manipulation;
}

.btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.btn--primary {
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent-hot) 55%, var(--accent)));
    color: #fff;
    box-shadow: 0 14px 34px color-mix(in srgb, var(--accent) 35%, transparent);
}

.btn--accent {
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 70%, #054061), var(--accent-hot));
    color: #fff;
    box-shadow: 0 12px 28px color-mix(in srgb, var(--accent) 38%, transparent);
}

.btn--ghost {
    background: transparent;
    border-color: var(--border-subtle);
    color: var(--text-primary);
}

.telegram-auth {
    margin-top: 1.15rem;
}

.telegram-auth__divider {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 0 0 0.85rem;
    color: var(--text-muted);
    font-size: 0.8rem;
}

.telegram-auth__divider::before,
.telegram-auth__divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--border-subtle);
}

.telegram-auth__btn {
    width: 100%;
    justify-content: center;
    gap: 0.5rem;
    border-color: color-mix(in srgb, #229ed9 42%, var(--border-subtle));
    background: color-mix(in srgb, #229ed9 13%, var(--bg-elevated));
    color: color-mix(in srgb, #168ac0 88%, var(--text-primary));
}

.telegram-auth__btn--mini {
    display: none;
}

.telegram-auth__widget {
    display: flex;
    justify-content: center;
}

html.telegram-mini-app .telegram-auth__btn--mini {
    display: inline-flex;
}

html.telegram-mini-app .telegram-auth__widget {
    display: none;
}

.telegram-auth__btn:hover:not(:disabled) {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px color-mix(in srgb, #229ed9 24%, transparent);
}

.telegram-auth__icon {
    font-size: 1.05rem;
}

.telegram-auth__hint,
.telegram-auth__status {
    margin: 0.55rem 0 0;
    font-size: 0.8rem;
    line-height: 1.4;
    color: var(--text-muted);
    text-align: center;
}

.telegram-auth__status--error {
    color: color-mix(in srgb, #ef4444 85%, var(--text-primary));
}

.btn--sm {
    padding: 0.35rem 0.65rem;
    font-size: 0.85rem;
}

.btn--pulse:not(:disabled) {
    animation: pulse-soft 2.4s ease-in-out infinite;
}

@keyframes pulse-soft {
    0%,
    100% {
        box-shadow: 0 14px 34px color-mix(in srgb, var(--accent) 28%, transparent);
    }
    50% {
        box-shadow: 0 18px 44px color-mix(in srgb, var(--accent) 42%, transparent);
    }
}

@keyframes spin-slow {
    to {
        transform: rotate(360deg);
    }
}

.is-hidden {
    display: none !important;
}

/* Overlay */

.overlay {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: grid;
    place-items: center;
    padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right))
        max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
}

.overlay__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(14, 38, 58, 0.58);
    backdrop-filter: blur(6px);
}

.overlay__panel {
    position: relative;
    max-width: 420px;
    width: 100%;
    padding: 2rem 1.75rem;
    text-align: center;
    overflow: hidden;
}

.success-burst {
    position: absolute;
    inset: -40%;
    background: radial-gradient(circle at 50% 40%, var(--accent-soft), transparent 55%),
        radial-gradient(circle at 30% 70%, var(--accent-hot-soft), transparent 50%);
    animation: burst 1.2s ease-out forwards;
    pointer-events: none;
}

@keyframes burst {
    from {
        opacity: 0;
        transform: scale(0.85);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.overlay__title {
    position: relative;
    margin: 0 0 0.75rem;
    font-size: 1.45rem;
}

.overlay__text {
    position: relative;
    margin: 0 0 1.5rem;
    color: var(--text-muted);
    font-size: 0.95rem;
}

.overlay__actions {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.foreign-watch-ui {
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transform: translate3d(0, 14px, 0);
    margin-top: 0;
    padding-top: 0;
    padding-bottom: 0;
    border-top: 1px solid transparent;
    pointer-events: none;
    visibility: hidden;
    transition:
        opacity 0.42s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.48s cubic-bezier(0.22, 1, 0.36, 1),
        max-height 0.52s cubic-bezier(0.22, 1, 0.36, 1),
        margin-top 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        padding-top 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        visibility 0s linear 0.42s,
        border-top-color 0.35s ease;
}

.foreign-watch-ui.foreign-watch-ui--show {
    max-height: none;
    overflow: visible;
    opacity: 1;
    transform: translate3d(0, 0, 0);
    margin-top: 1.1rem;
    padding-top: 0.85rem;
    border-top-color: var(--border-subtle);
    pointer-events: auto;
    visibility: visible;
    transition:
        opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.52s cubic-bezier(0.34, 1.2, 0.64, 1),
        max-height 0.52s cubic-bezier(0.22, 1, 0.36, 1),
        margin-top 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        padding-top 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        visibility 0s linear 0s,
        border-top-color 0.38s ease;
}

.foreign-watch-ui--show .foreign-watch-ui__row {
    animation: foreign-watch-ui-row-in 0.52s cubic-bezier(0.34, 1.25, 0.64, 1) both;
}

@keyframes foreign-watch-ui-row-in {
    from {
        opacity: 0;
        transform: translate3d(0, 12px, 0);
    }

    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .foreign-watch-ui,
    .foreign-watch-ui.foreign-watch-ui--show {
        transition-duration: 0.01ms !important;
        transition-delay: 0s !important;
    }

    .foreign-watch-ui--show .foreign-watch-ui__row {
        animation: none !important;
    }
}

.foreign-watch-ui__row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.55rem 0.65rem;
}

.foreign-watch-ui__pills {
    gap: 0.6rem 0.75rem;
}

.watch-stat-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    box-sizing: border-box;
    min-height: 2.75rem;
    padding: 0.28rem 0.5rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--border-subtle) 88%, transparent);
    background: color-mix(in srgb, var(--bg-muted) 72%, #0b1220);
    box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 6%, transparent);
}

.watch-stat-pill--votes {
    gap: 0;
    padding: 0.2rem 0.42rem 0.2rem 0.26rem;
}

.watch-stat-pill__vote-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    flex-shrink: 0;
    padding: 0;
    margin: 0;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    font-family: inherit;
    background: transparent;
    color: color-mix(in srgb, var(--text-primary) 92%, #cbd5e1);
    transition:
        background 0.15s ease,
        color 0.15s ease,
        opacity 0.15s ease;
}

.watch-stat-pill__vote-btn:hover:not(:disabled) {
    background: color-mix(in srgb, #fff 10%, transparent);
}

.watch-stat-pill__vote-btn--up {
    background: transparent;
}

.watch-stat-pill__vote-btn.vote-chip--on.watch-stat-pill__vote-btn--up {
    color: color-mix(in srgb, var(--accent-hot, #fb923c) 92%, #fed7aa);
    background: color-mix(in srgb, var(--accent-hot, #ea580c) 22%, transparent);
}

.watch-stat-pill__vote-btn.vote-chip--on.watch-stat-pill__vote-btn--down {
    color: color-mix(in srgb, var(--accent) 88%, #e2e8f0);
    background: color-mix(in srgb, var(--accent) 24%, transparent);
}

.watch-stat-pill__vote-btn:disabled {
    cursor: not-allowed;
    opacity: 0.38;
}

.watch-stat-pill__vote-btn:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent) 65%, transparent);
    outline-offset: 2px;
}

.watch-stat-pill__chevron {
    flex-shrink: 0;
    pointer-events: none;
    font-size: 0.95rem;
    line-height: 1;
    transition:
        color 0.15s ease,
        transform 0.15s ease,
        filter 0.18s ease;
}

.watch-stat-pill__vote-btn:hover:not(:disabled) .watch-stat-pill__chevron {
    transform: scale(1.14);
}

.watch-stat-pill__vote-btn--up:hover:not(:disabled):not(.vote-chip--on) .watch-stat-pill__chevron {
    color: color-mix(in srgb, #34d399 92%, var(--text-primary));
    filter: drop-shadow(0 0 10px color-mix(in srgb, #34d399 55%, transparent));
}

.watch-stat-pill__vote-btn--down:hover:not(:disabled):not(.vote-chip--on) .watch-stat-pill__chevron {
    color: color-mix(in srgb, #f87171 92%, var(--text-primary));
    filter: drop-shadow(0 0 10px color-mix(in srgb, #f87171 52%, transparent));
}

.watch-stat-pill__vote-btn.vote-chip--on:hover:not(:disabled) .watch-stat-pill__chevron {
    filter: brightness(1.15);
}

.watch-stat-pill__value {
    min-width: 3rem;
    padding: 0 0.32rem;
    text-align: center;
    font-weight: 700;
    font-size: 0.95rem;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
}

.watch-stat-pill__value--zero {
    color: color-mix(in srgb, var(--text-primary) 82%, var(--text-muted));
}

.watch-stat-pill__value--pos {
    color: color-mix(in srgb, #22c55e 88%, var(--text-primary));
}

.watch-stat-pill__value--neg {
    color: color-mix(in srgb, #ef4444 85%, var(--text-primary));
}

.watch-stat-pill--comments {
    gap: 0.42rem;
    padding: 0.28rem 0.55rem;
    cursor: pointer;
    font-family: inherit;
    margin: 0;
}

.watch-stat-pill__comments-count {
    font-weight: 700;
    font-size: 0.95rem;
}

.foreign-watch-ui__scores {
    margin-bottom: 0;
}

.foreign-watch-ui .viewer-card__score {
    align-items: center;
    justify-content: center;
}

.comments-chip-btn:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

.comments-chip-btn {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: inherit;
    font-weight: 700;
    font-size: 0.92rem;
    color: color-mix(in srgb, var(--text-primary) 94%, #f8fafc);
    cursor: pointer;
    transition:
        background 0.15s ease,
        border-color 0.15s ease,
        opacity 0.15s ease,
        box-shadow 0.15s ease;
}

.watch-stat-pill.watch-stat-pill--comments.comments-chip-btn:hover {
    background: color-mix(in srgb, var(--bg-muted) 62%, #fff 5%);
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border-subtle));
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, #fff 7%, transparent),
        0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.watch-stat-pill.watch-stat-pill--comments.comments-chip-btn:hover .comments-chip-btn__icon {
    opacity: 1;
    color: color-mix(in srgb, var(--accent-hot, var(--accent)) 72%, var(--text-primary));
}

.comments-chip-btn:active {
    opacity: 0.92;
}

.comments-chip-btn__icon {
    flex-shrink: 0;
    opacity: 0.92;
    font-size: 1.05rem;
    line-height: 1;
}

.comments-chip-btn__count {
    min-width: 1ch;
    font-variant-numeric: tabular-nums;
}

.comments-modal__lead {
    margin: 0 0 1rem;
    font-size: 0.88rem;
    color: var(--text-muted);
    line-height: 1.4;
}

.comments-modal__status {
    margin: 0 0 0.65rem;
    font-size: 0.82rem;
    color: color-mix(in srgb, var(--accent-hot, var(--accent)) 65%, var(--text-muted));
}

.comments-modal__status.is-hidden {
    display: none;
}

.comments-modal__list {
    max-height: min(42vh, 18rem);
    min-height: 4rem;
    overflow-y: auto;
    margin: 0 0 1rem;
    padding: 0.25rem 0.15rem 0.25rem 0;
    box-sizing: border-box;
    scrollbar-gutter: stable;
}

.comments-modal__loading {
    margin: 0;
    padding: 0.75rem 0;
    font-size: 0.88rem;
    color: var(--text-muted);
    text-align: center;
}

.comments-modal__empty {
    margin: 0;
    padding: 0.85rem 0.35rem;
    font-size: 0.88rem;
    color: var(--text-muted);
    line-height: 1.45;
    text-align: center;
}

.comment-thread-item {
    padding: 0.65rem 0.75rem;
    margin-bottom: 0.5rem;
    border-radius: 12px;
    border: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--bg-muted) 88%, transparent);
}

.comment-thread-item:last-child {
    margin-bottom: 0;
}

.comment-thread-item__meta {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-muted);
    margin-bottom: 0.35rem;
}

.comment-thread-item__body {
    font-size: 0.88rem;
    line-height: 1.45;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.comments-modal__composer {
    margin-bottom: 0.75rem;
}

.comments-modal__textarea {
    margin-bottom: 0.55rem;
}

.comments-modal__composer-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

.comments-modal__footer-actions {
    margin-top: 0;
    justify-content: flex-end;
}

.comments-modal__actions {
    margin-top: 0.75rem;
}

.comments-modal__panel {
    max-width: 26rem;
    width: calc(100vw - 2rem);
}

/* Viewer stub (нижний блок убран; стили viewer-card остаются для панели в recorder-card) */

.viewer-section {
    margin-top: 3rem;
}

.viewer-card {
    display: grid;
    gap: 1.5rem;
    padding: 1.5rem;
}

@media (min-width: 720px) {
    .viewer-card {
        grid-template-columns: 280px 1fr;
        align-items: start;
    }
}

.viewer-card__circle {
    display: flex;
    justify-content: center;
}

.viewer-card__viewport-wrap {
    margin-bottom: 0;
}

.viewer-card__score {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.vote-chip {
    border-radius: var(--radius-full);
    border: 1px solid var(--border-subtle);
    padding: 0.45rem 0.85rem;
    background: var(--bg-muted);
    font-family: inherit;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    opacity: 1;
    color: inherit;
    transition:
        border-color 0.18s ease,
        background 0.18s ease,
        opacity 0.18s ease;
}

.vote-chip:disabled {
    cursor: not-allowed;
    opacity: 0.45;
}

.vote-chip:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent) 65%, transparent);
    outline-offset: 2px;
}

.vote-chip--on {
    border-color: color-mix(in srgb, var(--accent) 55%, var(--border-subtle));
    background: color-mix(in srgb, var(--accent) 18%, var(--bg-muted));
}

.vote-chip--readonly {
    cursor: default;
    opacity: 1;
}

.watch-stat-pill .watch-stat-pill__vote-btn.vote-chip {
    border: none;
    padding: 0;
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
    background: transparent;
}

.watch-stat-pill .watch-stat-pill__vote-btn.vote-chip--on {
    border: none;
}

.field-label {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    margin-bottom: 0.35rem;
    color: var(--text-muted);
}

.input {
    width: 100%;
    box-sizing: border-box;
    border-radius: 14px;
    border: 1px solid var(--border-subtle);
    padding: 0.65rem 0.85rem;
    font-family: inherit;
    font-size: 0.92rem;
    background: var(--bg-page);
    color: inherit;
}

.input.input--error {
    border-color: color-mix(in srgb, #ef4444 60%, var(--border-subtle));
}

.input.textarea {
    resize: vertical;
}

.viewer-card__comment-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.65rem;
    flex-wrap: wrap;
}

/* Auth & account bar */

.top-bar__auth {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.top-bar__profile-menu {
    position: relative;
    flex-shrink: 0;
}

.top-bar__profile-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--top-bar-icon-btn-size);
    height: var(--top-bar-icon-btn-size);
    min-width: var(--top-bar-icon-btn-size);
    min-height: var(--top-bar-icon-btn-size);
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-full);
    background: color-mix(in srgb, var(--bg-muted) 88%, transparent);
    color: var(--text-primary);
    cursor: pointer;
    transition:
        background 0.15s ease,
        border-color 0.15s ease,
        color 0.15s ease;
}

.top-bar__profile-trigger:hover {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border-subtle));
    background: color-mix(in srgb, var(--accent) 12%, var(--bg-muted));
    color: var(--accent);
}

.top-bar__profile-trigger:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
}

.top-bar__profile-trigger[aria-expanded="true"] {
    border-color: color-mix(in srgb, var(--accent) 55%, var(--border-subtle));
    background: color-mix(in srgb, var(--accent) 14%, var(--bg-muted));
    color: var(--accent);
}

.top-bar__profile-trigger-icon {
    font-size: 1.35rem;
    line-height: 1;
}

.top-bar__profile-panel {
    position: absolute;
    top: calc(100% + 0.45rem);
    right: 0;
    z-index: 50;
    width: min(17.5rem, calc(100vw - 2rem));
    padding: 0.85rem 0.95rem 0.95rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-subtle);
    background: var(--bg-elevated);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
}

[data-theme="dark"] .top-bar__profile-panel {
    box-shadow: 0 22px 52px rgba(0, 0, 0, 0.55);
}

.top-bar__profile-panel[hidden] {
    display: none !important;
}

.top-bar__profile-nick {
    margin: 0 0 0.55rem;
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.top-bar__profile-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem 0.65rem;
    margin: 0 0 0.75rem;
    padding: 0 0 0.75rem;
    border-bottom: 1px solid var(--border-subtle);
}

.top-bar__profile-stat {
    margin: 0;
    min-width: 0;
}

.top-bar__profile-stat dt {
    margin: 0;
    font-size: 0.66rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.top-bar__profile-stat dd {
    margin: 0.12rem 0 0;
    font-size: 0.88rem;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.top-bar__profile-actions {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.top-bar__profile-profile-btn {
    width: 100%;
    justify-content: center;
    text-align: center;
    text-decoration: none;
    box-sizing: border-box;
}

.top-bar__profile-logout-form {
    margin: 0;
}

.top-bar__profile-logout-btn {
    width: 100%;
    justify-content: center;
}

.top-bar__user-name {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-muted);
    max-width: 10rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.top-bar__logout-form {
    margin: 0;
}

.auth-hero {
    align-items: center;
}

.auth-card {
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
    padding: 1.5rem clamp(1rem, 4vw, 1.75rem);
}

.auth-card__title {
    margin: 0 0 0.35rem;
    font-size: 1.35rem;
    letter-spacing: -0.02em;
}

.auth-card__lead {
    margin: 0 0 1.25rem;
    font-size: 0.88rem;
    color: var(--text-muted);
    line-height: 1.45;
}

.auth-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.password-field {
    position: relative;
    display: block;
}

.password-field > .input {
    width: 100%;
    padding-right: 2.75rem;
    box-sizing: border-box;
}

.password-toggle {
    position: absolute;
    right: 0.35rem;
    top: 50%;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    padding: 0;
    border: none;
    border-radius: var(--radius-full);
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
}

.password-toggle:hover {
    color: var(--text-primary);
    background: color-mix(in srgb, var(--bg-muted) 85%, transparent);
}

.password-toggle:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

.password-toggle__icon {
    flex-shrink: 0;
    pointer-events: none;
    font-size: 1.05rem;
    line-height: 1;
    width: 1.15em;
    text-align: center;
}

.password-toggle__icon--hide {
    display: none;
}

.password-toggle[aria-pressed="true"] .password-toggle__icon--show {
    display: none;
}

.password-toggle[aria-pressed="true"] .password-toggle__icon--hide {
    display: inline-block;
}

.auth-field__error {
    margin: 0.35rem 0 0;
    font-size: 0.82rem;
    color: color-mix(in srgb, #ef4444 85%, var(--text-primary));
}

.auth-field__error--block {
    margin-bottom: 0.25rem;
}

.auth-field__hint {
    margin: 0.35rem 0 0;
    font-size: 0.82rem;
    color: var(--text-muted);
    line-height: 1.4;
}

.auth-register-password-toggle {
    align-self: flex-start;
    margin: -0.25rem 0 0;
    padding: 0.35rem 0.6rem;
    font-size: 0.875rem;
}

.auth-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.88rem;
    color: var(--text-muted);
    cursor: pointer;
    user-select: none;
}

.auth-check input {
    accent-color: var(--accent);
}

.auth-form__submit {
    margin-top: 0.25rem;
}

.auth-card__footer {
    margin: 1.25rem 0 0;
    font-size: 0.88rem;
    color: var(--text-muted);
    text-align: center;
}

.auth-card__link {
    color: var(--accent);
    font-weight: 600;
    text-decoration: none;
}

.auth-card__link:hover {
    text-decoration: underline;
}

/* Mobile layout — после базовых правил, чтобы перекрывать desktop */
@media (max-width: 520px) {
    .site-main {
        padding-top: 1.25rem;
        padding-inline: max(1rem, env(safe-area-inset-left)) max(1rem, env(safe-area-inset-right));
        padding-bottom: max(2rem, calc(1.25rem + env(safe-area-inset-bottom)));
    }

    .hero--solo {
        min-height: unset;
        padding-block: 0.75rem 1rem;
        align-items: flex-start;
    }

    .recorder-panel.card-glow,
    .foreign-watch-panel.card-glow {
        padding: 1rem max(0.85rem, env(safe-area-inset-left)) 1rem max(0.85rem, env(safe-area-inset-right));
    }

    .recorder-card__toolbar {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: stretch;
        gap: 0.55rem;
    }

    .recorder-card__toolbar > .btn {
        width: 100%;
        min-height: 48px;
        justify-content: center;
        box-sizing: border-box;
    }

    .recorder-post-actions__btn {
        min-height: 48px;
    }

    .studio-watch-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .studio-watch-actions .btn {
        width: 100%;
        min-height: 48px;
        justify-content: center;
        box-sizing: border-box;
    }

    .studio-record-bridge .btn {
        width: 100%;
        min-height: 48px;
        justify-content: center;
        box-sizing: border-box;
    }

    .recorder-card__hint {
        font-size: 0.82rem;
        padding-inline: 0.25rem;
        line-height: 1.45;
    }

    .overlay__panel {
        padding: 1.5rem max(1.25rem, env(safe-area-inset-left)) 1.5rem max(1.25rem, env(safe-area-inset-right));
    }

    .overlay__title {
        font-size: clamp(1.2rem, 5vw, 1.45rem);
    }

    .viewer-card {
        padding: 1rem max(0.75rem, env(safe-area-inset-left)) 1rem max(0.75rem, env(safe-area-inset-right));
    }

    .viewer-section {
        margin-top: 2rem;
    }

    .top-bar__auth .btn--sm {
        min-height: 44px;
        padding-inline: 0.75rem;
    }

    .top-bar__link {
        padding: 0.5rem 0.65rem;
        font-size: 0.85rem;
        min-height: 44px;
        box-sizing: border-box;
        display: inline-flex;
        align-items: center;
        touch-action: manipulation;
    }

    .auth-card {
        padding: 1.25rem max(1rem, env(safe-area-inset-left)) 1.25rem max(1rem, env(safe-area-inset-right));
    }

    .auth-card__title {
        font-size: clamp(1.2rem, 5vw, 1.35rem);
    }

    .auth-form__submit {
        min-height: 48px;
    }

    .input,
    .input.textarea {
        font-size: 16px;
    }

    .intro-modal__panel {
        padding-left: max(1.25rem, env(safe-area-inset-left));
        padding-right: max(1.25rem, env(safe-area-inset-right));
    }
}

/* Тёмная тема: слои без видимых рамок, голубые акценты */
[data-theme="dark"] .top-bar {
    border-bottom: none;
    background: color-mix(in srgb, var(--bg-elevated) 94%, transparent);
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.42);
}

[data-theme="dark"] .theme-toggle {
    border: none;
    background: var(--bg-muted);
}

[data-theme="dark"] .theme-toggle:hover {
    background: var(--bg-interactive);
}

[data-theme="dark"] .mobile-menu-trigger {
    border: none;
    background: var(--bg-muted);
}

[data-theme="dark"] .mobile-menu-trigger:hover {
    background: var(--bg-interactive);
}

[data-theme="dark"] .mobile-menu-trigger.is-open {
    background: color-mix(in srgb, var(--accent) 18%, var(--bg-muted));
}

[data-theme="dark"] .site-footer {
    border-top: none;
    background: color-mix(in srgb, var(--bg-page) 55%, var(--bg-elevated));
}

[data-theme="dark"] .site-footer__bottom {
    border-top-color: color-mix(in srgb, var(--border-subtle) 70%, transparent);
}

[data-theme="dark"] .site-footer__social-link {
    background: color-mix(in srgb, var(--bg-muted) 78%, transparent);
}

[data-theme="dark"] .card-glow {
    border: none;
    background: var(--bg-elevated);
    box-shadow: var(--shadow-lg);
}

[data-theme="dark"] .foreign-watch-panel__viewport,
[data-theme="dark"] .recorder-card__viewport {
    border: none;
    box-shadow:
        0 20px 52px rgba(0, 0, 0, 0.52),
        inset 0 0 64px color-mix(in srgb, var(--accent-soft) 95%, transparent);
}

[data-theme="dark"] .foreign-watch-ui.foreign-watch-ui--show {
    border-top: none;
}

[data-theme="dark"] .watch-stat-pill {
    border: none;
    background: var(--bg-muted);
    box-shadow: none;
}

[data-theme="dark"] .watch-stat-pill__vote-btn:hover:not(:disabled) {
    background: var(--bg-interactive);
}

[data-theme="dark"] .watch-stat-pill__vote-btn.vote-chip--on.watch-stat-pill__vote-btn--up,
[data-theme="dark"] .watch-stat-pill__vote-btn.vote-chip--on.watch-stat-pill__vote-btn--down {
    color: var(--accent-hot);
    background: color-mix(in srgb, var(--accent) 28%, var(--bg-interactive-strong));
}

[data-theme="dark"] .watch-stat-pill.watch-stat-pill--comments.comments-chip-btn:hover {
    background: var(--bg-interactive);
    border: none;
    box-shadow: none;
}

[data-theme="dark"] .watch-stat-pill.watch-stat-pill--comments.comments-chip-btn:hover .comments-chip-btn__icon {
    color: var(--accent-hot);
}

[data-theme="dark"] .btn--ghost {
    border-color: transparent;
    background: var(--bg-muted);
}

[data-theme="dark"] .btn--ghost:hover:not(:disabled) {
    background: var(--bg-interactive);
}

[data-theme="dark"] .telegram-auth__btn {
    border-color: transparent;
    background: color-mix(in srgb, #229ed9 18%, var(--bg-muted));
    color: color-mix(in srgb, #7dd3fc 82%, var(--text-primary));
}

[data-theme="dark"] .preview-mirror-btn {
    border: none;
    box-shadow: 0 12px 34px color-mix(in srgb, var(--accent) 38%, transparent);
}

[data-theme="dark"] .preview-mirror-btn:hover {
    border-color: transparent;
    box-shadow: 0 16px 42px color-mix(in srgb, var(--accent) 46%, transparent);
}

[data-theme="dark"] .preview-mirror-btn[aria-pressed="false"] {
    border-color: transparent;
    background: var(--bg-interactive-strong);
    color: color-mix(in srgb, var(--text-primary) 88%, var(--accent-hot));
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
}

[data-theme="dark"] .recorder-placeholder__ring {
    border: none;
    box-shadow: none;
    background: radial-gradient(
        circle at 50% 50%,
        color-mix(in srgb, var(--accent) 26%, transparent) 0%,
        transparent 70%
    );
}

[data-theme="dark"] .recorder-placeholder__hint {
    color: color-mix(in srgb, var(--text-muted) 82%, var(--accent-hot));
}

[data-theme="dark"] .circle-ended-overlay__replay {
    border: none;
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.48);
}

[data-theme="dark"] .circle-picker-loading__spinner {
    border-width: 3px;
    border-color: color-mix(in srgb, var(--accent) 22%, var(--bg-muted));
    border-top-color: color-mix(in srgb, var(--accent-hot) 92%, #fff);
}

[data-theme="dark"] .overlay__backdrop {
    background: rgba(5, 8, 11, 0.74);
}

[data-theme="dark"] .intro-modal__backdrop {
    background: rgba(5, 8, 11, 0.82);
}

[data-theme="dark"] .input {
    border-color: transparent;
    background: var(--bg-muted);
}

[data-theme="dark"] .input.input--error {
    border-color: transparent;
    background: color-mix(in srgb, #f87171 11%, var(--bg-muted));
}

[data-theme="dark"] .input:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 28%, transparent);
}

[data-theme="dark"] .input.input--error:focus-visible {
    box-shadow: 0 0 0 3px color-mix(in srgb, #f87171 35%, transparent);
}

[data-theme="dark"] .comment-thread-item {
    border: none;
    background: var(--bg-muted);
}

[data-theme="dark"] .vote-chip {
    border-color: transparent;
    background: var(--bg-muted);
}

[data-theme="dark"] .vote-chip:hover:not(:disabled) {
    background: var(--bg-interactive);
}

/* Анонимный чат */

@keyframes anon-phase-rise {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes anon-msg-rise {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes anon-divider-fade {
    from {
        opacity: 0;
        transform: scaleX(0.94);
    }
    to {
        opacity: 1;
        transform: scaleX(1);
    }
}

@keyframes anon-spin-smooth {
    to {
        transform: rotate(360deg);
    }
}

@keyframes anon-backdrop-in {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes anon-modal-rise {
    from {
        opacity: 0;
        transform: translateY(14px) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@media (prefers-reduced-motion: reduce) {
    .anon-chat-phase-pop,
    .anon-msg-row,
    .anon-msg-divider--enter,
    .anon-chat-rules-modal--open:not(.is-hidden) .intro-modal__backdrop,
    .anon-chat-rules-modal--open:not(.is-hidden) .anon-chat-rules-modal__panel,
    .anon-chat-search__spinner {
        animation: none !important;
    }
}

html[data-spam-anon-locked="true"] #anon-chat-send,
html[data-spam-anon-locked="true"] #anon-chat-input,
html[data-spam-anon-locked="true"] #anon-chat-open-rules,
html[data-spam-anon-locked="true"] #anon-chat-rules-confirm,
html[data-spam-anon-locked="true"] #anon-chat-cancel-search,
html[data-spam-anon-locked="true"] #anon-chat-new-same,
html[data-spam-anon-locked="true"] #anon-chat-end,
html[data-spam-anon-voice-locked="true"] #anon-voice-open-rules,
html[data-spam-anon-voice-locked="true"] #anon-voice-rules-confirm,
html[data-spam-anon-voice-locked="true"] #anon-voice-cancel-search,
html[data-spam-anon-voice-locked="true"] #anon-voice-new-same,
html[data-spam-anon-voice-locked="true"] #anon-voice-end,
html[data-spam-anon-voice-locked="true"] #anon-voice-end-header {
    pointer-events: none;
    opacity: 0.52;
}

.anon-chat-spam-hint {
    margin: -0.35rem 0 1rem;
    padding: 0.45rem 0.65rem;
    border-radius: var(--radius-lg);
    font-size: 0.82rem;
    line-height: 1.35;
    background: color-mix(in srgb, var(--accent) 14%, var(--bg-muted));
    border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
    color: color-mix(in srgb, var(--text-primary) 88%, var(--accent-hot));
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-phase-pop {
    animation: anon-phase-rise 0.42s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.anon-chat-rules-modal--open:not(.is-hidden) .intro-modal__backdrop {
    animation: anon-backdrop-in 0.26s ease both;
}

.anon-chat-rules-modal--open:not(.is-hidden) .anon-chat-rules-modal__panel {
    animation: anon-modal-rise 0.4s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.site-main:has(#anon-chat-app),
.site-main:has(#anon-voice-app) {
    flex: 1;
    min-height: 0;
    padding-top: 1rem;
    padding-inline: max(1rem, env(safe-area-inset-left)) max(1rem, env(safe-area-inset-right));
    padding-bottom: max(1.35rem, env(safe-area-inset-bottom));
}

@media (max-width: 520px) {
    .site-main:has(#anon-chat-app),
    .site-main:has(#anon-voice-app) {
        padding-top: 0.45rem;
        padding-inline: max(0.45rem, env(safe-area-inset-left)) max(0.45rem, env(safe-area-inset-right));
        padding-bottom: max(0.55rem, calc(0.35rem + env(safe-area-inset-bottom)));
    }
}

.anon-chat {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
    width: 100%;
    max-width: 42rem;
    margin-inline: auto;
    padding: 0.35rem clamp(0.45rem, 3vw, 1rem) 1rem;
}

.anon-chat__panel.card-glow {
    box-sizing: border-box;
    width: 100%;
    padding:
        clamp(1.05rem, 3.5vw, 1.65rem)
        clamp(0.85rem, 3.5vw, 1.5rem)
        clamp(1.2rem, 4vw, 1.95rem);
}

.anon-chat__title {
    margin: 0 0 0.45rem;
    font-size: clamp(1.35rem, 4vw, 1.65rem);
    letter-spacing: -0.03em;
}

.anon-chat__subtitle {
    margin: 0 0 1.5rem;
    font-size: 0.92rem;
    line-height: 1.45;
    color: var(--text-muted);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-form {
    display: flex;
    flex-direction: column;
    gap: 1.45rem;
}

.anon-chat-fieldset {
    margin: 0;
    padding: 0;
    border: none;
    min-width: 0;
}

.anon-chat-legend {
    padding: 0;
    margin: 0 0 0.7rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: color-mix(in srgb, var(--text-muted) 84%, var(--text-primary));
}

.anon-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.anon-multi-hint {
    margin: 0 0 0.55rem;
    font-size: 0.8rem;
    line-height: 1.38;
    color: color-mix(in srgb, var(--text-muted) 88%, var(--text-primary));
}

.anon-chip-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin: 0 0 0.45rem;
}

.anon-chip-toolbar__btn {
    padding: 0.28rem 0.55rem;
    border-radius: var(--radius-full);
    border: 1px solid var(--border-subtle);
    background: transparent;
    font-size: 0.76rem;
    font-weight: 500;
    font-family: inherit;
    color: var(--text-muted);
    cursor: pointer;
    transition:
        border-color 0.15s ease,
        color 0.15s ease,
        background 0.15s ease;
}

.anon-chip-toolbar__btn:hover {
    border-color: color-mix(in srgb, var(--accent) 45%, var(--border-subtle));
    color: var(--text-primary);
    background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.anon-chat-rules__block + .anon-chat-rules__block {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-subtle);
}

.anon-chip-row--narrow {
    max-width: 22rem;
}

.anon-chip {
    flex: 1 1 auto;
    cursor: pointer;
    border-radius: var(--radius-full);
}

.anon-chip input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.anon-chip span {
    display: block;
    text-align: center;
    padding: 0.55rem 0.65rem;
    border-radius: var(--radius-full);
    font-size: 0.84rem;
    font-weight: 500;
    border: 1px solid var(--border-subtle);
    background: var(--bg-muted);
    color: var(--text-primary);
    overflow-wrap: anywhere;
    word-break: break-word;
    transition:
        background 0.18s cubic-bezier(0.22, 1, 0.36, 1),
        border-color 0.18s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.14s ease,
        box-shadow 0.18s ease;
}

.anon-chip:active span {
    transform: scale(0.98);
}

.anon-chip input:checked + span {
    border-color: color-mix(in srgb, var(--accent) 55%, transparent);
    background: color-mix(in srgb, var(--accent) 22%, var(--bg-muted));
    box-shadow: 0 6px 18px color-mix(in srgb, var(--accent) 14%, transparent);
}

.anon-chat-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem 1.25rem;
}

@media (max-width: 620px) {
    .anon-chat-columns {
        grid-template-columns: 1fr;
    }

    /* Возраст: две колонки кнопок вместо длинной простыни — та же разметка и name/value радиокнопок */
    .anon-chat-columns--age {
        gap: 0.65rem;
    }

    .anon-chat-columns--age .anon-chat-legend {
        font-size: 0.76rem;
        margin-bottom: 0.42rem;
    }

    .anon-chat-columns--age .anon-age-stack {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.38rem;
    }

    .anon-chat-columns--age .anon-age-btn span {
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: center;
        min-height: 2.35rem;
        padding: 0.38rem 0.35rem;
        font-size: 0.68rem;
        line-height: 1.2;
        border-radius: var(--radius-lg);
        hyphens: auto;
        overflow-wrap: anywhere;
        word-break: break-word;
    }
}

@media (max-width: 360px) {
    .anon-chat-columns--age .anon-age-btn span {
        font-size: 0.64rem;
        padding: 0.34rem 0.28rem;
        min-height: 2.2rem;
    }
}

.anon-segment {
    display: flex;
    border-radius: var(--radius-full);
    overflow: hidden;
    border: 1px solid var(--border-subtle);
}

.anon-segment__item {
    flex: 1 1 0;
    cursor: pointer;
    text-align: center;
}

.anon-segment__item input {
    position: absolute;
    opacity: 0;
}

.anon-segment__item span {
    display: block;
    padding: 0.5rem 0.35rem;
    font-size: 0.78rem;
    font-weight: 600;
    background: var(--bg-muted);
    transition: background 0.18s cubic-bezier(0.22, 1, 0.36, 1);
}

.anon-segment__item input:checked + span {
    background: color-mix(in srgb, var(--accent) 24%, var(--bg-muted));
}

.anon-age-stack {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.anon-age-btn {
    cursor: pointer;
}

.anon-age-btn input {
    position: absolute;
    opacity: 0;
}

.anon-age-btn span {
    display: block;
    padding: 0.5rem 0.65rem;
    border-radius: var(--radius-lg);
    font-size: 0.76rem;
    border: 1px solid var(--border-subtle);
    background: var(--bg-muted);
    overflow-wrap: anywhere;
    word-break: break-word;
    transition:
        background 0.18s cubic-bezier(0.22, 1, 0.36, 1),
        border-color 0.18s ease,
        transform 0.14s ease;
}

.anon-age-btn:active span {
    transform: scale(0.99);
}

.anon-age-btn input:checked + span {
    border-color: color-mix(in srgb, var(--accent) 45%, transparent);
    background: color-mix(in srgb, var(--accent) 14%, var(--bg-muted));
}

.anon-chat__cta {
    margin-top: 0.5rem;
    border-radius: var(--radius-full);
    align-self: stretch;
}

.anon-chat-error {
    margin: 0;
    font-size: 0.86rem;
    color: #dc2626;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-rules-modal.intro-modal {
    z-index: 160;
}

.anon-chat-rules-modal__panel {
    position: relative;
    max-width: 460px;
}

.anon-chat-rules-modal__close {
    position: absolute;
    top: 0.65rem;
    right: 0.85rem;
    border: none;
    background: transparent;
    font-size: 1.65rem;
    line-height: 1;
    cursor: pointer;
    color: var(--text-muted);
}

.anon-chat-rules-modal__title {
    padding-right: 2rem;
}

.anon-chat-rules-modal .intro-modal__body {
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-rules__intro {
    margin: 0 0 0.65rem;
    font-size: 0.92rem;
    line-height: 1.45;
    color: var(--text-muted);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-rules__sub {
    margin: 0 0 0.35rem;
    font-weight: 600;
    font-size: 0.88rem;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-rules__list {
    margin: 0;
    padding-left: 1.1rem;
    font-size: 0.84rem;
    line-height: 1.45;
    color: color-mix(in srgb, var(--text-muted) 92%, var(--text-primary));
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-rules__list li + li {
    margin-top: 0.35rem;
}

.anon-chat-search__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    padding: 1.35rem 0.35rem;
    text-align: center;
}

.anon-chat-search__spinner {
    font-size: 2rem;
    color: color-mix(in srgb, var(--accent) 55%, var(--text-muted));
    animation: anon-spin-smooth 0.85s linear infinite;
}

.anon-chat-search__status {
    margin: 0;
    font-weight: 600;
    font-size: 1rem;
    overflow-wrap: anywhere;
    word-break: break-word;
    padding-inline: 0.35rem;
}

.anon-chat-search__cancel {
    border-radius: var(--radius-full);
}

.anon-chat-room {
    display: flex;
    flex-direction: column;
    gap: 0.42rem;
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
}

.anon-chat-room .card-glow {
    border-radius: var(--radius-xl);
}

@media (max-width: 520px) {
    .anon-chat-room {
        gap: 0.35rem;
    }
}

.anon-chat-room__header {
    flex-shrink: 0;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem;
    padding: 0.48rem 0.62rem;
    border: 1px solid color-mix(in srgb, var(--text-primary) 6%, transparent);
}

[data-theme="dark"] .anon-chat-room__header {
    border-color: color-mix(in srgb, var(--accent) 16%, transparent);
}

.anon-chat-room__headline {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    min-width: 0;
    flex: 1 1 auto;
}

.anon-chat-room__title {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.25;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.anon-chat-room__report {
    flex-shrink: 0;
    border: none;
    background: color-mix(in srgb, #ef4444 12%, transparent);
    color: #dc2626;
    cursor: pointer;
    padding: 0.28rem 0.4rem;
    font-size: 0.92rem;
    border-radius: var(--radius-full);
    transition:
        background 0.18s ease,
        color 0.18s ease,
        transform 0.14s ease;
}

.anon-chat-room__report:hover {
    background: color-mix(in srgb, #ef4444 22%, transparent);
    color: #b91c1c;
}

.anon-chat-room__report:active {
    transform: scale(0.94);
}

[data-theme="dark"] .anon-chat-room__report {
    background: color-mix(in srgb, #f87171 14%, transparent);
    color: #fca5a5;
}

[data-theme="dark"] .anon-chat-room__report:hover {
    background: color-mix(in srgb, #f87171 26%, transparent);
    color: #fecaca;
}

.anon-chat-room__end {
    border-radius: var(--radius-full);
    flex-shrink: 0;
}

.anon-chat-room__end--compact {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.4rem;
    height: 2.4rem;
    min-height: 2.4rem;
    padding: 0;
    font-size: 1.05rem;
    line-height: 1;
}

.anon-chat-room__end--compact.btn {
    padding: 0;
    line-height: 1;
}

.anon-chat-room__messages {
    flex: 1 1 auto;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: 0.38rem 0.45rem;
    border-radius: var(--radius-xl);
    background: color-mix(in srgb, var(--bg-muted) 88%, transparent);
    border: 1px solid color-mix(in srgb, var(--text-primary) 6%, transparent);
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}

[data-theme="dark"] .anon-chat-room__messages {
    background: color-mix(in srgb, var(--bg-muted) 72%, var(--bg-page));
    border-color: color-mix(in srgb, var(--accent) 16%, transparent);
}

.anon-msg-divider {
    text-align: center;
    font-size: 0.72rem;
    color: var(--text-muted);
    margin: 0.65rem 0;
    overflow-wrap: anywhere;
    word-break: break-word;
    padding-inline: 0.25rem;
}

.anon-msg-divider--enter {
    animation: anon-divider-fade 0.45s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.anon-msg-row {
    display: flex;
    align-items: flex-end;
    gap: 0.45rem;
    margin-bottom: 0.55rem;
    min-width: 0;
    animation: anon-msg-rise 0.38s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.anon-msg-row--mine {
    flex-direction: row-reverse;
}

.anon-msg-avatar {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border-radius: var(--radius-full);
    font-size: 0.62rem;
    font-weight: 700;
    display: grid;
    place-items: center;
    background: var(--bg-interactive-strong);
    border: 1px solid var(--border-subtle);
}

.anon-msg-row--mine .anon-msg-avatar {
    font-size: 0.58rem;
}

.anon-msg-bubble {
    box-sizing: border-box;
    max-width: min(82%, 26rem);
    min-width: 0;
    padding: 0.52rem 0.72rem;
    border-radius: 16px;
    font-size: 0.88rem;
    line-height: 1.38;
    background: var(--bg-elevated);
    border: 1px solid color-mix(in srgb, var(--text-primary) 8%, transparent);
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: pre-wrap;
    transition:
        border-color 0.18s ease,
        box-shadow 0.22s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.18s ease;
}

[data-theme="dark"] .anon-msg-bubble {
    border-color: color-mix(in srgb, var(--accent) 14%, transparent);
}

.anon-msg-row--mine .anon-msg-bubble {
    border-color: color-mix(in srgb, var(--accent) 36%, transparent);
    background: color-mix(in srgb, var(--accent) 12%, var(--bg-elevated));
}

.anon-msg-time {
    font-size: 0.68rem;
    color: var(--text-muted);
    flex-shrink: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-room__composer {
    flex-shrink: 0;
    padding: 0;
    margin: 0;
    background: none;
    border: none;
}

.anon-chat-composer {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.anon-chat-composer__shell {
    display: flex;
    align-items: center;
    gap: 0.32rem;
    padding: 0.2rem 0.25rem 0.2rem 0.68rem;
    border-radius: var(--radius-xl);
    background: color-mix(in srgb, var(--bg-muted) 40%, var(--bg-elevated));
    border: 1px solid color-mix(in srgb, var(--accent) 12%, var(--border-subtle));
    box-shadow: 0 1px 3px color-mix(in srgb, var(--text-primary) 5%, transparent);
    min-width: 0;
    transition:
        border-color 0.18s ease,
        box-shadow 0.18s ease;
}

[data-theme="dark"] .anon-chat-composer__shell {
    background: color-mix(in srgb, var(--bg-muted) 55%, var(--bg-elevated));
    border-color: color-mix(in srgb, var(--accent) 22%, var(--bg-muted));
    box-shadow: none;
}

.anon-chat-composer__shell:focus-within {
    border-color: color-mix(in srgb, var(--accent) 40%, transparent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 18%, transparent);
}

[data-theme="dark"] .anon-chat-composer__shell:focus-within {
    border-color: color-mix(in srgb, var(--accent) 48%, transparent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 12%, transparent);
}

.anon-chat-composer__input {
    flex: 1 1 auto;
    min-width: 0;
    margin: 0;
    padding: 0.38rem 0;
    min-height: 2.3rem;
    max-height: 8rem;
    resize: none;
    overflow-y: auto;
    overflow-wrap: anywhere;
    word-break: break-word;
    border: none;
    background: transparent;
    font: inherit;
    font-size: 0.93rem;
    line-height: 1.4;
    color: var(--text-primary);
    field-sizing: content;
}

.anon-chat-composer__input::placeholder {
    color: color-mix(in srgb, var(--text-muted) 82%, transparent);
}

.anon-chat-composer__input:focus {
    outline: none;
}

.anon-chat-composer__input::-webkit-scrollbar {
    width: 4px;
}

.anon-chat-composer__input::-webkit-scrollbar-thumb {
    border-radius: 99px;
    background: color-mix(in srgb, var(--text-muted) 35%, transparent);
}

.anon-chat-composer__send {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.32rem;
    height: 2.32rem;
    min-height: 2.32rem;
    padding: 0;
    border-radius: var(--radius-full);
    cursor: pointer;
    color: #fff;
    background: linear-gradient(
        155deg,
        color-mix(in srgb, var(--accent) 74%, #06364c),
        var(--accent-hot)
    );
    border: none;
    box-shadow: 0 1px 2px color-mix(in srgb, var(--text-primary) 14%, transparent);
    transition:
        transform 0.12s ease,
        filter 0.15s ease;
}

[data-theme="dark"] .anon-chat-composer__send {
    background: linear-gradient(
        155deg,
        color-mix(in srgb, var(--accent) 48%, #0a2740),
        color-mix(in srgb, var(--accent-hot) 86%, #fff)
    );
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
}

.anon-chat-composer__send:hover {
    filter: brightness(1.08);
}

.anon-chat-composer__send:active {
    transform: scale(0.96);
}

.anon-chat-composer__send:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent) 58%, transparent);
    outline-offset: 2px;
}

.anon-chat-composer__send-icon {
    font-size: 0.88rem;
}

.anon-chat-ended {
    padding: 0;
    text-align: center;
}

.anon-chat-ended__title {
    margin: 0 0 0.65rem;
    font-weight: 700;
    font-size: 1.05rem;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-ended__hint {
    margin: 0 0 1rem;
    font-size: 0.88rem;
    color: var(--text-muted);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.anon-chat-ended__fake-link {
    border: none;
    background: none;
    padding: 0;
    cursor: pointer;
    color: color-mix(in srgb, var(--accent) 65%, var(--text-muted));
    text-decoration: underline;
    font-size: inherit;
}

.anon-chat-ended__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    justify-content: center;
}

.anon-chat-ended__new {
    border-radius: var(--radius-full);
    border: 2px solid color-mix(in srgb, #22c55e 85%, var(--accent-hot));
    color: color-mix(in srgb, #22c55e 92%, var(--accent-hot));
    background: transparent;
    padding: 0.45rem 1rem;
    font-weight: 600;
    cursor: pointer;
}

[data-theme="dark"] .anon-chat-ended__new {
    border-color: #4ade80;
    color: #4ade80;
}

.anon-voice-room .anon-chat-room__messages {
    display: none;
}

.anon-voice-room .anon-chat-room__composer {
    display: none;
}

.anon-voice-call {
    margin-top: 0.55rem;
    padding:
        clamp(1.35rem, 5vw, 2rem) clamp(1rem, 4vw, 1.35rem) clamp(1.25rem, 4vw, 1.65rem);
    border-radius: 1.85rem;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--bg-elevated) 92%, var(--accent-soft)) 0%,
            var(--bg-elevated) 42%,
            color-mix(in srgb, var(--bg-muted) 82%, var(--accent-soft)) 100%
        );
    border: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-lg);
    color: var(--text-primary);
    --av-wave-rgb-a: 34, 118, 210;
    --av-wave-rgb-b: 52, 183, 241;
    --av-wave-rgb-hi: 214, 232, 247;
    --av-vol-fill-start: color-mix(in srgb, var(--accent) 78%, #2563eb);
    --av-vol-fill-end: color-mix(in srgb, var(--accent-hot) 55%, #6366f1);
    --av-vol-track: color-mix(in srgb, var(--text-muted) 32%, var(--bg-muted));
}

[data-theme="dark"] .anon-voice-call {
    background: linear-gradient(180deg, #1e2d4a 0%, #121a2e 42%, #070b14 100%);
    border: none;
    box-shadow: none;
    color: #fff;
    --av-wave-rgb-a: 86, 185, 255;
    --av-wave-rgb-b: 135, 206, 255;
    --av-wave-rgb-hi: 255, 255, 255;
    --av-vol-fill-start: #4f8cff;
    --av-vol-fill-end: #7c3aed;
    --av-vol-track: #454f63;
}

.anon-voice-call__status {
    margin: 0 0 clamp(1rem, 4vw, 1.35rem);
    font-weight: 500;
    font-size: clamp(0.92rem, 2.6vw, 1rem);
    line-height: 1.35;
    color: var(--text-primary);
    text-align: center;
    letter-spacing: 0.01em;
}

[data-theme="dark"] .anon-voice-call__status {
    color: rgba(255, 255, 255, 0.92);
}

.anon-voice-call__audio {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.anon-voice-call__stage {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: clamp(0.85rem, 3vw, 1.15rem);
    margin-bottom: clamp(1rem, 4vw, 1.35rem);
}

.anon-voice-peer-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.55rem;
}

.anon-voice-peer-caption {
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--text-muted);
    letter-spacing: 0.03em;
}

[data-theme="dark"] .anon-voice-peer-caption {
    color: rgba(255, 255, 255, 0.88);
}

.anon-voice-avatar {
    position: relative;
    width: clamp(5.25rem, 22vw, 6.75rem);
    height: clamp(5.25rem, 22vw, 6.75rem);
    border-radius: 50%;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 35% 28%, color-mix(in srgb, var(--accent-soft) 95%, transparent), transparent 52%),
        radial-gradient(circle at 70% 75%, color-mix(in srgb, var(--accent) 42%, var(--bg-muted)), var(--bg-muted));
    color: var(--text-primary);
    border: 3px solid color-mix(in srgb, var(--accent) 35%, var(--border-subtle));
    box-shadow:
        0 12px 32px color-mix(in srgb, var(--text-primary) 10%, transparent),
        inset 0 1px 0 color-mix(in srgb, var(--bg-elevated) 65%, transparent);
    transition:
        border-color 0.3s ease,
        box-shadow 0.3s ease,
        transform 0.3s ease;
}

[data-theme="dark"] .anon-voice-avatar {
    background:
        radial-gradient(circle at 35% 28%, rgba(120, 170, 255, 0.45), transparent 50%),
        radial-gradient(circle at 70% 75%, rgba(30, 58, 138, 0.9), #0f172a);
    color: rgba(255, 255, 255, 0.96);
    border: 3px solid rgba(255, 255, 255, 0.28);
    box-shadow:
        0 14px 36px rgba(0, 0, 0, 0.45),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.anon-voice-avatar--solo.anon-voice-avatar--speaking {
    border-color: rgba(52, 211, 153, 0.95);
    box-shadow:
        0 0 0 4px rgba(16, 185, 129, 0.26),
        0 12px 28px color-mix(in srgb, var(--text-primary) 12%, transparent),
        inset 0 1px 0 color-mix(in srgb, var(--bg-elevated) 65%, transparent);
    transform: scale(1.02);
}

[data-theme="dark"] .anon-voice-avatar--solo.anon-voice-avatar--speaking {
    box-shadow:
        0 0 0 4px rgba(16, 185, 129, 0.32),
        0 14px 36px rgba(0, 0, 0, 0.45),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.anon-voice-avatar--solo {
    width: clamp(7rem, 34vw, 8.75rem);
    height: clamp(7rem, 34vw, 8.75rem);
}

.anon-voice-avatar--solo .anon-voice-avatar__glyph {
    font-size: clamp(2.65rem, 12vw, 3.35rem);
}

.anon-voice-avatar__glyph {
    font-size: clamp(2rem, 8vw, 2.65rem);
    font-weight: 600;
    line-height: 1;
    text-shadow: 0 1px 12px color-mix(in srgb, var(--accent) 35%, transparent);
}

[data-theme="dark"] .anon-voice-avatar__glyph {
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.4);
}

.anon-voice-wave-wrap {
    margin-inline: auto;
    width: 100%;
    max-width: 17.5rem;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
    overflow: visible;
}

.anon-voice-wave-inner {
    overflow: hidden;
    border-radius: 999px;
    width: 100%;
    min-width: 0;
}

.anon-voice-wave {
    display: block;
    width: 100%;
    height: 64px;
}

.anon-voice-toolbar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1.15rem;
}

.anon-voice-toolbar__circles {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: clamp(2.5rem, 14vw, 3.75rem);
    width: 100%;
    max-width: 20rem;
    margin-inline: auto;
}

.anon-voice-toolbar__circle-slot {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 0;
}

.anon-voice-circle-btn {
    width: 4.65rem;
    height: 4.65rem;
    border-radius: 50%;
    border: none;
    display: grid;
    place-items: center;
    cursor: pointer;
    font-size: 1.35rem;
    transition:
        transform 0.18s ease,
        filter 0.18s ease,
        box-shadow 0.22s ease;
    box-shadow:
        0 10px 24px color-mix(in srgb, var(--text-primary) 14%, transparent),
        inset 0 1px 0 color-mix(in srgb, var(--bg-elevated) 72%, transparent);
}

[data-theme="dark"] .anon-voice-circle-btn {
    box-shadow:
        0 12px 28px rgba(0, 0, 0, 0.35),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.anon-voice-circle-btn:active {
    transform: scale(0.94);
}

.anon-voice-circle-btn:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
}

.anon-voice-circle-btn--mute {
    position: relative;
    background: linear-gradient(165deg, #eef2f7 0%, #dce4ee 100%);
    color: #1e293b;
}

[data-theme="dark"] .anon-voice-circle-btn--mute {
    background: linear-gradient(165deg, #3d4558 0%, #2a3142 100%);
    color: #fff;
}

.anon-voice-mic-led {
    position: absolute;
    top: 12%;
    right: 14%;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #34d399;
    box-shadow:
        0 0 10px rgba(52, 211, 153, 0.95),
        0 0 4px rgba(52, 211, 153, 0.85);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.anon-voice-circle-btn--mute:not(.anon-voice-circle-btn--muted) .anon-voice-mic-led {
    opacity: 1;
}

.anon-voice-circle-btn--mute:hover {
    filter: brightness(1.06);
}

.anon-voice-circle-btn--mute.anon-voice-circle-btn--muted {
    background: linear-gradient(165deg, #cbd5e1 0%, #94a3b8 100%);
    color: #334155;
}

[data-theme="dark"] .anon-voice-circle-btn--mute.anon-voice-circle-btn--muted {
    background: linear-gradient(165deg, #5c5360 0%, #3f3845 100%);
    color: #fff;
}

.anon-voice-circle-btn--mute.anon-voice-circle-btn--muted .anon-voice-mic-led {
    opacity: 0;
}

.anon-voice-circle-btn--hangup {
    background: linear-gradient(165deg, #ff5c7a 0%, #ff2d46 55%, #e11d48 100%);
    color: #fff;
    font-size: 1.42rem;
}

.anon-voice-circle-btn--hangup:hover {
    filter: brightness(1.05);
}

.anon-voice-volume-strip {
    width: 100%;
    max-width: 20rem;
    margin-inline: auto;
    padding: 0;
}

.anon-voice-volume-slider {
    display: block;
    width: 100%;
    height: 1.5rem;
    margin: 0;
    background: transparent;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
    --anon-voice-vol-pct: 100%;
}

.anon-voice-volume-slider::-webkit-slider-runnable-track {
    height: 6px;
    border-radius: 999px;
    background: linear-gradient(
        to right,
        var(--av-vol-fill-start) 0%,
        var(--av-vol-fill-end) var(--anon-voice-vol-pct),
        var(--av-vol-track) var(--anon-voice-vol-pct),
        var(--av-vol-track) 100%
    );
}

.anon-voice-volume-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    margin-top: -5px;
    border-radius: 50%;
    background: var(--bg-elevated);
    border: 1px solid color-mix(in srgb, var(--text-muted) 30%, transparent);
    box-shadow: 0 2px 8px color-mix(in srgb, var(--text-primary) 16%, transparent);
}

[data-theme="dark"] .anon-voice-volume-slider::-webkit-slider-thumb {
    background: #fff;
    border: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.anon-voice-volume-slider::-moz-range-track {
    height: 6px;
    border-radius: 999px;
    background: var(--av-vol-track);
}

.anon-voice-volume-slider::-moz-range-progress {
    height: 6px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--av-vol-fill-start) 0%, var(--av-vol-fill-end) 100%);
}

.anon-voice-volume-slider::-moz-range-thumb {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--bg-elevated);
    border: 1px solid color-mix(in srgb, var(--text-muted) 30%, transparent);
    box-shadow: 0 2px 8px color-mix(in srgb, var(--text-primary) 16%, transparent);
}

[data-theme="dark"] .anon-voice-volume-slider::-moz-range-thumb {
    background: #fff;
    border: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

@media (max-width: 520px) {
    .anon-voice-circle-btn {
        width: 4.35rem;
        height: 4.35rem;
        font-size: 1.25rem;
    }

    .anon-voice-circle-btn--hangup {
        font-size: 1.32rem;
    }
}

/* Антиспам: временная блокировка кнопок студии до прохождения reCAPTCHA v3 в фоне */
html[data-spam-studio-locked="true"] #studio-carousel button,
html[data-spam-studio-locked="true"] #studio-carousel textarea,
html[data-spam-studio-locked="true"] #comments-modal button,
html[data-spam-studio-locked="true"] #comments-modal textarea {
    pointer-events: none;
    opacity: 0.52;
}

html[data-spam-studio-locked="true"] #studio-carousel .circle-ended-overlay__replay {
    pointer-events: none;
}

/* --- Профиль --- */

.top-bar__user-link {
    text-decoration: none;
    color: var(--text-muted);
    max-width: 10rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.top-bar__user-link:hover {
    color: var(--accent);
}

.mobile-menu__username--link {
    text-decoration: none;
    color: inherit;
    font-weight: 700;
    letter-spacing: -0.02em;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

.mobile-menu__username--link:hover {
    color: var(--accent);
}

.profile-page {
    width: 100%;
}

.profile-layout {
    display: grid;
    grid-template-columns: minmax(200px, 240px) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

@media (max-width: 768px) {
    .profile-layout {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
}

.profile-nav {
    position: sticky;
    top: calc(var(--top-bar-height) + 0.75rem);
    padding: 1.1rem 1rem;
    border-radius: var(--radius-xl);
}

.profile-nav__heading {
    margin: 0 0 0.65rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.profile-nav__list {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

@media (max-width: 768px) {
    .profile-nav {
        position: static;
        padding: 0.85rem 1rem;
    }

    .profile-nav__list {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 0.45rem;
    }

    .profile-nav__link {
        flex: 1 1 auto;
        justify-content: center;
        min-width: 44%;
    }
}

.profile-nav__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.55rem 0.75rem;
    border-radius: var(--radius-full);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-muted);
    text-decoration: none;
    border: 1px solid transparent;
    transition:
        color 0.18s ease,
        border-color 0.18s ease,
        background 0.18s ease;
}

.profile-nav__link:hover {
    color: var(--text-primary);
    background: color-mix(in srgb, var(--bg-muted) 65%, transparent);
}

.profile-nav__link--current {
    color: var(--text-primary);
    border-color: color-mix(in srgb, var(--accent) 38%, transparent);
    background: color-mix(in srgb, var(--accent) 12%, var(--bg-muted));
}

.profile-nav__icon {
    font-size: 0.95rem;
    opacity: 0.85;
}

.profile-main {
    min-width: 0;
}

.profile-panel {
    padding: clamp(1.25rem, 3vw, 1.85rem);
    border-radius: var(--radius-xl);
}

.profile-hero {
    display: flex;
    align-items: center;
    gap: 1.1rem;
    margin-bottom: 1.75rem;
    padding-bottom: 1.35rem;
    border-bottom: 1px solid var(--border-subtle);
}

.profile-hero__avatar {
    flex-shrink: 0;
    width: 72px;
    height: 72px;
    border-radius: var(--radius-full);
    display: grid;
    place-items: center;
    font-size: 1.65rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: #fff;
    background: linear-gradient(145deg, var(--accent), color-mix(in srgb, var(--accent-hot) 55%, var(--accent)));
    box-shadow:
        0 12px 36px color-mix(in srgb, var(--accent) 28%, transparent),
        0 0 0 4px color-mix(in srgb, var(--accent-soft) 45%, transparent);
}

.profile-hero__title {
    margin: 0 0 0.25rem;
    font-size: clamp(1.35rem, 4vw, 1.65rem);
    letter-spacing: -0.03em;
}

.profile-hero__meta {
    margin: 0;
    font-size: 0.88rem;
    color: var(--text-muted);
}

.profile-section-title {
    margin: 0 0 0.85rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.profile-stat-grid {
    list-style: none;
    margin: 0 0 1.5rem;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
    gap: 0.75rem;
}

.profile-stat-tile {
    padding: 1rem 1.05rem;
    border-radius: 16px;
    border: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--bg-muted) 42%, transparent);
    transition:
        transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1),
        box-shadow 0.2s ease;
}

.profile-stat-tile:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(13, 57, 82, 0.08);
}

.profile-stat-tile--accent {
    border-color: color-mix(in srgb, var(--accent) 35%, transparent);
    background: linear-gradient(
        160deg,
        color-mix(in srgb, var(--accent) 14%, var(--bg-elevated)),
        color-mix(in srgb, var(--accent-soft) 35%, var(--bg-elevated))
    );
}

.profile-stat-tile__value {
    display: block;
    font-size: 1.55rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
    line-height: 1.15;
}

.profile-stat-tile__label {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-muted);
    line-height: 1.35;
}

.profile-cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.profile-panel__head {
    margin-bottom: 1.25rem;
}

.profile-panel__title {
    margin: 0 0 0.35rem;
    font-size: clamp(1.25rem, 3.5vw, 1.5rem);
    letter-spacing: -0.02em;
}

.profile-panel__lead {
    margin: 0;
    font-size: 0.88rem;
    color: var(--text-muted);
    line-height: 1.45;
    max-width: 42rem;
}

.profile-empty {
    margin: 0 0 1rem;
    font-size: 0.95rem;
    color: var(--text-muted);
}

.profile-empty__btn {
    margin-top: 0.25rem;
}

.profile-circles-table-wrap {
    overflow-x: auto;
    margin: 0 -0.25rem;
    padding: 0 0.25rem;
    -webkit-overflow-scrolling: touch;
}

.profile-circles-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.86rem;
}

.profile-circles-table th {
    text-align: left;
    padding: 0.55rem 0.65rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border-subtle);
    white-space: nowrap;
}

.profile-circles-table td {
    padding: 0.65rem 0.65rem;
    border-bottom: 1px solid color-mix(in srgb, var(--border-subtle) 70%, transparent);
    vertical-align: middle;
}

.profile-circles-table tbody tr:hover td {
    background: color-mix(in srgb, var(--bg-muted) 55%, transparent);
}

.profile-circles-table__id code {
    font-family: var(--font-mono);
    font-size: 0.82rem;
    font-weight: 600;
    background: color-mix(in srgb, var(--bg-muted) 88%, transparent);
    padding: 0.15rem 0.45rem;
    border-radius: 8px;
}

.profile-circles-table__reach {
    font-variant-numeric: tabular-nums;
}

.profile-circles-table__reach-head {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.profile-circles-table__date {
    color: var(--text-muted);
    font-size: 0.82rem;
    white-space: nowrap;
}

.profile-reach {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-weight: 700;
    color: var(--accent);
}

.profile-reach__icon {
    opacity: 0.9;
}

.profile-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.55rem;
    border-radius: var(--radius-full);
    font-size: 0.75rem;
    font-weight: 600;
}

.profile-badge--live {
    background: color-mix(in srgb, #22c55e 18%, transparent);
    color: color-mix(in srgb, #15803d 90%, var(--text-primary));
    border: 1px solid color-mix(in srgb, #22c55e 35%, transparent);
}

.profile-badge--muted {
    background: color-mix(in srgb, var(--bg-muted) 80%, transparent);
    color: var(--text-muted);
    border: 1px solid var(--border-subtle);
}

[data-theme="dark"] .profile-nav__link--current {
    border-color: color-mix(in srgb, var(--accent) 42%, transparent);
    background: color-mix(in srgb, var(--accent) 16%, var(--bg-muted));
}

[data-theme="dark"] .profile-stat-tile:hover {
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.35);
}

[data-theme="dark"] .profile-badge--live {
    background: color-mix(in srgb, #22c55e 22%, transparent);
    color: #86efac;
    border-color: color-mix(in srgb, #22c55e 38%, transparent);
}

/* ---- Account moderation overlay ---- */
.account-ban-overlay {
    position: fixed;
    inset: 0;
    z-index: 400;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    box-sizing: border-box;
}

.account-ban-overlay--visible {
    display: flex;
}

.account-ban-overlay__backdrop {
    position: absolute;
    inset: 0;
    background: color-mix(in srgb, var(--bg-base) 55%, rgba(0, 0, 0, 0.82));
    backdrop-filter: blur(6px);
}

.account-ban-overlay__panel {
    position: relative;
    z-index: 1;
    max-width: 26rem;
    width: 100%;
    padding: 1.35rem 1.35rem 1.15rem;
}

.account-ban-overlay__title {
    margin: 0 0 0.65rem;
    font-size: 1.15rem;
    font-weight: 700;
}

.account-ban-overlay__body {
    font-size: 0.92rem;
    line-height: 1.45;
    color: var(--text-muted);
}

.account-ban-overlay__lead {
    margin: 0 0 0.65rem;
    color: var(--text-primary);
}

.account-ban-overlay__reason {
    margin: 0 0 0.55rem;
}

.account-ban-overlay__expires {
    margin: 0 0 0.85rem;
    font-size: 0.85rem;
}

.account-ban-overlay__logout {
    margin: 0;
}

/* ---- Admin layout ---- */
.admin-body {
    margin: 0;
    min-height: 100vh;
}

.admin-shell {
    display: flex;
    min-height: 100vh;
    background: var(--bg-muted);
}

.admin-shell__aside {
    width: 240px;
    flex-shrink: 0;
    padding: 1.25rem 1rem;
    border-right: 1px solid var(--border-subtle);
    background: var(--bg-base);
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.admin-shell__brand {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.admin-shell__brand-name {
    font-weight: 700;
    font-size: 0.95rem;
}

.admin-shell__badge {
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--accent);
}

.admin-shell__nav {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.admin-shell__nav-link {
    font-size: 0.88rem;
    padding: 0.45rem 0.55rem;
    border-radius: var(--radius-md);
    color: var(--text-primary);
    text-decoration: none;
}

.admin-shell__nav-link:hover {
    background: var(--bg-muted);
}

.admin-shell__nav-link--current {
    background: color-mix(in srgb, var(--accent) 14%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
}

.admin-shell__nav-link--muted {
    color: var(--text-muted);
}

.admin-shell__foot {
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid var(--border-subtle);
    font-size: 0.82rem;
}

.admin-shell__user {
    display: block;
    margin-bottom: 0.35rem;
    font-weight: 600;
}

.admin-shell__logout {
    margin: 0;
}

.admin-shell__main {
    flex: 1;
    padding: 1.5rem clamp(1rem, 3vw, 2rem);
}

.admin-flash {
    padding: 0.65rem 0.85rem;
    border-radius: var(--radius-md);
    margin-bottom: 1rem;
    font-size: 0.88rem;
}

.admin-flash--ok {
    background: color-mix(in srgb, #22c55e 14%, transparent);
    border: 1px solid color-mix(in srgb, #22c55e 35%, transparent);
}

.admin-page-head {
    margin-bottom: 1.25rem;
}

.admin-page-head--split {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.admin-page-head__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    justify-content: flex-end;
}

.admin-page-head__title {
    margin: 0 0 0.35rem;
    font-size: 1.35rem;
}

.admin-page-head__lead {
    margin: 0;
    font-size: 0.92rem;
    color: var(--text-muted);
}

.admin-page-head__meta {
    margin: 0.5rem 0 0;
    font-size: 0.82rem;
    color: var(--text-muted);
}

.admin-muted {
    color: var(--text-muted);
}

.admin-filter-row {
    margin-top: 0.65rem;
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 0.75rem;
}

.admin-filter-row--wide .admin-filter-row__label:first-child {
    min-width: min(100%, 280px);
}

.admin-filter-row__label {
    font-size: 0.82rem;
    color: var(--text-muted);
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.admin-select,
.admin-input,
.admin-textarea {
    font: inherit;
    padding: 0.45rem 0.55rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: var(--bg-base);
    color: var(--text-primary);
}

.admin-textarea {
    resize: vertical;
    min-height: 4rem;
}

.admin-field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    font-size: 0.82rem;
}

.admin-stack-form {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.admin-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 1rem;
}

.admin-kpi {
    padding: 1rem;
}

.admin-kpi__label {
    margin: 0 0 0.35rem;
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-muted);
}

.admin-kpi__value {
    margin: 0;
    font-size: 1.65rem;
    font-weight: 700;
}

.admin-chart-card {
    margin-top: 1rem;
    padding: clamp(1rem, 2vw, 1.35rem);
}

.admin-chart-card__head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.admin-chart-card__title {
    margin: 0 0 0.3rem;
    font-size: 1.08rem;
    letter-spacing: -0.02em;
}

.admin-chart-card__lead {
    margin: 0;
    font-size: 0.84rem;
    color: var(--text-muted);
}

.admin-chart-range {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    padding: 0.28rem;
    border-radius: var(--radius-full);
    background: color-mix(in srgb, var(--bg-muted) 72%, transparent);
}

.admin-chart-range__btn {
    border: none;
    border-radius: var(--radius-full);
    padding: 0.45rem 0.72rem;
    background: transparent;
    color: var(--text-muted);
    font: inherit;
    font-size: 0.78rem;
    font-weight: 700;
    cursor: pointer;
}

.admin-chart-range__btn:hover,
.admin-chart-range__btn.is-active {
    background: var(--bg-elevated);
    color: var(--text-primary);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}

.admin-chart-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.admin-chart-summary__item {
    padding: 0.85rem 0.95rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--bg-muted) 45%, transparent);
}

.admin-chart-summary__item--users {
    border-color: color-mix(in srgb, var(--accent) 34%, var(--border-subtle));
}

.admin-chart-summary__item--circles {
    border-color: color-mix(in srgb, #f59e0b 36%, var(--border-subtle));
}

.admin-chart-summary__label {
    display: block;
    margin-bottom: 0.25rem;
    font-size: 0.74rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-muted);
}

.admin-chart-summary__value {
    display: block;
    font-size: 1.35rem;
    line-height: 1;
}

.admin-chart-canvas-wrap {
    min-height: 280px;
    border-radius: var(--radius-xl);
    border: 1px solid var(--border-subtle);
    background:
        radial-gradient(circle at 12% 14%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 34%),
        radial-gradient(circle at 88% 20%, rgba(245, 158, 11, 0.11), transparent 32%),
        color-mix(in srgb, var(--bg-base) 68%, transparent);
    overflow: hidden;
}

.admin-chart-canvas {
    display: block;
    width: 100%;
    height: 280px;
}

.admin-chart-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.75rem;
    font-size: 0.78rem;
    color: var(--text-muted);
}

.admin-chart-legend__item {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.admin-chart-legend__item::before {
    content: "";
    width: 0.75rem;
    height: 0.75rem;
    border-radius: var(--radius-full);
}

.admin-chart-legend__item--users::before {
    background: var(--accent);
}

.admin-chart-legend__item--circles::before {
    background: #f59e0b;
}

.admin-table-wrap {
    overflow-x: auto;
    padding: 0.35rem;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.84rem;
}

.admin-table th,
.admin-table td {
    padding: 0.55rem 0.45rem;
    text-align: left;
    border-bottom: 1px solid var(--border-subtle);
    vertical-align: top;
}

.admin-table__empty {
    text-align: center;
    padding: 1.25rem;
    color: var(--text-muted);
}

.admin-inline-link {
    color: var(--accent);
    font-weight: 600;
    text-decoration: none;
}

.admin-inline-link:hover {
    text-decoration: underline;
}

.admin-user-link {
    color: var(--text-primary);
}

.admin-badge {
    display: inline-flex;
    align-items: center;
    min-height: 1.35rem;
    padding: 0.16rem 0.48rem;
    border-radius: var(--radius-full);
    border: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--bg-muted) 78%, transparent);
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 700;
    white-space: nowrap;
}

.admin-badge--ok {
    border-color: color-mix(in srgb, #10b981 38%, var(--border-subtle));
    background: color-mix(in srgb, #10b981 12%, transparent);
    color: color-mix(in srgb, #10b981 82%, var(--text-primary));
}

.admin-badge--accent {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border-subtle));
    background: color-mix(in srgb, var(--accent) 12%, transparent);
    color: var(--accent);
}

.admin-badge--danger {
    border-color: color-mix(in srgb, #ef4444 42%, var(--border-subtle));
    background: color-mix(in srgb, #ef4444 12%, transparent);
    color: color-mix(in srgb, #ef4444 88%, var(--text-primary));
}

.admin-pagination {
    margin-top: 1rem;
}

.admin-detail-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    margin-bottom: 1rem;
}

.admin-detail-card {
    padding: 1rem;
    margin-bottom: 1rem;
}

.admin-detail-card__head {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 0.75rem;
}

.admin-detail-card__title {
    margin: 0 0 0.75rem;
    font-size: 1rem;
    letter-spacing: -0.02em;
}

.admin-detail-card__head .admin-detail-card__title {
    margin-bottom: 0;
}

.admin-detail-card__subtitle {
    margin: 1rem 0 0.5rem;
    font-size: 0.86rem;
}

.admin-detail-card__text,
.admin-detail-card__muted {
    margin: 0.45rem 0 0;
    font-size: 0.84rem;
    color: var(--text-muted);
    line-height: 1.45;
}

.admin-detail-list {
    margin: 0;
    display: grid;
    gap: 0.55rem;
}

.admin-detail-list > div {
    display: grid;
    grid-template-columns: minmax(110px, 0.35fr) minmax(0, 1fr);
    gap: 0.75rem;
    align-items: baseline;
}

.admin-detail-list dt {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-muted);
}

.admin-detail-list dd {
    margin: 0;
    min-width: 0;
    overflow-wrap: anywhere;
}

.admin-user-ban {
    margin: 0;
    padding: 0.7rem 0.8rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--bg-muted) 50%, transparent);
    font-size: 0.84rem;
    font-weight: 700;
}

.admin-user-ban--active {
    border-color: color-mix(in srgb, #ef4444 42%, var(--border-subtle));
    background: color-mix(in srgb, #ef4444 12%, transparent);
    color: color-mix(in srgb, #ef4444 86%, var(--text-primary));
}

.admin-mini-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.65rem;
    padding: 0.35rem 0;
    border-bottom: 1px solid var(--border-subtle);
    font-size: 0.78rem;
    color: var(--text-muted);
}

.admin-mini-row:last-child {
    border-bottom: none;
}

.admin-table-wrap--inner {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.admin-comment-list {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.admin-comment-item {
    padding: 0.65rem 0.7rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--bg-muted) 42%, transparent);
}

.admin-comment-item__meta {
    margin: 0 0 0.3rem;
    font-size: 0.74rem;
    font-weight: 600;
    color: var(--text-muted);
}

.admin-comment-item__body {
    margin: 0;
    font-size: 0.84rem;
    line-height: 1.45;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.admin-actions-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}

.admin-card {
    padding: 1rem;
}

.admin-card--wide {
    grid-column: 1 / -1;
}

.admin-card--narrow {
    max-width: 28rem;
}

.admin-card__title {
    margin: 0 0 0.65rem;
    font-size: 1rem;
}

.admin-dl {
    margin: 0;
}

.admin-dl > div {
    margin-bottom: 0.55rem;
}

.admin-dl dt {
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-muted);
}

.admin-dl dd {
    margin: 0.15rem 0 0;
}

.admin-pre-wrap {
    white-space: pre-wrap;
    word-break: break-word;
}

.admin-pre-wrap--sm {
    font-size: 0.82rem;
}

.admin-json {
    margin: 0;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.72rem;
    white-space: pre-wrap;
    word-break: break-word;
    max-height: 320px;
    overflow: auto;
}

.admin-fine-print {
    margin: 0;
    font-size: 0.78rem;
    color: var(--text-muted);
}

.admin-error {
    margin: 0;
    font-size: 0.82rem;
    color: color-mix(in srgb, #ef4444 90%, var(--text-primary));
}

.admin-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.admin-inline-form {
    display: inline-block;
    margin-right: 0.35rem;
    margin-bottom: 0.35rem;
}

.admin-table-actions {
    white-space: nowrap;
}

.admin-back-row {
    margin-top: 1.25rem;
}

.admin-code {
    font-family: ui-monospace, monospace;
    font-size: 0.78rem;
}

.admin-danger-btn {
    color: color-mix(in srgb, #ef4444 88%, var(--text-primary));
}

.admin-circle-open {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font: inherit;
}

.admin-circle-modal {
    z-index: 180;
}

.admin-circle-modal__backdrop {
    border: none;
}

.admin-circle-modal__panel {
    max-width: min(92vw, 520px);
    width: min(92vw, 520px);
    padding: clamp(1.1rem, 3vw, 1.5rem);
    overflow: hidden;
}

.admin-circle-modal__head {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: center;
    margin-bottom: 0.85rem;
}

.admin-circle-modal__title {
    margin: 0;
    font-size: 1.05rem;
}

.admin-circle-modal__video {
    display: block;
    width: min(100%, 420px);
    aspect-ratio: 9 / 16;
    max-height: min(72vh, 680px);
    margin: 0 auto;
    border-radius: 0.9rem;
    background: #000;
    object-fit: contain;
}

@media (max-width: 820px) {
    .admin-shell {
        flex-direction: column;
    }

    .admin-shell__aside {
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
    }

    .admin-shell__nav {
        flex-direction: row;
        flex-wrap: wrap;
        flex: 1;
    }

    .admin-shell__foot {
        margin-top: 0;
        padding-top: 0;
        border-top: none;
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
}

/* ---- Жалоба: модалка и кнопка в студии ---- */
.randly-report-modal .randly-report-modal__panel {
    max-width: 420px;
    position: relative;
}

.randly-report-modal__lead {
    margin: 0 0 1rem;
    font-size: 0.88rem;
    line-height: 1.45;
    color: var(--text-muted);
}

.randly-report-modal__form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.randly-report-modal__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.randly-report-modal__label {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-muted);
}

.randly-report-modal__select,
.randly-report-modal__textarea {
    width: 100%;
}

.randly-report-modal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
    margin-top: 0.35rem;
}

.foreign-watch-report-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.55rem;
    border-radius: var(--radius-full);
    border: 1px solid color-mix(in srgb, var(--warning-amber, #f59e0b) 42%, var(--border-subtle));
    background: color-mix(in srgb, var(--warning-amber, #f59e0b) 12%, transparent);
    color: var(--text-primary);
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    line-height: 1;
}

.foreign-watch-report-btn:hover:not(:disabled) {
    background: color-mix(in srgb, var(--warning-amber, #f59e0b) 22%, transparent);
}

.foreign-watch-report-btn:disabled {
    opacity: 0.38;
    cursor: not-allowed;
}

.foreign-watch-report-btn i {
    font-size: 0.82rem;
}

.foreign-watch-ui__row.foreign-watch-ui__pills {
    flex-wrap: wrap;
}

/* Уведомления: комментарии к кружкам владельца */

.top-bar__notifications-menu {
    position: relative;
    flex-shrink: 0;
}

.top-bar__notifications-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--top-bar-icon-btn-size, 2.35rem);
    height: var(--top-bar-icon-btn-size, 2.35rem);
    min-width: var(--top-bar-icon-btn-size, 2.35rem);
    min-height: var(--top-bar-icon-btn-size, 2.35rem);
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-full);
    background: color-mix(in srgb, var(--bg-muted) 88%, transparent);
    color: var(--text-primary);
    cursor: pointer;
    transition:
        background 0.15s ease,
        border-color 0.15s ease,
        color 0.15s ease;
}

.top-bar__notifications-trigger:hover {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border-subtle));
    background: color-mix(in srgb, var(--accent) 12%, var(--bg-muted));
    color: var(--accent);
}

.top-bar__notifications-trigger:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
}

.top-bar__notifications-trigger[aria-expanded="true"] {
    border-color: color-mix(in srgb, var(--accent) 55%, var(--border-subtle));
    background: color-mix(in srgb, var(--accent) 14%, var(--bg-muted));
    color: var(--accent);
}

.top-bar__notifications-trigger-icon {
    font-size: 1.15rem;
    line-height: 1;
}

.top-bar__notifications-badge {
    position: absolute;
    top: -0.15rem;
    right: -0.15rem;
    min-width: 1.05rem;
    height: 1.05rem;
    padding: 0 0.28rem;
    border-radius: var(--radius-full);
    background: #dc2626;
    color: #fff;
    font-size: 0.62rem;
    font-weight: 800;
    line-height: 1.05rem;
    text-align: center;
    box-shadow: 0 0 0 2px var(--bg-elevated);
    pointer-events: none;
}

.top-bar__notifications-badge.is-hidden {
    display: none !important;
}

.top-bar__notifications-panel {
    position: absolute;
    top: calc(100% + 0.45rem);
    right: 0;
    z-index: 50;
    width: min(20rem, calc(100vw - 2rem));
    max-height: min(22rem, 70vh);
    display: flex;
    flex-direction: column;
    padding: 0.75rem 0.85rem 0.85rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-subtle);
    background: var(--bg-elevated);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
}

[data-theme="dark"] .top-bar__notifications-panel {
    box-shadow: 0 22px 52px rgba(0, 0, 0, 0.55);
}

.top-bar__notifications-panel[hidden] {
    display: none !important;
}

.top-bar__notifications-title {
    margin: 0 0 0.45rem;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--text-primary);
}

.top-bar__notifications-body {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    margin: 0 -0.25rem;
    padding: 0 0.25rem;
}

.top-bar__notifications-status {
    margin: 0.35rem 0 0;
    font-size: 0.78rem;
    color: var(--text-muted);
}

.top-bar__notifications-footer-btn {
    margin-top: 0.55rem;
    width: 100%;
    justify-content: center;
    text-decoration: none;
    box-sizing: border-box;
}

.top-bar__notifications-item {
    display: block;
    padding: 0.55rem 0.35rem;
    margin: 0 -0.35rem;
    border-radius: var(--radius-md);
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid var(--border-subtle);
    transition: background 0.12s ease;
}

.top-bar__notifications-item:last-child {
    border-bottom: none;
}

.top-bar__notifications-item:hover {
    background: color-mix(in srgb, var(--bg-muted) 82%, transparent);
}

.top-bar__notifications-item__who {
    margin: 0 0 0.18rem;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--text-muted);
    letter-spacing: 0.02em;
}

.top-bar__notifications-item__what {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.35;
    color: var(--text-primary);
}

.top-bar__notifications-empty {
    margin: 0.35rem 0 0.25rem;
    font-size: 0.82rem;
    color: var(--text-muted);
    line-height: 1.4;
}

@media (min-width: 768px) {
    .top-bar .top-bar__notifications-trigger {
        width: var(--top-bar-icon-btn-size);
        height: var(--top-bar-icon-btn-size);
        min-width: var(--top-bar-icon-btn-size);
        min-height: var(--top-bar-icon-btn-size);
    }

    .top-bar .top-bar__notifications-trigger .top-bar__notifications-trigger-icon {
        font-size: 1.22rem;
    }
}

/* Профиль: лента комментариев к своим кружкам */

.profile-comments-feed {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.profile-comment-card {
    padding: 0.75rem 0.85rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--bg-muted) 38%, transparent);
    scroll-margin-top: calc(var(--top-bar-height) + 0.75rem);
}

.profile-comment-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.25rem 0.35rem;
    margin: 0 0 0.4rem;
    font-size: 0.76rem;
    color: var(--text-muted);
}

.profile-comment-card__author {
    font-weight: 700;
    color: var(--text-primary);
}

.profile-comment-card__sep {
    opacity: 0.45;
    user-select: none;
}

.profile-comment-card__circle code {
    font-size: 0.74rem;
}

.profile-comment-card__time {
    font-variant-numeric: tabular-nums;
}

.profile-comment-card__body {
    margin: 0;
    white-space: pre-wrap;
    word-break: break-word;
    font-size: 0.88rem;
    line-height: 1.45;
    color: var(--text-primary);
}

.profile-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    margin-top: 1.15rem;
}

.profile-pagination__link {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--accent);
    text-decoration: none;
}

.profile-pagination__link:hover {
    text-decoration: underline;
}

.profile-pagination__meta {
    font-size: 0.8rem;
    font-variant-numeric: tabular-nums;
    color: var(--text-muted);
}

.profile-pagination__muted {
    font-size: 0.85rem;
    color: color-mix(in srgb, var(--text-muted) 72%, transparent);
    user-select: none;
}
