/* Meet Fy — 文章动态流样式 */
:root {
    --bg: #08080c;
    --bg-elevated: #0f0f14;
    --surface: rgba(255, 255, 255, 0.03);
    --surface-hover: rgba(255, 255, 255, 0.055);
    --text: #ececf1;
    --text-secondary: #9898a6;
    --text-dim: #5c5c6a;
    --accent: #a78bfa;
    --accent-dim: rgba(167, 139, 250, 0.15);
    --accent-glow: rgba(167, 139, 250, 0.35);
    --border: rgba(255, 255, 255, 0.06);
    --border-strong: rgba(255, 255, 255, 0.1);
    --radius: 14px;
    --radius-sm: 8px;
    --font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", sans-serif;
    --mono: "SF Mono", "Fira Code", "Cascadia Code", monospace;
    --header-h: 64px;
    --container-wide: 1200px;
    --container-narrow: 640px;
    --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

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

html {
    color-scheme: dark;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--font);
    background: var(--bg);
    color: var(--text);
    line-height: 1.65;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* 背景氛围 */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse 60% 50% at 15% -10%, rgba(167, 139, 250, 0.12), transparent),
        radial-gradient(ellipse 50% 40% at 85% 110%, rgba(99, 102, 241, 0.08), transparent),
        radial-gradient(ellipse 40% 30% at 50% 50%, rgba(255, 255, 255, 0.015), transparent);
}

body::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    opacity: 0.35;
    background-image: url("../img/noise.svg");
    background-repeat: repeat;
    background-size: 128px 128px;
}

.container {
    width: min(var(--container-narrow), 90vw);
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

/* ── Header ── */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    height: var(--header-h);
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(8, 8, 12, 0.72);
    backdrop-filter: blur(16px) saturate(1.4);
    -webkit-backdrop-filter: blur(16px) saturate(1.4);
    border-bottom: 1px solid var(--border);
}

.site-header .container {
    width: min(var(--container-narrow), 90vw);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 16px;
}

.header-leading {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    flex: 1;
}

.header-search {
    position: relative;
    flex-shrink: 0;
    margin: 0;
}

.header-search__trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    margin: 0;
    padding: 0;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.04);
    color: var(--text-dim);
    cursor: pointer;
    transition:
        border-color 0.25s var(--ease),
        background 0.25s var(--ease),
        color 0.25s var(--ease);
}

.header-search__trigger:hover,
.header-search.is-open .header-search__trigger {
    border-color: rgba(167, 139, 250, 0.35);
    background: rgba(99, 102, 241, 0.08);
    color: #a78bfa;
}

.header-search__icon {
    flex-shrink: 0;
    pointer-events: none;
}

.header-search__panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    left: auto;
    z-index: 210;
    width: min(360px, calc(100vw - 32px));
    padding: 10px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition:
        opacity 0.2s var(--ease),
        transform 0.2s var(--ease),
        visibility 0.2s;
}

.header-search.is-open .header-search__panel {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.header-search__form {
    margin: 0;
}

.header-search__field {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    padding: 0 12px;
    height: 36px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.04);
    transition: border-color 0.2s var(--ease), background 0.2s var(--ease);
}

.header-search__field:focus-within {
    border-color: rgba(167, 139, 250, 0.35);
    background: rgba(99, 102, 241, 0.08);
}

.header-search__field-icon {
    flex-shrink: 0;
    color: var(--text-dim);
}

.header-search__field:focus-within .header-search__field-icon {
    color: #a78bfa;
}

.header-search__input {
    flex: 1;
    min-width: 0;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--text);
    font-family: var(--font);
    font-size: 0.82rem;
    line-height: 1.2;
    outline: none;
}

.header-search__input::placeholder {
    color: var(--text-dim);
}

.header-search__input::-webkit-search-cancel-button {
    -webkit-appearance: none;
}

.header-search__list {
    margin: 8px 0 0;
    padding: 4px 0 0;
    list-style: none;
    border-top: 1px solid var(--border);
    max-height: min(50vh, 320px);
    overflow: auto;
}

.header-search__item {
    margin: 0;
}

.header-search__link {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 8px 10px;
    font-size: 0.84rem;
    line-height: 1.35;
    color: var(--text);
    text-decoration: none;
    border-radius: 6px;
    transition: background 0.15s var(--ease), color 0.15s var(--ease);
}

.header-search__link:hover {
    background: var(--surface-hover);
    color: var(--accent);
}

.header-search__num {
    flex-shrink: 0;
    min-width: 1.1em;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: var(--accent);
}

.header-search__title {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

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

.site-brand {
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: #A78BFA;
    text-decoration: none;
    transition: color 0.25s var(--ease);
}

.site-brand:hover {
    color: #C4B5FD;
}

.site-brand--logo {
    display: flex;
    align-items: center;
    line-height: 0;
}

.site-brand--logo img {
    height: 27px;
    width: auto;
    max-width: 160px;
    object-fit: contain;
}

/* ── Header nav dropdown ── */
.header-nav {
    position: relative;
}

.header-menu-trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--accent);
    background: var(--accent-dim);
    padding: 5px 12px;
    border-radius: 999px;
    border: 1px solid rgba(167, 139, 250, 0.2);
    cursor: pointer;
    transition: background 0.2s var(--ease), border-color 0.2s var(--ease);
}

/* ── Header menu dropdown ── */
.header-menu {
    position: relative;
    flex-shrink: 0;
}

.header-menu-trigger:hover,
.header-menu.is-open .header-menu-trigger {
    background: rgba(167, 139, 250, 0.22);
    border-color: rgba(167, 139, 250, 0.35);
}

.header-menu-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: auto;
    min-width: 148px;
    margin: 0;
    padding: 6px;
    list-style: none;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition: opacity 0.2s var(--ease), transform 0.2s var(--ease), visibility 0.2s;
    z-index: 200;
}

.header-menu.is-open .header-menu-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.header-menu-item {
    margin: 0;
}

.header-menu-item--sub .header-menu-link {
    padding-left: 22px;
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.header-menu-link {
    display: block;
    padding: 8px 12px;
    font-size: 0.85rem;
    color: var(--text);
    text-decoration: none;
    border-radius: 6px;
    transition: background 0.15s var(--ease), color 0.15s var(--ease);
}

.header-menu-link:hover,
.header-menu-link[aria-current="page"] {
    background: var(--surface-hover);
    color: var(--accent);
}

/* ── Hero ── */
.meet_page {
    flex: 1;
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 48px 0 0;
}

.meet_page > .meet_container {
    flex: 1;
    display: flex;
    flex-direction: column;
    width: min(var(--container-narrow), 90vw);
    margin-left: auto;
    margin-right: auto;
}

.meet_feed_view {
    flex: 1;
    width: 100%;
    min-width: 0;
    padding-bottom: 28px;
}

.meet_hero {
    margin-bottom: 40px;
    padding-bottom: 32px;
    border-bottom: 1px solid var(--border);
}

.meet_hero__center {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.meet_label {
    display: block;
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 12px;
}

.meet_title {
    margin: 0 0 10px;
    font-size: clamp(1.6rem, 5vw, 2rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.2;
}

.meet_title_inner {
    position: relative;
    display: inline-block;
    padding-right: 6px;
    background: linear-gradient(135deg, var(--text) 30%, var(--text-secondary));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.meet_title_text {
    -webkit-text-fill-color: transparent;
}

.meet_title_count {
    position: absolute;
    top: 0;
    right: 0;
    transform: translate(72%, -42%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 17px;
    height: 17px;
    padding: 0 4px;
    border-radius: 999px;
    font-size: 0.58rem;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0;
    line-height: 1;
    color: #fff;
    -webkit-text-fill-color: #fff;
    background: var(--accent);
    border: 1.5px solid var(--bg);
    box-shadow: 0 0 0 1px rgba(167, 139, 250, 0.35), 0 2px 8px var(--accent-glow);
    pointer-events: none;
    user-select: none;
}

.meet_title_count[hidden] {
    display: none !important;
}

.meet_desc {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
    font-weight: 400;
}

/* ── Composer ── */
.meet_composer {
    margin-bottom: 24px;
}

.meet_composer.meet_composer--no-guest #meet_guest_panel {
    display: none !important;
}

.meet_composer_guest {
    position: relative;
    padding: 0 0 24px 52px;
}

.meet_composer_guest::before {
    content: "";
    position: absolute;
    left: 14px;
    top: 12px;
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: var(--bg);
    border: 2px solid var(--border-strong);
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.02);
}

.meet_composer_guest__inner {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 40px;
    padding-top: 2px;
}

.meet_composer_guest__avatar {
    appearance: none;
    cursor: pointer;
    padding: 0;
    transition: transform 0.15s var(--ease), box-shadow 0.2s var(--ease);
}

.meet_composer_guest__avatar:hover {
    transform: scale(1.04);
    box-shadow: 0 0 0 3px var(--accent-dim);
}

.meet_composer_guest__avatar:active {
    transform: scale(0.98);
}

.meet_composer_guest__hint {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.55;
    color: var(--text-secondary);
}

.meet_login_modal {
    position: fixed;
    inset: 0;
    z-index: 10070;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 16px;
    box-sizing: border-box;
    background: rgba(8, 8, 12, 0.72);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity 0.3s var(--ease),
        visibility 0.3s var(--ease);
}

.meet_login_modal.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.meet_login_modal[hidden] {
    display: none !important;
}

body.meet_login_modal_open {
    overflow: hidden;
}

.meet_login_modal__panel {
    position: relative;
    width: min(400px, 100%);
    max-height: min(90vh, 520px);
    overflow: auto;
    padding: 20px 20px 18px;
    border-radius: 16px;
    border: 1px solid var(--border-strong);
    background: var(--bg-elevated);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.55);
    pointer-events: auto;
    opacity: 0;
    transform: translateY(14px) scale(0.97);
    transition:
        opacity 0.32s var(--ease),
        transform 0.32s var(--ease);
}

.meet_login_modal.is-open .meet_login_modal__panel {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.meet_login_modal__close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--text-secondary);
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
    transition: background 0.2s var(--ease), color 0.2s var(--ease);
}

.meet_login_modal__close:hover {
    background: rgba(255, 255, 255, 0.06);
    color: var(--text);
}

.meet_login_modal__title {
    margin: 0 0 14px;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

/* ── Logout confirm modal ── */
.meet_logout_modal {
    position: fixed;
    inset: 0;
    z-index: 10075;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 16px;
    box-sizing: border-box;
    background: rgba(8, 8, 12, 0.72);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity 0.3s var(--ease),
        visibility 0.3s var(--ease);
}

.meet_logout_modal.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.meet_logout_modal[hidden] {
    display: none !important;
}

body.meet_logout_modal_open {
    overflow: hidden;
}

.meet_logout_modal__panel {
    width: min(360px, 100%);
    padding: 24px 22px 20px;
    border-radius: 16px;
    border: 1px solid var(--border-strong);
    background: var(--bg-elevated);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.55);
    text-align: center;
    opacity: 0;
    transform: translateY(14px) scale(0.97);
    transition:
        opacity 0.32s var(--ease),
        transform 0.32s var(--ease);
}

.meet_logout_modal.is-open .meet_logout_modal__panel {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.meet_logout_modal__user {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
}

.meet_logout_modal__user .meet_avatar {
    width: 48px;
    height: 48px;
}

.meet_logout_modal__user-name {
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--text);
}

.meet_logout_modal__title {
    margin: 0 0 10px;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text);
}

.meet_logout_modal__text {
    margin: 0 0 20px;
    font-size: 0.84rem;
    line-height: 1.6;
    color: var(--text-secondary);
}

.meet_logout_modal__actions {
    display: flex;
    gap: 10px;
}

.meet_logout_modal__actions .meet_btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px;
}

.meet_logout_modal__cancel {
    border: 1px solid var(--border-strong);
    background: transparent;
    color: var(--text-secondary);
}

.meet_logout_modal__cancel:hover:not(:disabled) {
    background: rgba(255, 255, 255, 0.05);
    color: var(--text);
}

.meet_composer_post {
    position: relative;
    padding: 0 0 24px 52px;
}

.meet_composer_post::before {
    content: "";
    position: absolute;
    left: 14px;
    top: 6px;
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: var(--bg);
    border: 2px solid var(--accent);
    box-shadow: 0 0 0 3px var(--accent-dim), 0 0 12px var(--accent-glow);
}

.meet_composer_row {
    display: flex;
    align-items: flex-start;
    gap: 14px;
}

.meet_composer_avatar {
    flex-shrink: 0;
}

.meet_login_form {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    min-width: 0;
}

.meet_login_form__submit {
    align-self: center;
    margin-top: 4px;
    min-width: 120px;
}

.meet_input {
    width: 100%;
    min-width: 0;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-family: var(--font);
    font-size: 0.875rem;
    outline: none;
    transition: border-color 0.2s var(--ease);
}

.meet_input:focus {
    border-color: rgba(167, 139, 250, 0.4);
}

.meet_input::placeholder {
    color: var(--text-dim);
}

.meet_captcha_row {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
}

.meet_input__captcha {
    flex: 0 1 120px;
}

.meet_captcha {
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-strong);
    cursor: pointer;
    flex-shrink: 0;
}

.meet_btn {
    appearance: none;
    border: 1px solid var(--border-strong);
    background: transparent;
    color: var(--text-secondary);
    padding: 10px 18px;
    border-radius: 999px;
    font-size: 0.8rem;
    font-family: var(--font);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.25s var(--ease);
    white-space: nowrap;
    flex-shrink: 0;
}

.meet_btn__primary {
    background: var(--accent-dim);
    border-color: rgba(167, 139, 250, 0.25);
    color: var(--accent);
}

.meet_btn__primary:hover:not(:disabled) {
    background: rgba(167, 139, 250, 0.22);
    border-color: rgba(167, 139, 250, 0.35);
}

.meet_btn__danger {
    background: rgba(248, 113, 113, 0.14);
    border-color: rgba(248, 113, 113, 0.35);
    color: #fca5a5;
}

.meet_btn__danger:hover:not(:disabled) {
    background: rgba(248, 113, 113, 0.24);
    border-color: rgba(248, 113, 113, 0.5);
    color: #fecaca;
}

.meet_btn__publish {
    background: var(--accent);
    border-color: transparent;
    color: #fff;
    font-weight: 600;
    padding: 8px 18px;
    font-size: 0.82rem;
}

.meet_btn__publish:hover:not(:disabled) {
    opacity: 0.88;
}

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

.meet_compose_box {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    transition: background 0.3s var(--ease), border-color 0.3s var(--ease), box-shadow 0.3s var(--ease);
}

.meet_compose_box:focus-within {
    background: var(--surface-hover);
    border-color: var(--border-strong);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.18);
}

.meet_compose_head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 20px 22px 0;
}

.meet_compose_head .meet_composer_avatar {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    margin-top: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.meet_compose_fields {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.meet_title_input {
    display: block;
    width: 100%;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--text);
    font-family: var(--font);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.45;
    letter-spacing: -0.02em;
    outline: none;
}

.meet_title_input::placeholder {
    color: var(--text-dim);
    font-weight: 500;
}

.meet_composer_avatar__interactive {
    cursor: pointer;
}

.meet_composer_avatar__interactive .meet_avatar {
    pointer-events: none;
    transition: box-shadow 0.2s var(--ease), transform 0.15s var(--ease);
}

.meet_composer_avatar__interactive:hover .meet_avatar,
.meet_composer_avatar__interactive:focus-visible .meet_avatar {
    box-shadow: 0 0 0 3px var(--accent-dim);
}

.meet_composer_avatar__interactive:active .meet_avatar {
    transform: scale(0.96);
}

.meet_textarea {
    display: block;
    flex: 1;
    width: 100%;
    min-width: 0;
    min-height: 56px;
    max-height: 160px;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--text);
    font-family: var(--font);
    font-size: 0.9rem;
    line-height: 1.65;
    resize: vertical;
    outline: none;
}

.meet_textarea::placeholder {
    color: var(--text-dim);
}

.meet_media_preview {
    padding: 12px 22px 0;
}

.meet_compose_bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 22px 20px;
    margin-top: 12px;
    border-top: 1px solid var(--border);
}

.meet_compose_actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-shrink: 0;
}

.meet_btn__sort {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    max-width: 9.5em;
    padding: 8px 12px;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--text-secondary);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--border);
    border-radius: 999px;
}

.meet_btn__sort:hover:not(:disabled) {
    color: var(--accent);
    border-color: rgba(167, 139, 250, 0.35);
    background: var(--accent-dim);
}

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

.meet_sort_btn__icon {
    flex-shrink: 0;
    opacity: 0.75;
}

.meet_sort_menu {
    position: fixed;
    z-index: 10056;
    min-width: 160px;
    max-width: min(280px, calc(100vw - 16px));
    max-height: min(280px, calc(100vh - 24px));
    overflow: auto;
    padding: 6px;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}

.meet_sort_menu[hidden] {
    display: none !important;
}

.meet_sort_menu__item {
    display: block;
    width: 100%;
    margin: 0;
    padding: 9px 12px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--text);
    font: inherit;
    font-size: 0.84rem;
    text-align: left;
    cursor: pointer;
    transition: background 0.2s var(--ease), color 0.2s var(--ease);
}

.meet_sort_menu__item:hover {
    background: var(--accent-dim);
    color: var(--accent);
}

.meet_sort_menu__item.is-active {
    background: rgba(167, 139, 250, 0.18);
    color: var(--accent);
    font-weight: 600;
}

.meet_compose_tools {
    display: flex;
    align-items: center;
    gap: 4px;
}

.meet_compose_tool {
    appearance: none;
    -webkit-appearance: none;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 10px;
    background: transparent;
    color: var(--text-secondary);
    font: inherit;
    line-height: 1;
    cursor: pointer;
    transition: color 0.2s var(--ease), background 0.2s var(--ease);
}

.meet_compose_tool svg {
    display: block;
    flex-shrink: 0;
}

.meet_compose_tool:hover {
    color: var(--accent);
    background: var(--accent-dim);
}

.meet_compose_tool:focus {
    outline: none;
}

.meet_compose_tool:focus-visible {
    box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.35);
}

.meet_compose_tool:has(input:disabled) {
    opacity: 0.35;
    cursor: not-allowed;
    pointer-events: none;
}

.meet_compose_tool:disabled {
    opacity: 0.35;
    cursor: not-allowed;
    pointer-events: none;
}

.meet_media_menu {
    position: fixed;
    z-index: 10055;
    min-width: 148px;
    padding: 6px;
    border-radius: 12px;
    border: 1px solid var(--border-strong);
    background: var(--surface);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}

.meet_media_menu[hidden] {
    display: none !important;
}

.meet_media_menu__item {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 10px 12px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--text);
    font-size: 0.88rem;
    text-align: left;
    cursor: pointer;
    transition: background 0.2s var(--ease), color 0.2s var(--ease);
}

.meet_media_menu__item:hover {
    background: var(--accent-dim);
    color: var(--accent);
}

.meet_media_menu__item svg {
    flex-shrink: 0;
    opacity: 0.85;
}

.meet_url_modal {
    position: fixed;
    inset: 0;
    z-index: 10065;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 16px;
    box-sizing: border-box;
    background: rgba(0, 0, 0, 0.72);
    backdrop-filter: blur(8px);
}

.meet_url_modal[hidden] {
    display: none !important;
}

body.meet_url_modal_open {
    overflow: hidden;
}

.meet_url_modal__panel {
    width: min(420px, 100%);
    padding: 18px 18px 16px;
    border-radius: 16px;
    border: 1px solid var(--border-strong);
    background: var(--surface);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.45);
}

.meet_url_modal__title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
}

.meet_url_modal__hint {
    margin: 6px 0 12px;
    font-size: 13px;
    line-height: 1.5;
    color: var(--text-secondary);
}

.meet_url_modal__input {
    display: block;
    width: 100%;
    min-height: 88px;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.03);
    color: var(--text);
    font-size: 0.88rem;
    line-height: 1.5;
    resize: vertical;
    box-sizing: border-box;
}

.meet_url_modal__input:focus {
    outline: none;
    border-color: rgba(129, 140, 248, 0.5);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
}

.meet_url_modal__input__single {
    min-height: 0;
    height: 42px;
    resize: none;
}

.meet_url_modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 14px;
}

/* ── Grid crop modal ── */
.meet_grid_crop {
    position: fixed;
    inset: 0;
    z-index: 10060;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 16px;
    box-sizing: border-box;
    background: rgba(0, 0, 0, 0.72);
    backdrop-filter: blur(8px);
}

.meet_grid_crop[hidden] {
    display: none !important;
}

body.meet_grid_crop_open {
    overflow: hidden;
}

.meet_grid_crop__panel {
    width: min(360px, 100%);
    padding: 18px 18px 16px;
    border-radius: 16px;
    border: 1px solid var(--border-strong);
    background: var(--surface);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.45);
}

.meet_grid_crop__title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
}

.meet_grid_crop__hint {
    margin: 6px 0 0;
    font-size: 13px;
    line-height: 1.5;
    color: var(--text-secondary);
}

.meet_grid_crop__stage {
    margin-top: 16px;
}

.meet_grid_crop__viewport {
    position: relative;
    width: 100%;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 12px;
    background: #0a0a0a;
    touch-action: none;
    cursor: grab;
    user-select: none;
    -webkit-user-select: none;
}

.meet_grid_crop__viewport:has(.meet_grid_crop__img.is-dragging) {
    cursor: grabbing;
}

.meet_grid_crop__img {
    position: absolute;
    top: 0;
    left: 0;
    max-width: none;
    max-height: none;
    will-change: transform;
    pointer-events: auto;
    touch-action: none;
    user-select: none;
    -webkit-user-drag: none;
}

.meet_grid_crop__img.is-dragging {
    transition: none;
}

.meet_grid_crop__mask {
    position: absolute;
    inset: 0;
    pointer-events: none;
    box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.85);
}

.meet_grid_crop__line {
    position: absolute;
    background: rgba(255, 255, 255, 0.42);
}

.meet_grid_crop__line__v1,
.meet_grid_crop__line__v2 {
    top: 0;
    bottom: 0;
    width: 1px;
}

.meet_grid_crop__line__v1 {
    left: 33.3333%;
}

.meet_grid_crop__line__v2 {
    left: 66.6667%;
}

.meet_grid_crop__line__h1,
.meet_grid_crop__line__h2 {
    left: 0;
    right: 0;
    height: 1px;
}

.meet_grid_crop__line__h1 {
    top: 33.3333%;
}

.meet_grid_crop__line__h2 {
    top: 66.6667%;
}

.meet_grid_crop__actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 16px;
}

.meet_compose_video {
    position: relative;
    max-width: min(280px, 100%);
}

.meet_compose_voice {
    position: relative;
    display: inline-block;
    max-width: 100%;
    margin-top: 4px;
}

.meet_compose_voice .meet_media_remove {
    position: absolute;
    top: -8px;
    right: -8px;
    z-index: 3;
}

.meet_voice_player {
    --voice-progress: 0%;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    width: 40px;
    min-width: 40px;
    height: 40px;
    padding: 0 14px;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(74, 222, 128, 0.24), rgba(34, 197, 94, 0.14));
    border: 1px solid rgba(74, 222, 128, 0.32);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
    cursor: pointer;
    user-select: none;
    overflow: hidden;
    transform-origin: left center;
    transition:
        width 0.5s var(--ease),
        min-width 0.5s var(--ease),
        padding 0.35s var(--ease),
        background 0.2s var(--ease),
        transform 0.15s var(--ease);
}

.meet_voice_player.is-ready {
    cursor: pointer;
    touch-action: none;
}

.meet_voice_player.is-scrubbing {
    cursor: grabbing;
}

.meet_voice_player.is-scrubbing:active {
    transform: none;
}

.meet_voice_player.is-scrubbing::before {
    transition: none;
    opacity: 0.5;
}

.meet_voice_player.is-loading {
    width: 40px !important;
    min-width: 40px !important;
    max-width: 40px;
    height: 40px;
    padding: 0;
    gap: 0;
    justify-content: center;
    transition:
        width 0.5s var(--ease),
        min-width 0.5s var(--ease),
        padding 0.35s var(--ease),
        background 0.2s var(--ease);
}

.meet_voice_player.is-loading::before {
    opacity: 0 !important;
}

.meet_voice_player::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: var(--voice-progress);
    border-radius: 999px 0 0 999px;
    background: rgba(255, 255, 255, 0.16);
    pointer-events: none;
    opacity: 0;
    transition: width 0.12s linear, opacity 0.2s var(--ease);
}

.meet_voice_player.is-progress-full::before {
    border-radius: 999px;
}

.meet_voice_player.is-playing::before,
.meet_voice_player.has-progress::before {
    opacity: 0.38;
}

.meet_voice_player > * {
    position: relative;
    z-index: 1;
}

.meet_voice_player:hover {
    background: linear-gradient(135deg, rgba(74, 222, 128, 0.32), rgba(34, 197, 94, 0.2));
}

.meet_voice_player:active {
    transform: scale(0.98);
}

.meet_voice_player__duration {
    flex-shrink: 0;
    min-width: 2.2em;
    font-size: 0.82rem;
    font-weight: 500;
    font-variant-numeric: tabular-nums;
    color: rgba(255, 255, 255, 0.9);
    white-space: nowrap;
    line-height: 1;
    opacity: 0;
    transition: opacity 0.45s var(--ease) 0.2s;
    pointer-events: none;
}

.meet_voice_player.is-ready .meet_voice_player__duration {
    opacity: 1;
}

.meet_voice_player.is-loading .meet_voice_player__duration,
.meet_voice_player.is-loading .meet_voice_player__icon {
    display: none;
}

.meet_voice_player__icon {
    flex-shrink: 0;
    width: 7px;
    height: 7px;
    margin-left: auto;
    border-radius: 50%;
    background: #86efac;
    box-shadow: 0 0 0 1.5px rgba(134, 239, 172, 0.25);
    opacity: 0;
    transition: opacity 0.35s var(--ease) 0.28s;
    pointer-events: none;
}

.meet_voice_player.is-ready .meet_voice_player__icon {
    opacity: 1;
}

.meet_voice_player.is-playing .meet_voice_player__icon {
    animation: meet_voice_icon_pulse 2.2s ease-in-out infinite;
}

.meet_voice_player__loading {
    display: none;
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    align-items: center;
    justify-content: center;
}

.meet_voice_player__spinner {
    display: block;
    width: 18px;
    height: 18px;
    box-sizing: border-box;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: #86efac;
    border-radius: 50%;
    transform-origin: 50% 50%;
    will-change: transform;
    animation: meet_video_spin 0.75s linear infinite;
}

.meet_voice_player.is-loading .meet_voice_player__loading {
    display: flex;
}

.meet_voice_player__audio {
    display: none !important;
}

.meet_content .meet_voice_player {
    margin-top: 8px;
}

@keyframes meet_voice_icon_pulse {
    0%, 100% {
        transform: scale(0.9);
        opacity: 0.7;
        box-shadow:
            0 0 0 1.5px rgba(134, 239, 172, 0.2),
            0 0 0 rgba(134, 239, 172, 0);
    }
    50% {
        transform: scale(1.24);
        opacity: 1;
        box-shadow:
            0 0 0 3px rgba(134, 239, 172, 0.38),
            0 0 7px rgba(74, 222, 128, 0.45);
    }
}

@keyframes meet_video_spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.meet_compose_video .meet_video_player {
    max-width: 100%;
}

.meet_compose_video .meet_video_player video-skin {
    min-height: 120px;
}

.meet_compose_video .meet_media_remove {
    position: absolute;
    top: 4px;
    right: 4px;
    z-index: 3;
}

.meet_video_player_wrap,
.weiyu-video-player-wrap,
.weiyu_video_player_wrap {
    width: 100%;
    margin-top: 10px;
}

.meet_video_player,
.weiyu-video-player,
.weiyu_video_player {
    position: relative;
    display: block;
    width: 100%;
    max-width: 100%;
    border-radius: 4px;
    overflow: hidden;
    background: #0a0a0a;
    border: 1px solid var(--border);
    user-select: none;
}

.meet_video_player.is-portrait,
.weiyu-video-player.is-portrait,
.weiyu_video_player.is-portrait {
    width: auto;
    max-width: 100%;
    margin-inline: auto;
}

.meet_video_player.has-blur-bg,
.weiyu-video-player.has-blur-bg,
.weiyu_video_player.has-blur-bg {
    width: 100%;
    max-width: 100%;
    margin-inline: 0;
}

.meet_video_player__frame {
    position: relative;
    display: block;
    max-width: 100%;
    margin-inline: auto;
    overflow: hidden;
}

.meet_video_player__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

.meet_video_player__bg_media {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform: scale(1.12);
    filter: blur(32px) saturate(1.2) brightness(0.5);
    will-change: transform;
}

.meet_video_player__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.28);
    backdrop-filter: blur(6px) saturate(1.1);
    -webkit-backdrop-filter: blur(6px) saturate(1.1);
    pointer-events: none;
}

.meet_video_player__main {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.meet_video_player.meet_video_player__v10 .meet_vjs10,
.weiyu-video-player.meet_video_player__v10 .meet_vjs10,
.weiyu_video_player.meet_video_player__v10 .meet_vjs10 {
    display: block;
    width: 100%;
}

.meet_video_player.meet_video_player__v10 video-skin,
.weiyu-video-player.meet_video_player__v10 video-skin,
.weiyu_video_player.meet_video_player__v10 video-skin {
    position: relative;
    display: block;
    box-sizing: border-box;
    max-width: 100%;
    overflow: hidden;
    --media-border-radius: 4px;
    --media-video-border-radius: 0;
    --media-object-fit: contain;
    --media-surface-background-color: #000;
    --media-surface-outer-border-color: transparent;
    --media-surface-inner-border-color: transparent;
    --media-surface-shadow-color: transparent;
    color: #e5e7eb;
}

.meet_video_player__error {
    position: absolute;
    inset: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
    background: rgba(0, 0, 0, 0.72);
    color: #fca5a5;
    font-size: 0.85rem;
    text-align: center;
    pointer-events: auto;
}

.meet_video_player__error-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    max-width: 28em;
}

.meet_video_player__error-text {
    margin: 0;
    line-height: 1.55;
}

.meet_video_player__retry {
    appearance: none;
    padding: 6px 16px;
    border-radius: 999px;
    border: 1px solid rgba(248, 113, 113, 0.45);
    background: rgba(248, 113, 113, 0.12);
    color: #fecaca;
    font-family: var(--font);
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.2s var(--ease), border-color 0.2s var(--ease);
}

.meet_video_player__retry:hover {
    background: rgba(248, 113, 113, 0.22);
    border-color: rgba(248, 113, 113, 0.6);
}

.meet_video_player__error[hidden] {
    display: none !important;
}

/* 元数据未就绪：16:9 占位，避免未加载时出现扁条尺寸 */
.meet_video_player.is-layout-pending:not(.is-layout-ready) .meet_video_player__frame {
    position: relative;
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    max-height: min(56vh, 420px);
    margin-inline: auto;
    background: #0a0612;
}

.meet_video_player.is-layout-pending:not(.is-layout-ready) .meet_video_player__main {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.meet_video_player.is-layout-pending:not(.is-layout-ready) video-skin {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.meet_video_player.is-layout-pending:not(.is-layout-ready) .meet_vjs10 {
    width: 100%;
    height: 100%;
}

/* 黑紫毛玻璃水波加载背景 */
.meet_video_player__ambient {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.55s ease, visibility 0.55s ease;
    background: linear-gradient(152deg, #06040c 0%, #0f0820 38%, #160a28 72%, #0a0614 100%);
}

/* 仅首屏未出画面前显示黑紫水波（is-loading），与布局占位 is-layout-pending 分离 */
.meet_video_player.is-loading .meet_video_player__ambient {
    z-index: 4;
    opacity: 1;
    visibility: visible;
}

.meet_video_player.is-loading .meet_video_player__main {
    z-index: 1;
}

.meet_video_player.is-loading .meet_video_player__main hls-video,
.meet_video_player.is-loading .meet_video_player__main video {
    opacity: 0;
}

.meet_video_player__ambient::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(8, 4, 18, 0.18);
    backdrop-filter: blur(14px) saturate(1.45);
    -webkit-backdrop-filter: blur(14px) saturate(1.45);
    border: 1px solid rgba(167, 139, 250, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.meet_video_player__wave {
    position: absolute;
    display: block;
    filter: blur(26px);
    opacity: 0.62;
    mix-blend-mode: screen;
    will-change: transform, border-radius;
}

.meet_video_player__wave--a {
    width: 78%;
    height: 62%;
    left: -12%;
    top: 8%;
    background: radial-gradient(circle at 35% 35%, rgba(167, 139, 250, 0.75), rgba(109, 40, 217, 0.25) 58%, transparent 72%);
    border-radius: 42% 58% 52% 48% / 46% 44% 56% 54%;
    animation: meet_video_wave_a 9s ease-in-out infinite;
}

.meet_video_player__wave--b {
    width: 68%;
    height: 58%;
    right: -8%;
    bottom: 0;
    background: radial-gradient(circle at 60% 55%, rgba(192, 132, 252, 0.6), rgba(76, 29, 149, 0.3) 55%, transparent 70%);
    border-radius: 58% 42% 47% 53% / 52% 48% 52% 48%;
    animation: meet_video_wave_b 11s ease-in-out infinite;
}

.meet_video_player__wave--c {
    width: 55%;
    height: 48%;
    left: 22%;
    bottom: -8%;
    background: radial-gradient(circle at 50% 50%, rgba(124, 58, 237, 0.55), rgba(30, 15, 55, 0.2) 60%, transparent 75%);
    border-radius: 48% 52% 58% 42% / 55% 45% 50% 50%;
    animation: meet_video_wave_c 7.5s ease-in-out infinite;
}

@keyframes meet_video_wave_a {
    0%, 100% {
        transform: translate(0, 0) rotate(0deg) scale(1);
        border-radius: 42% 58% 52% 48% / 46% 44% 56% 54%;
    }
    50% {
        transform: translate(10%, -8%) rotate(14deg) scale(1.12);
        border-radius: 55% 45% 40% 60% / 50% 55% 45% 50%;
    }
}

@keyframes meet_video_wave_b {
    0%, 100% {
        transform: translate(0, 0) rotate(0deg) scale(1.05);
        border-radius: 58% 42% 47% 53% / 52% 48% 52% 48%;
    }
    50% {
        transform: translate(-12%, 6%) rotate(-10deg) scale(0.94);
        border-radius: 45% 55% 60% 40% / 48% 52% 44% 56%;
    }
}

@keyframes meet_video_wave_c {
    0%, 100% {
        transform: translate(0, 0) scale(1);
        border-radius: 48% 52% 58% 42% / 55% 45% 50% 50%;
    }
    33% {
        transform: translate(6%, 10%) scale(1.08);
        border-radius: 52% 48% 44% 56% / 42% 58% 52% 48%;
    }
    66% {
        transform: translate(-5%, 4%) scale(1.02);
        border-radius: 60% 40% 50% 50% / 55% 45% 48% 52%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .meet_video_player__wave {
        animation: none !important;
    }
}

/* 加载中转圈（叠在水波毛玻璃之上） */
.meet_video_player__loading {
    position: absolute;
    inset: 0;
    z-index: 18;
    display: none;
    align-items: center;
    justify-content: center;
    background: transparent;
    pointer-events: none;
}

.meet_video_player__spinner {
    position: relative;
    z-index: 1;
    display: block;
    width: 36px;
    height: 36px;
    box-sizing: border-box;
    border: 3px solid rgba(196, 181, 253, 0.28);
    border-top-color: #e9d5ff;
    border-radius: 50%;
    box-shadow: 0 0 20px rgba(139, 92, 246, 0.35);
    animation: meet_video_spin 0.75s linear infinite;
}

.meet_video_player.is-loading .meet_video_player__loading {
    display: flex;
}

/* 无模糊底时主层铺满黑底；有模糊底时主层透明，左右露出 __bg */
.meet_video_player.is-layout-ready:not(.is-loading):not(.has-blur-bg) .meet_video_player__main {
    background: #000;
}

.meet_video_player.has-blur-bg.is-layout-ready:not(.is-loading) .meet_video_player__main {
    background: transparent;
}

.meet_video_player.has-blur-bg .meet_video_player__bg[hidden] {
    display: none !important;
}

.meet_video_player.has-blur-bg .meet_video_player__bg:not([hidden]) {
    display: block;
}

/* 首屏自定义加载时隐藏 Video.js 转圈；播放中卡顿用原生缓冲指示 */
.meet_video_player.is-loading video-skin::part(buffering-indicator),
.meet_video_player.is-loading .media-buffering-indicator {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

/* 全屏伪回退 */
.meet_video_player.is-fullscreen:not(:fullscreen):not(:-webkit-full-screen):not(:-moz-full-screen) {
    position: fixed;
    inset: 0;
    z-index: 10050;
    width: 100vw !important;
    height: 100dvh !important;
    max-width: none;
    max-height: none;
    border-radius: 0;
    border: none;
}

.meet_video_player.is-fullscreen:not(:fullscreen):not(:-webkit-full-screen):not(:-moz-full-screen) video-skin {
    max-height: none;
    aspect-ratio: unset;
    height: 100%;
}

body.meet_video_fs_lock {
    overflow: hidden;
}

.meet_content .meet_video_player_wrap,
.meet_content .meet_video_player,
.meet_content .weiyu-video-player-wrap,
.meet_content .weiyu-video-player,
.meet_content .weiyu_video_player_wrap,
.meet_content .weiyu_video_player {
    width: 100%;
    max-width: 100%;
    margin-top: 10px;
    margin-left: 0;
    margin-right: 0;
}

.meet_content_body .meet_video_player_wrap,
.meet_content_body .meet_video_player,
.meet_content_body .weiyu-video-player-wrap,
.meet_content_body .weiyu-video-player,
.meet_content_body .weiyu_video_player_wrap,
.meet_content_body .weiyu_video_player {
    margin-top: 10px;
}

.meet_content_toggle + .meet_video_player_wrap,
.meet_content_toggle + .meet_video_player,
.meet_content_toggle + .weiyu-video-player-wrap,
.meet_content_toggle + .weiyu-video-player,
.meet_content_toggle + .weiyu_video_player_wrap,
.meet_content_toggle + .weiyu_video_player {
    margin-top: 10px;
}

.meet_moments_grid {
    display: grid;
    gap: 4px;
    max-width: min(280px, 100%);
}

.meet_moments_grid__1 {
    grid-template-columns: 1fr;
    max-width: min(200px, 72%);
}

.meet_moments_grid__1 .meet_moments_grid__cell img {
    aspect-ratio: auto;
    max-height: 240px;
    object-fit: cover;
}

.meet_moments_grid__2,
.meet_moments_grid__4 {
    grid-template-columns: repeat(2, 1fr);
}

.meet_moments_grid__3,
.meet_moments_grid__multi {
    grid-template-columns: repeat(3, 1fr);
}

.meet_moments_grid__cell {
    position: relative;
    overflow: hidden;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.04);
}

.meet_moments_grid__cell img {
    display: block;
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
}

.meet_moments_img {
    cursor: zoom-in;
}

.meet_image_viewer {
    position: fixed;
    inset: 0;
    z-index: 10050;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px 32px;
    box-sizing: border-box;
    background: rgba(0, 0, 0, 0.88);
    backdrop-filter: blur(6px);
}

.meet_image_viewer[hidden] {
    display: none !important;
}

body.meet_viewer_open {
    overflow: hidden;
}

.meet_image_viewer__close {
    position: absolute;
    top: 16px;
    right: 16px;
    z-index: 2;
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    transition: background 0.2s var(--ease);
}

.meet_image_viewer__close:hover {
    background: rgba(255, 255, 255, 0.22);
}

.meet_image_viewer__stage {
    flex: 1;
    width: 100%;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.meet_image_viewer.is-scrollable .meet_image_viewer__stage {
    display: block;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

.meet_image_viewer__img {
    display: block;
    max-width: 100%;
    max-height: calc(100vh - 120px);
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 4px;
    cursor: zoom-in;
    user-select: none;
    -webkit-user-drag: none;
}

.meet_image_viewer.is-scrollable .meet_image_viewer__img {
    margin: auto;
}

.meet_image_viewer__img.is-natural {
    max-width: none;
    max-height: none;
    cursor: zoom-out;
}

.meet_image_viewer__hint {
    flex-shrink: 0;
    margin: 14px 0 0;
    color: rgba(255, 255, 255, 0.72);
    font-size: 13px;
    line-height: 1.4;
    text-align: center;
    pointer-events: none;
}

.meet_compose_cell .meet_media_remove,
.meet_compose_video .meet_media_remove {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 22px;
    height: 22px;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.meet_card_actions {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-left: auto;
}

.meet_action_btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border-radius: 8px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.03);
    color: var(--text-secondary);
    cursor: pointer;
    transition: color 0.2s var(--ease), background 0.2s var(--ease), border-color 0.2s var(--ease), transform 0.2s var(--ease);
}

.meet_action_btn svg {
    flex-shrink: 0;
}

.meet_pin_btn:hover,
.meet_pin_btn:focus-visible {
    color: #93c5fd;
    background: rgba(59, 130, 246, 0.12);
    border-color: rgba(147, 197, 253, 0.35);
}

.meet_pin_btn.is-active {
    color: #60a5fa;
    background: rgba(59, 130, 246, 0.16);
    border-color: rgba(96, 165, 250, 0.45);
}

.meet_pin_btn.is-active:hover {
    color: #fff;
    background: rgba(59, 130, 246, 0.82);
    border-color: rgba(59, 130, 246, 0.9);
}

.meet_edit_btn:hover,
.meet_edit_btn:focus-visible {
    color: #fcd34d;
    background: rgba(245, 158, 11, 0.12);
    border-color: rgba(252, 211, 77, 0.35);
}

.meet_delete_btn {
    border-color: rgba(252, 165, 165, 0.28);
    background: rgba(239, 68, 68, 0.1);
    color: #f87171;
}

.meet_card:hover .meet_delete_btn,
.meet_delete_btn:focus-visible {
    color: #fca5a5;
    background: rgba(239, 68, 68, 0.16);
    border-color: rgba(252, 165, 165, 0.45);
}

.meet_delete_btn:hover {
    color: #fff;
    background: rgba(239, 68, 68, 0.82);
    border-color: rgba(239, 68, 68, 0.9);
    transform: scale(1.05);
}

.meet_card__top .meet_card_inner {
    border-color: rgba(96, 165, 250, 0.35);
}

.meet_top_badge {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    padding: 0 5px;
    border-radius: 4px;
    background: rgba(59, 130, 246, 0.14);
    color: #93c5fd;
    font-size: 10px;
    line-height: 1.55;
    font-weight: 600;
    letter-spacing: 0.02em;
    transform: translateY(-0.5px);
}

/* ── Toast ── */
.meet_toast_root {
    position: fixed;
    top: 100px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10050;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    width: min(92vw, 360px);
    pointer-events: none;
}

.meet_toast {
    pointer-events: auto;
    width: 100%;
    padding: 14px 18px;
    border-radius: 12px;
    background: rgba(18, 18, 24, 0.92);
    border: 1px solid var(--border-strong);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    color: var(--text);
    font-size: 0.88rem;
    line-height: 1.5;
    text-align: center;
    opacity: 0;
    transform: translateY(-10px) scale(0.96);
    transition: opacity 0.22s var(--ease), transform 0.22s var(--ease);
}

.meet_toast.is-show {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.meet_toast__success {
    border-color: rgba(167, 139, 250, 0.35);
    color: #e9d5ff;
}

.meet_toast__error {
    border-color: rgba(248, 113, 113, 0.35);
    color: #fecaca;
}

.meet_toast__info {
    border-color: rgba(255, 255, 255, 0.12);
    color: var(--text-secondary);
}

.meet_toast__confirm {
    padding: 18px 18px 14px;
}

.meet_toast__text {
    margin: 0 0 14px;
    color: var(--text);
    font-size: 0.9rem;
}

.meet_toast__actions {
    display: flex;
    justify-content: center;
    gap: 10px;
}

.meet_toast__btn {
    appearance: none;
    min-width: 72px;
    padding: 8px 16px;
    border-radius: 999px;
    font-family: var(--font);
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
    transition: opacity 0.2s var(--ease), background 0.2s var(--ease);
}

.meet_toast__btn__cancel {
    border: 1px solid var(--border-strong);
    background: transparent;
    color: var(--text-secondary);
}

.meet_toast__btn__cancel:hover {
    background: var(--surface-hover);
}

.meet_toast__btn__ok {
    border: none;
    background: rgba(239, 68, 68, 0.88);
    color: #fff;
}

.meet_toast__btn__ok:hover {
    opacity: 0.9;
}

/* ── Status（加载中 / 空列表 / 错误提示，无文案时不占位）── */
.meet_status {
    text-align: center;
    padding: 14px 18px;
    color: var(--text-secondary);
    font-size: 0.85rem;
    border-radius: var(--radius-sm);
}

.meet_status:empty,
.meet_status[hidden] {
    display: none;
}

.meet_status.is-error {
    color: #fca5a5;
    background: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.15);
}

.meet_status.is-empty {
    color: var(--text-dim);
    padding: 48px 0;
}

.meet_status.is-hint {
    color: var(--text-secondary);
    background: var(--surface);
    border: 1px solid var(--border);
    margin-bottom: 20px;
    font-size: 0.8rem;
}

/* ── Timeline ── */
.meet_list {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.meet_list::before {
    content: "";
    position: absolute;
    left: 19px;
    top: 8px;
    bottom: 8px;
    width: 1px;
    background: linear-gradient(to bottom, transparent, var(--border-strong) 8%, var(--border-strong) 92%, transparent);
}

/* ── Card ── */
.meet_card {
    position: relative;
    padding: 0 0 28px 52px;
    opacity: 0;
    transform: translateY(12px);
    animation: cardIn 0.5s var(--ease) forwards;
}

.meet_card::before {
    content: "";
    position: absolute;
    left: 14px;
    top: 6px;
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: var(--bg);
    border: 2px solid var(--accent);
    box-shadow: 0 0 0 3px var(--accent-dim), 0 0 12px var(--accent-glow);
    transition: box-shadow 0.3s var(--ease);
}

.meet_card:hover::before {
    box-shadow: 0 0 0 4px var(--accent-dim), 0 0 20px var(--accent-glow);
}

.meet_card_inner {
    position: relative;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px 22px;
    transition: background 0.3s var(--ease), border-color 0.3s var(--ease), box-shadow 0.3s var(--ease);
}

.meet_card:hover .meet_card_inner {
    background: var(--surface-hover);
    border-color: var(--border-strong);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
}

.meet_card_head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
    padding-right: 0;
}

.meet_card_head .meet_meta {
    flex: 1;
    min-width: 0;
}

.meet_avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid var(--border-strong);
}

.meet_avatar__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #6366f1, #a78bfa);
    color: #fff;
    font-weight: 600;
    font-size: 0.85rem;
}

.meet_meta {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}

.meet_meta_topline {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
}

.meet_author {
    font-weight: 600;
    font-size: 0.875rem;
    letter-spacing: -0.01em;
    min-width: 0;
}

.meet_date {
    font-size: 0.75rem;
    color: var(--text-dim);
    font-family: var(--mono);
    font-weight: 400;
}

.meet_content {
    font-size: 0.9rem;
    color: var(--text-secondary);
    word-break: break-word;
    line-height: 1.7;
    white-space: normal;
}

.meet_content_body {
    white-space: pre-line;
}

.meet_content > * {
    white-space: normal;
}

.meet_article_heading {
    margin: 0 0 4px;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
    letter-spacing: -0.02em;
    line-height: 1.35;
}

.meet_article_heading + .meet_content_body {
    margin-top: 0;
}

.meet_content_body > .meet_article_heading:first-child {
    margin-bottom: 4px;
}

.meet_content_body > *:first-child:not(.meet_article_heading) {
    margin-top: 0;
}

.meet_article_heading__link {
    color: inherit;
    text-decoration: none;
    cursor: pointer;
    transition: color 0.2s var(--ease);
}

.meet_article_heading__link:hover {
    color: var(--accent);
}

/* ── Feed / article view transition ── */
.meet_container {
    position: relative;
    width: min(var(--container-narrow), 90vw);
    margin-left: auto;
    margin-right: auto;
}

.meet_back_top {
    position: fixed;
    z-index: 120;
    bottom: var(--meet-back-top-bottom, 28px);
    right: max(12px, calc((100vw - min(var(--container-narrow), 90vw)) / 2 - 48px));
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    border: 1px solid rgba(167, 139, 250, 0.28);
    border-radius: 999px;
    background: rgba(18, 18, 24, 0.88);
    color: #A78BFA;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35), 0 0 0 1px rgba(255, 255, 255, 0.04) inset;
    cursor: pointer;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(10px) scale(0.92);
    transition:
        opacity 0.28s var(--ease),
        visibility 0.28s var(--ease),
        transform 0.28s var(--ease),
        bottom 0.22s var(--ease),
        border-color 0.2s var(--ease),
        background 0.2s var(--ease),
        color 0.2s var(--ease);
}

.meet_back_top.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

.meet_back_top:hover {
    color: #C4B5FD;
    border-color: rgba(167, 139, 250, 0.45);
    background: rgba(99, 102, 241, 0.16);
}

.meet_back_top:active {
    transform: translateY(0) scale(0.96);
}

.meet_back_top__icon {
    display: block;
}

body.meet_article_mode .meet_back_top {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

.meet_feed_view,
.meet_article_view {
    transition: opacity 0.38s var(--ease), transform 0.38s var(--ease);
    will-change: opacity, transform;
}

.meet_article_view {
    width: 100%;
    min-width: 0;
}

.meet_feed_view.meet_view__leave {
    opacity: 0;
    transform: translateY(-10px);
    pointer-events: none;
}

.meet_article_view {
    opacity: 0;
    transform: translateY(18px);
}

.meet_article_view.meet_view__active {
    opacity: 1;
    transform: none;
}

body.meet_article_mode .meet_feed_view {
    position: absolute;
    left: 0;
    right: 0;
    visibility: hidden;
    height: 0;
    overflow: hidden;
    margin: 0;
    padding: 0;
}

body.meet_article_mode .meet_composer {
    display: none !important;
}

/* ── Article detail page ── */
.meet_article_detail {
    padding: 4px 0 48px;
    animation: meet_fade_up 0.45s var(--ease) both;
}

.meet_article_back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 0 0 20px;
    padding: 8px 14px 8px 10px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface);
    color: var(--text-secondary);
    font-family: var(--font);
    font-size: 0.8rem;
    cursor: pointer;
    transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.meet_article_back svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.meet_article_back:hover {
    color: var(--accent);
    border-color: rgba(167, 139, 250, 0.35);
    background: var(--accent-dim);
}

.meet_article_detail__card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.22);
}

.meet_article_detail__head {
    padding: 28px 28px 22px;
    border-bottom: 1px solid var(--border);
    background: linear-gradient(180deg, rgba(167, 139, 250, 0.06) 0%, transparent 100%);
}

.meet_article_detail__title {
    margin: 0 0 16px;
    font-size: clamp(1.35rem, 4vw, 1.75rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.35;
    color: var(--text);
}

.meet_article_detail__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.meet_article_detail__meta .meet_avatar {
    width: 40px;
    height: 40px;
}

.meet_article_detail__author {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text);
}

.meet_article_detail__date {
    display: block;
    font-size: 0.75rem;
    color: var(--text-dim);
    font-family: var(--mono);
    margin-top: 2px;
}

.meet_article_detail__stats {
    margin-left: auto;
    font-size: 0.75rem;
    color: var(--text-dim);
    font-family: var(--mono);
}

.meet_article_detail__body {
    padding: 24px 28px 32px;
}

.meet_article_detail__body .meet_content {
    font-size: 0.95rem;
    line-height: 1.8;
    color: var(--text-secondary);
}

.meet_article_detail__body .meet_content_body.is-collapsed,
.meet_article_detail__body .meet_content_toggle {
    display: none !important;
}

.meet_article_neighbor {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid var(--border);
}

.meet_article_neighbor__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.meet_article_neighbor__card {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-height: 84px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0.01) 100%);
    color: inherit;
    text-decoration: none;
    transition:
        border-color 0.25s var(--ease),
        background 0.25s var(--ease),
        box-shadow 0.25s var(--ease),
        transform 0.25s var(--ease);
}

.meet_article_neighbor__card--prev {
    text-align: left;
    align-items: flex-start;
}

.meet_article_neighbor__card--next {
    text-align: right;
    align-items: flex-end;
}

.meet_article_neighbor__card:hover {
    border-color: rgba(167, 139, 250, 0.4);
    background: linear-gradient(145deg, rgba(167, 139, 250, 0.12) 0%, rgba(99, 102, 241, 0.06) 100%);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
    transform: translateY(-2px);
}

.meet_article_neighbor__card:hover .meet_article_neighbor__title {
    color: #c4b5fd;
}

.meet_article_neighbor__card.is-disabled {
    opacity: 0.55;
    cursor: default;
    pointer-events: none;
    transform: none;
    box-shadow: none;
}

.meet_article_neighbor__meta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--accent);
}

.meet_article_neighbor__card--next .meet_article_neighbor__meta {
    flex-direction: row-reverse;
}

.meet_article_neighbor__card.is-disabled .meet_article_neighbor__meta {
    color: var(--text-dim);
}

.meet_article_neighbor__icon {
    flex-shrink: 0;
    opacity: 0.9;
}

.meet_article_neighbor__icon--next {
    transform: rotate(180deg);
}

.meet_article_neighbor__title {
    width: 100%;
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.5;
    color: var(--text);
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    transition: color 0.2s var(--ease);
}

.meet_article_neighbor__empty {
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--text-dim);
}

.meet_article_detail__loading .meet_article_detail__title,
.meet_article_detail__loading .meet_article_detail__body {
    background: linear-gradient(90deg, var(--surface-hover) 25%, rgba(255,255,255,0.06) 50%, var(--surface-hover) 75%);
    background-size: 200% 100%;
    animation: meet_shimmer 1.2s ease-in-out infinite;
    border-radius: var(--radius-sm);
    color: transparent;
    min-height: 1.5em;
}

.meet_article_detail__loading .meet_article_detail__body {
    min-height: 200px;
    margin: 24px 28px 32px;
}

.meet_content_body.is-collapsed {
    display: block;
    max-height: calc(1.7em * 5.85);
    overflow: hidden;
    position: relative;
    -webkit-mask-image: linear-gradient(
        to bottom,
        #000 0%,
        #000 62%,
        rgba(0, 0, 0, 0.94) 74%,
        rgba(0, 0, 0, 0.72) 84%,
        rgba(0, 0, 0, 0.38) 93%,
        rgba(0, 0, 0, 0.12) 98%,
        rgba(0, 0, 0, 0) 100%
    );
    mask-image: linear-gradient(
        to bottom,
        #000 0%,
        #000 62%,
        rgba(0, 0, 0, 0.94) 74%,
        rgba(0, 0, 0, 0.72) 84%,
        rgba(0, 0, 0, 0.38) 93%,
        rgba(0, 0, 0, 0.12) 98%,
        rgba(0, 0, 0, 0) 100%
    );
}

.meet_content_body.is-expanded {
    display: block;
    max-height: none;
    -webkit-mask-image: none;
    mask-image: none;
}

.meet_content_toggle {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 28px;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--accent);
    cursor: pointer;
    transition: color 0.2s var(--ease), background 0.2s var(--ease);
}

.meet_content_toggle__ring {
    position: absolute;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1px solid rgba(129, 140, 248, 0.28);
    background: rgba(99, 102, 241, 0.08);
    transition: transform 0.25s var(--ease), background 0.2s var(--ease), border-color 0.2s var(--ease);
    animation: meet_toggle_pulse 2.4s ease-in-out infinite;
}

.meet_content_toggle__icon {
    position: relative;
    z-index: 1;
    transition: transform 0.32s cubic-bezier(0.34, 1.3, 0.64, 1);
    animation: meet_toggle_nudge 2.4s ease-in-out infinite;
}

.meet_content_toggle.is-expanded .meet_content_toggle__ring {
    animation: none;
    background: rgba(99, 102, 241, 0.14);
    border-color: rgba(129, 140, 248, 0.42);
}

.meet_content_toggle.is-expanded .meet_content_toggle__icon {
    transform: rotate(180deg);
    animation: none;
}

.meet_content_toggle:hover .meet_content_toggle__ring {
    background: rgba(99, 102, 241, 0.16);
    border-color: rgba(129, 140, 248, 0.5);
    transform: scale(1.06);
}

.meet_content_toggle:hover .meet_content_toggle__icon {
    animation: none;
}

@keyframes meet_toggle_nudge {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(3px);
    }
}

@keyframes meet_toggle_pulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(99, 102, 241, 0);
    }
    50% {
        box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.12);
    }
}

.meet_content_toggle + .meet_moments_grid,
.meet_content_toggle + .meet_moments_video_wrap,
.meet_content_toggle + .meet_video_player_wrap,
.meet_content_toggle + .meet_video_player,
.meet_content_toggle + .weiyu-video-player-wrap,
.meet_content_toggle + .weiyu-video-player,
.meet_content_toggle + .weiyu_video_player_wrap,
.meet_content_toggle + .weiyu_video_player,
.meet_content_toggle + .meet_voice_player,
.meet_content_body + .meet_moments_grid,
.meet_content .meet_moments_grid {
    margin-top: 4px;
}

.meet_content p {
    margin: 0 0 0.45em;
}

.meet_content p:last-child {
    margin-bottom: 0;
}

.meet_content a {
    color: var(--accent);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s;
}

.meet_content a:hover {
    border-bottom-color: var(--accent);
}

.meet_content .meet_moments_grid__cell img {
    margin-top: 0;
    border: none;
    border-radius: 0;
}

.meet_content img {
    max-width: 100%;
    border-radius: var(--radius-sm);
    margin-top: 4px;
    border: 1px solid var(--border);
}

.meet_content code {
    font-family: var(--mono);
    font-size: 0.82em;
    background: rgba(255, 255, 255, 0.06);
    padding: 2px 6px;
    border-radius: 4px;
}

.meet_content pre {
    background: rgba(0, 0, 0, 0.35);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 14px 16px;
    overflow-x: auto;
    font-size: 0.82rem;
}

.meet_content blockquote {
    margin: 12px 0;
    padding: 0 0 0 14px;
    border-left: 2px solid var(--accent);
    color: var(--text-dim);
}

/* ── Skeleton ── */
.meet_skeleton {
    padding: 0 0 28px 52px;
}

.meet_skeleton .meet_card_inner {
    animation: pulse 1.8s ease-in-out infinite;
}

.sk-line {
    height: 10px;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.05);
    margin-bottom: 10px;
}

.sk-line--short { width: 35%; }
.sk-line--mid { width: 70%; }
.sk-line--long { width: 100%; height: 14px; }

/* ── Load more ── */
.meet_actions {
    text-align: center;
    margin-top: 8px;
    padding-top: 16px;
}

.btn-load-more {
    appearance: none;
    border: 1px solid var(--border-strong);
    background: transparent;
    color: var(--text-secondary);
    padding: 10px 32px;
    border-radius: 999px;
    font-size: 0.8rem;
    font-family: var(--font);
    font-weight: 500;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: all 0.3s var(--ease);
    position: relative;
    overflow: hidden;
}

.btn-load-more::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--accent-dim);
    opacity: 0;
    transition: opacity 0.3s var(--ease);
}

.btn-load-more:hover:not(:disabled) {
    color: var(--accent);
    border-color: rgba(167, 139, 250, 0.35);
}

.btn-load-more:hover:not(:disabled)::before {
    opacity: 1;
}

.btn-load-more:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.btn-load-more span {
    position: relative;
    z-index: 1;
}

/* ── Footer ── */
.site-footer {
    flex-shrink: 0;
    width: 100%;
    min-height: 125px;
    padding: 28px 0 36px;
    color: var(--text-dim);
    border-top: 1px solid var(--border);
    background: linear-gradient(180deg, transparent 0%, rgba(167, 139, 250, 0.04) 100%);
    position: relative;
    z-index: 1;
}

.site-footer > .container {
    width: min(var(--container-narrow), 90vw);
    margin-left: auto;
    margin-right: auto;
}

.site-footer__inner {
    display: flex;
    align-items: center;
    justify-content: center;
}

.site-footer__brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 12px;
    min-width: 0;
}

.site-footer__logo {
    display: inline-flex;
    justify-content: center;
}

.site-footer__icp {
    margin: 0;
    font-size: 0.72rem;
    line-height: 1.5;
    color: var(--text-dim);
}

.site-footer a {
    color: var(--text-dim);
    text-decoration: none;
    transition: color 0.2s;
}

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

.site-footer__icp a {
    color: var(--text-dim);
}

/* ── Article pages (SSR fallback) ── */
.meet_article_back__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 0 0 20px;
    padding: 8px 14px 8px 10px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface);
    font-size: 0.8rem;
    color: var(--text-secondary);
    text-decoration: none;
    transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.meet_article_back__link:hover {
    color: var(--accent);
    border-color: rgba(167, 139, 250, 0.35);
    background: var(--accent-dim);
}

.meet_article_back__link svg {
    width: 16px;
    height: 16px;
}

/* ── Scrollbar ── */
::-webkit-scrollbar {
    width: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.18);
}

/* ── Animations ── */
@keyframes cardIn {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* stagger via inline style delay set in JS */

@media (max-width: 480px) {
    .meet_page {
        padding-top: 32px;
    }

    .meet_feed_view {
        padding-bottom: 20px;
    }

    .site-footer {
        padding-top: 24px;
        padding-bottom: 28px;
    }

    .meet_list::before {
        left: 15px;
    }

    .meet_card {
        padding-left: 44px;
    }

    .meet_composer_post {
        padding-left: 44px;
    }

    .meet_composer_post::before {
        left: 10px;
        width: 10px;
        height: 10px;
    }

    .meet_card::before {
        left: 10px;
        width: 10px;
        height: 10px;
    }

    .meet_card_inner {
        padding: 16px 18px;
    }

    .meet_compose_head {
        padding: 16px 18px 0;
    }

    .meet_article_detail__head {
        padding: 22px 18px 18px;
    }

    .meet_article_detail__body {
        padding: 18px 18px 24px;
    }

    .meet_article_neighbor__grid {
        grid-template-columns: 1fr;
    }

    .meet_article_detail__title {
        font-size: 1.25rem;
    }

    .meet_media_preview {
        padding: 12px 18px 0;
    }

    .meet_compose_bar {
        padding: 12px 18px 16px;
        flex-wrap: wrap;
    }

    .meet_compose_actions {
        margin-left: auto;
    }

    .meet_btn__sort {
        max-width: 7.5em;
        padding: 8px 10px;
    }

    .meet_login_form {
        flex-direction: column;
        align-items: stretch;
    }

    .meet_input {
        flex: 1 1 auto;
        width: 100%;
    }
}
