:root {
    --header-height: 68px;
    --color-primary: #128C7E;
    --color-primary-dark: #075E54;
    --color-accent: #25D366;
    --color-surface: #ffffff;
    --color-background: #f3f4f6;
    --color-text: #0f172a;
    --color-muted: #64748b;
    --color-border: #e2e8f0;
    --color-border-strong: #b7e4db;
    --radius-lg: 18px;
    --radius-md: 12px;
    --radius-sm: 8px;
    --shadow-xs: 0 2px 8px rgba(15, 23, 42, 0.06);
    --shadow-sm: 0 4px 12px rgba(15, 23, 42, 0.08);
    --shadow-md: 0 16px 32px rgba(15, 23, 42, 0.12);
    --transition: 0.2s ease;
}

@media (min-width: 900px) and (max-width: 1279px) {
    .status-chat {
        min-height: calc(var(--chat-available-height, 100vh));
    }

    .status-container {
        display: grid;
        grid-template-columns: minmax(280px, 320px) minmax(0, 1fr);
        grid-template-rows: auto;
        min-height: 0;
    }

    .status-mobile-bar {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px 20px;
        background: var(--color-surface);
        border-bottom: 1px solid var(--color-border);
        position: sticky;
        top: 0;
        z-index: 6;
    }

    .status-mobile-bar__title {
        margin: 0;
        flex: 1;
        font-size: 1rem;
        font-weight: 600;
        text-align: center;
        color: var(--color-strong);
    }

    .status-mobile-bar__back {
        display: none;
        align-items: center;
        justify-content: center;
        width: 36px;
        height: 36px;
        border: none;
        background: transparent;
        color: var(--color-strong);
        font-size: 1.25rem;
        padding: 0;
        border-radius: 999px;
        cursor: pointer;
    }

    .status-mobile-bar__back span {
        display: block;
        line-height: 1;
    }

    .status-mobile-bar__action {
        display: none;
        flex-shrink: 0;
        white-space: nowrap;
    }

    .status-chat[data-mobile-view="composer"] .status-mobile-bar__back,
    .status-chat[data-mobile-view="detail"] .status-mobile-bar__back,
    .status-chat[data-mobile-view="comments"] .status-mobile-bar__back {
        display: inline-flex;
    }

    .status-chat[data-mobile-view="list"] .status-mobile-bar__action,
    .status-chat[data-mobile-view="detail"] .status-mobile-bar__action,
    .status-chat[data-mobile-view="comments"] .status-mobile-bar__action {
        display: inline-flex;
    }

    .status-chat .status-sidebar {
        position: sticky;
        top: var(--header-height, 68px);
        align-self: flex-start;
        height: auto;
        max-height: calc(var(--chat-available-height, 100vh));
        padding: 18px 16px 20px;
        border-right: 1px solid var(--color-border);
        background: var(--color-surface);
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .status-chat[data-tablet-layout="hybrid"] .status-composer {
        display: none;
    }

    .status-chat .status-feed {
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        padding-right: 6px;
    }

    .status-chat .status-main {
        display: flex;
        flex-direction: column;
        gap: 20px;
        min-height: 0;
        padding: 20px;
        background: transparent;
    }

    .status-chat .status-placeholder {
        padding: 24px;
    }

    .status-composer-panel {
        display: none;
        flex-direction: column;
        gap: 16px;
        padding: 24px;
        background: #fff;
        border: 1px solid var(--color-border);
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-xs);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        max-height: calc(var(--chat-available-height, 100vh) - 40px);
    }

    .status-composer-panel .status-composer {
        display: flex;
        position: static;
        top: auto;
        height: auto;
        padding: 0;
    }

    .status-chat .status-thread {
        border-left: none;
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-xs);
        background: #fff;
    }

    .status-chat .status-thread-header {
        padding: 18px 24px;
    }

    .status-chat .status-thread-content {
        display: flex;
        flex-direction: column;
        gap: 18px;
        padding: 0 24px 24px;
    }

    .status-chat .status-thread-body {
        padding: 20px;
        background: #f1f5f9;
        border: 1px solid rgba(148, 163, 184, 0.35);
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-xs);
        max-height: none;
    }

    .status-chat .status-comments {
        padding: 20px;
        border: 1px solid var(--color-border);
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-xs);
        background: #fff;
    }

    .status-chat[data-mobile-view="list"] .status-composer-panel,
    .status-chat[data-mobile-view="list"] .status-thread {
        display: none;
    }

    .status-chat[data-mobile-view="list"] .status-placeholder {
        display: flex;
    }

    .status-chat[data-tablet-layout="hybrid"][data-mobile-view="composer"] .status-composer-panel {
        display: flex;
    }

    .status-chat[data-tablet-layout="hybrid"][data-mobile-view="composer"] .status-thread,
    .status-chat[data-tablet-layout="hybrid"][data-mobile-view="composer"] .status-placeholder {
        display: none;
    }

    .status-chat[data-mobile-view="detail"] .status-composer-panel {
        display: none;
    }

    .status-chat[data-mobile-view="detail"] .status-placeholder {
        display: none;
    }

    .status-chat[data-mobile-view="detail"] .status-comments {
        display: none;
    }

    .status-chat[data-mobile-view="comments"] .status-placeholder {
        display: none;
    }

    .status-chat[data-mobile-view="comments"] .status-thread-body {
        display: none;
    }

    .status-chat[data-mobile-view="comments"] .status-comments {
        display: flex;
        border: none;
        box-shadow: none;
        background: transparent;
        padding: 0;
        height: auto;
    }
}

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

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    font-family: "Inter", "Segoe UI", sans-serif;
    background: var(--color-background);
    color: var(--color-text);
    line-height: 1.6;
    letter-spacing: 0.01em;
}

body.modal-open,
body.nav-open {
    overflow: hidden;
}

body.chat-layout {
    height: 100vh;
    overflow: hidden;
}

@supports (height: 100dvh) {
    body.chat-layout {
        height: 100dvh;
    }
}

a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition);
}

a:hover,
a:focus-visible {
    color: var(--color-primary-dark);
}

.hidden {
    display: none !important;
}

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

.app-header {
    width: 100%;
    padding: clamp(18px, 4vw, 36px) clamp(24px, 6vw, 48px) 0;
    display: flex;
    justify-content: center;
    background: transparent;
    box-sizing: border-box;
}

.app-header-inner {
    width: 100%;
    max-width: none;
    display: flex;
    align-items: center;
    gap: clamp(16px, 3vw, 28px);
    justify-content: space-between;
    padding: clamp(18px, 3vw, 26px) clamp(24px, 6vw, 48px);
    box-sizing: border-box;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    color: var(--color-text);
    transition: padding var(--transition), box-shadow var(--transition), border-color var(--transition);
    position: relative;
}

.app-header-panel {
    display: flex;
    align-items: center;
    gap: clamp(12px, 2vw, 18px);
}

.app-header-panel--start {
    flex: 1 1 auto;
    min-width: 0;
}

.app-header-panel--actions {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
    min-width: 0;
    margin-left: auto;
}

.app-header-brand {
    display: flex;
    align-items: center;
    gap: clamp(16px, 3vw, 24px);
    min-width: 0;
}

.app-header-brand__logo {
    width: clamp(56px, 8vw, 72px);
    height: clamp(56px, 8vw, 72px);
    border-radius: 18px;
    object-fit: contain;
    background: rgba(255, 255, 255, 0.12);
    padding: clamp(8px, 2vw, 12px);
}

.app-header-brand__text h1 {
    margin: 0;
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.app-header-brand__text p {
    margin: 6px 0 0;
    font-size: clamp(0.78rem, 1.4vw, 0.9rem);
    color: rgba(15, 23, 42, 0.6);
}

body.header-collapsed .app-header {
    padding-bottom: clamp(12px, 2vw, 18px);
}

body.header-collapsed .app-header-inner {
    justify-content: flex-end;
    align-items: center;
    padding: clamp(12px, 2vw, 16px) clamp(24px, 6vw, 48px);
    box-shadow: var(--shadow-xs);
}

body.header-collapsed .app-header-panel--start,
body.header-collapsed .app-header-panel--actions {
    display: none;
}

.app-header-panel--end {
    flex: 0 0 auto;
    position: absolute;
    right: clamp(14px, 6vw, 0px);
    bottom: clamp(8px, 2vw, 4px);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    z-index: 2;
    pointer-events: none;
}

body.header-collapsed .app-header-panel--end {
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
}

.header-collapse-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: auto;
    height: auto;
    padding: 4px;
    border: none;
    background: transparent;
    color: var(--color-primary-dark);
    font-size: 1.1rem;
    cursor: pointer;
    transition: color var(--transition), transform var(--transition);
    pointer-events: auto;
    position: relative;
}

.header-collapse-toggle:hover,
.header-collapse-toggle:focus-visible {
    color: var(--color-primary);
    transform: translateY(-1px);
}

.header-collapse-toggle i {
    font-size: 1.1rem;
    line-height: 1;
    transition: transform var(--transition), opacity var(--transition);
}

.header-collapse-toggle i.icon-hidden {
    display: none !important;
}

body.chat-layout .app-header {
    padding: 0;
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1200;
    background: var(--color-background);
}

body.chat-layout .app-header-inner {
    max-width: none;
    border-radius: 0;
    border-left: none;
    border-right: none;
    padding: clamp(12px, 2vw, 16px) clamp(16px, 3vw, 28px);
}

body.chat-layout .app-header-panel--end {
    right: clamp(12px, 2.4vw, 4px);
    bottom: clamp(6px, 1.5vw, 4px);
    transition: height var(--transition), padding var(--transition);
}

.app-header-action {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: var(--shadow-xs);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);
    color: var(--color-primary-dark);
}

.app-header-action:hover,
.app-header-action:focus-visible,
.app-header-action.active {
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
    border-color: rgba(18, 140, 126, 0.35);
    background: rgba(255, 255, 255, 0.98);
}

.app-header-action__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    position: relative;
}

.app-header-action__icon i {
    font-size: 1.2rem;
    line-height: 1;
    color: inherit;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.app-header-action .indicator {
    position: absolute;
    top: 6px;
    right: 6px;
}

.icon-fallback {
    display: none;
    width: 100%;
    height: 100%;
    fill: currentColor;
    flex-shrink: 0;
    pointer-events: none;
    align-items: center;
    justify-content: center;
}

body.fa-fallback .icon-fa {
    display: none;
}

body.fa-fallback .icon-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.indicator {
    width: 0;
    height: 0;
    border-radius: 50%;
    background: #22c55e;
    display: inline-block;
    margin-left: 0;
    opacity: 0;
    transform: scale(0.6);
    transition: transform var(--transition), opacity var(--transition), width var(--transition), height var(--transition), margin var(--transition);
}

.indicator.active {
    width: 8px;
    height: 8px;
    margin-left: 6px;
    opacity: 1;
    transform: scale(1);
}

.app-content {
    width: 100%;
    max-width: none;
    margin: clamp(24px, 4vw, 48px) 0;
    padding: 0 clamp(24px, 6vw, 48px);
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 3vw, 28px);
    flex: 1 1 auto;
    min-height: 0;
    box-sizing: border-box;
}

.app-content.chat-layout {
    --chat-layout-padding-x: 0px;
    --chat-layout-padding-y: 0px;
    --chat-layout-gap: 0px;
    --chat-layout-offset: 0px;
    --chat-layout-fallback: calc(100vh - var(--header-height) - var(--chat-layout-offset));
    --chat-layout-height: var(--chat-available-height, var(--chat-layout-fallback));
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    gap: 0;
    flex: 1 1 auto;
    height: var(--chat-layout-height);
    max-height: var(--chat-layout-height);
    min-height: 0;
    overflow: hidden;
    background: var(--color-surface);
}

.app-content.chat-layout>.chat {
    flex: 1;
    display: flex;
    min-height: 0;
    height: 100%;
    max-height: 100%;
}

@supports (height: 100dvh) {
    .app-content.chat-layout {
        --chat-layout-fallback: calc(100dvh - var(--header-height) - var(--chat-layout-offset));
    }
}

.app-content>*+* {
    margin-top: clamp(28px, 4vw, 42px);
}

.dashboard>*+*,
.files>*+*,
.profile>*+* {
    margin-top: clamp(24px, 4vw, 36px);
}

.dashboard-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: clamp(16px, 3vw, 28px);
    padding: clamp(18px, 3vw, 26px);
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.dashboard-brand {
    display: flex;
    align-items: center;
    gap: clamp(16px, 3vw, 24px);
    min-width: 0;
}

.dashboard-brand-logo {
    width: clamp(56px, 8vw, 72px);
    height: clamp(56px, 8vw, 72px);
    border-radius: 18px;
    object-fit: contain;
    background: rgba(255, 255, 255, 0.12);
    padding: clamp(8px, 2vw, 12px);
}

.dashboard-brand-text h1 {
    margin: 0;
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.dashboard-brand-text p {
    margin: 6px 0 0;
    font-size: clamp(0.78rem, 1.4vw, 0.9rem);
    color: rgba(15, 23, 42, 0.6);
}

.dashboard-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    flex-wrap: wrap;
}

.dashboard-action-link {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: rgba(255, 255, 255, 0.72);
    box-shadow: var(--shadow-xs);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dashboard-action-link:hover,
.dashboard-action-link:focus-visible {
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
    border-color: rgba(18, 140, 126, 0.35);
}

.dashboard-action-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    position: relative;
}

.dashboard-action-icon i {
    font-size: 1.2rem;
    line-height: 1;
    color: var(--color-primary-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.dashboard-action-link .indicator {
    position: absolute;
    top: 6px;
    right: 6px;
}

.storage-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    height: 100%;
}

.storage-admin {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 20px;
    padding-top: 20px;
    margin-top: 12px;
    border-top: 1px solid rgba(148, 163, 184, 0.25);
}

.storage-admin-photo {
    width: 50%;
    max-width: 220px;
    aspect-ratio: 1 / 1;
    height: auto;
    border-radius: var(--radius-lg);
    object-fit: cover;
    box-shadow: var(--shadow-xs);
}

.storage-admin-body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: center;
}

.storage-admin-body strong {
    font-size: 0.98rem;
    color: var(--color-text);
}

.storage-admin-body span {
    font-size: 0.85rem;
    color: var(--color-muted);
    text-align: center;
}

.card {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    padding: clamp(20px, 3vw, 28px);
    box-shadow: var(--shadow-sm);
}

.card.card--spaced {
    margin-top: clamp(18px, 3vw, 26px);
}

.card-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.card-header .button-group {
    display: inline-flex;
    gap: 8px;
}

.grid {
    display: grid;
    gap: clamp(32px, 4.5vw, 42px);
}

.dashboard>*+* {
    margin-top: clamp(24px, 4vw, 32px);
}

.dashboard-bottom {
    margin-top: clamp(28px, 4vw, 38px);
    align-items: stretch;
}

.grid.two {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.auth-login {
    --auth-login-spacing: clamp(24px, 5vw, 40px);
    display: flex;
    flex-direction: column;
    gap: var(--auth-login-spacing);
    align-items: center;
    justify-content: center;
    padding: var(--auth-login-spacing);
    width: 100%;
    margin: 0;
    min-height: 100vh;
    background: linear-gradient(160deg, rgba(248, 250, 252, 0.9), rgba(241, 245, 249, 0.75));
}

.auth-login__card {
    width: 100%;
    max-width: none;
    display: flex;
    flex-direction: column;
    gap: clamp(18px, 3vw, 28px);
    padding: clamp(26px, 5vw, 36px);
    border-radius: var(--radius-xl, 22px);
    margin: 0;
    box-shadow: 0 20px 48px rgba(15, 23, 42, 0.08);
}

.auth-login__label {
    font-weight: 600;
    color: var(--color-text);
    font-size: 0.95rem;
}

.auth-login__title {
    margin: 0;
    font-size: clamp(1.35rem, 3vw, 1.6rem);
    color: var(--color-text);
}

.auth-login__lead {
    margin: 0;
    font-size: clamp(0.95rem, 2.4vw, 1.05rem);
    line-height: 1.6;
    color: var(--color-muted);
}

.auth-login__hint {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--color-muted);
}

@media (min-width: 768px) {
    .auth-login__card {
        width: 83.333%;
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .auth-login {
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: stretch;
        gap: clamp(12px, 2vw, 22px);
    }

    .auth-login__card {
        flex: 0 1 33.333%;
        width: 33.333%;
        max-width: 420px;
        min-width: 320px;
        margin: 0;
    }
}


.qr-preview {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(15, 23, 42, 0.04);
    border: 1px dashed rgba(15, 23, 42, 0.18);
    border-radius: var(--radius-lg);
    min-height: 260px;
    margin-bottom: 18px;
}

.qr-preview canvas,
.qr-preview img {
    width: 100%;
    height: auto;
    max-width: 280px;
}

.qr-token {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 14px;
    margin-bottom: 12px;
    background: rgba(15, 23, 42, 0.04);
    border: 1px dashed rgba(15, 23, 42, 0.18);
    border-radius: var(--radius-md);
}

.qr-token__info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.qr-token__label {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.qr-token__value {
    font-family: "Fira Code", "SFMono-Regular", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.92rem;
    word-break: break-all;
    color: var(--color-text, #0f172a);
}

.qr-token__feedback {
    font-size: 0.8rem;
    color: var(--color-muted);
    margin: 0 0 16px;
}

.qr-token__feedback.success {
    color: var(--color-primary);
}

.qr-token__feedback.error {
    color: var(--color-danger, #dc2626);
}

.dashboard-stats {
    grid-template-columns: 1fr;
}

@media (min-width: 720px) {
    .dashboard-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1080px) {
    .dashboard-stats {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.dashboard-actions .dashboard-action-link {
    width: 44px;
    height: 44px;
}

@media (max-width: 768px) {
    .dashboard-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .dashboard-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .dashboard-stats {
        grid-template-columns: 1fr;
    }

    .dashboard-actions .dashboard-action-link {
        width: 40px;
        height: 40px;
    }
}

.badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 12px;
    font-size: 0.75rem;
    border-radius: 999px;
    background: rgba(18, 140, 126, 0.12);
    color: var(--color-primary-dark);
    border: 1px solid rgba(18, 140, 126, 0.2);
    font-weight: 600;
}

.badge-success {
    background: rgba(34, 197, 94, 0.18);
    border-color: rgba(34, 197, 94, 0.28);
    color: #047857;
}

.badge-warning {
    background: rgba(250, 204, 21, 0.25);
    border-color: rgba(250, 204, 21, 0.4);
    color: #854d0e;
}

.badge-info {
    background: rgba(59, 130, 246, 0.18);
    border-color: rgba(59, 130, 246, 0.3);
    color: #1d4ed8;
}

.badge-danger {
    background: rgba(239, 68, 68, 0.16);
    border-color: rgba(239, 68, 68, 0.3);
    color: #b91c1c;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 9px 18px;
    border-radius: 999px;
    border: 1px solid transparent;
    background: rgba(18, 140, 126, 0.12);
    color: var(--color-primary-dark);
    font-weight: 600;
    cursor: pointer;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
}

.button-group {
    display: inline-flex;
    gap: 4px;
    align-items: center;
    flex-wrap: nowrap;
}

.button-group .button {
    white-space: nowrap;
}

.button-icon {
    padding: 8px;
    width: 34px;
    height: 34px;
}

.button-icon .fa-solid,
.button-icon .fa-regular,
.button-icon .fa-light {
    pointer-events: none;
}

.checkbox--spaced {
    margin-bottom: 16px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.filter-inline {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.filter-inline label {
    font-weight: 600;
    color: var(--color-muted);
}

.filter-inline .filter-select {
    min-width: 180px;
    padding: 8px 12px;
    border: 1px solid #d2d5da;
    border-radius: 8px;
    background: #fff;
    font-size: 0.95rem;
    line-height: 1.4;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    appearance: none;
}

.filter-inline .filter-select:focus {
    border-color: var(--color-primary, #128c7e);
    box-shadow: 0 0 0 2px rgba(18, 140, 126, 0.18);
    outline: none;
}

.ui-tooltip {
    position: absolute;
    z-index: 2000;
    background: rgba(17, 24, 39, 0.92);
    color: #fff;
    padding: 6px 10px;
    font-size: 0.75rem;
    border-radius: 6px;
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.14);
    transition: opacity 0.15s ease;
    opacity: 1;
    pointer-events: none;
}

.ui-tooltip.hidden {
    opacity: 0;
    visibility: hidden;
}

.button:hover,
.button:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(18, 140, 126, 0.18);
}

.button.is-disabled,
.button[aria-disabled="true"] {
    pointer-events: none;
    opacity: 0.6;
    box-shadow: none;
    transform: none;
}

.button:active {
    transform: translateY(0);
}

.button-primary {
    background: linear-gradient(120deg, var(--color-primary), var(--color-accent));
    border-color: transparent;
    color: #fff;
}

.button-outline {
    background: transparent;
    border-color: rgba(18, 140, 126, 0.38);
    color: var(--color-primary-dark);
}

.button-outline:hover,
.button-outline:focus-visible {
    background: rgba(18, 140, 126, 0.12);
    color: var(--color-primary-dark);
}

.button-danger {
    background: rgba(248, 113, 113, 0.18);
    color: #b91c1c;
    border-color: rgba(248, 113, 113, 0.26);
}

.button-small {
    padding: 6px 14px;
    font-size: 0.82rem;
}

.table-wrapper {
    overflow-x: auto;
}

table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 12px;
    font-size: 0.92rem;
}

th,
td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--color-border);
    text-align: left;
}

th {
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    color: var(--color-muted);
}

tbody tr:hover td {
    background: rgba(18, 140, 126, 0.06);
}

tbody tr:last-child td {
    border-bottom: none;
}

.user-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

.profile-card {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.profile-card__header {
    display: flex;
    gap: 16px;
    align-items: center;
}

.profile-card__avatar {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid rgba(18, 140, 126, 0.2);
    box-shadow: 0 10px 20px rgba(18, 140, 126, 0.15);
}

.profile-card__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.profile-card__body {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.profile-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 14px;
    margin: 0;
}

.profile-meta dt {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-muted);
    margin: 0 0 4px;
}

.profile-meta dd {
    margin: 0;
    font-size: 0.96rem;
}

.profile-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.user-tabs {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px;
    background: rgba(148, 163, 184, 0.18);
    border-radius: 999px;
    margin-bottom: 18px;
}

.user-tab {
    border: none;
    background: transparent;
    padding: 6px 16px;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-muted);
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
}

.user-tab.active {
    background: #fff;
    color: var(--color-primary-dark);
    box-shadow: var(--shadow-sm);
}

.user-tab-panel {
    display: block;
    margin-top: 12px;
}

.user-tab-panel.hidden {
    display: none;
}

.admin-user-panel {
    margin-top: 22px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: clamp(18px, 3vw, 26px);
    background: rgba(248, 250, 252, 0.7);
    box-shadow: var(--shadow-xs);
}

.admin-user-panel.hidden {
    display: none;
}

.admin-user-panel__header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 14px;
}

.admin-user-panel__header h3 {
    margin: 0;
    font-size: 1.05rem;
}

.admin-user-panel__header .text-muted {
    margin: 0;
    font-size: 0.82rem;
}

.profile-qr-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
    text-align: center;
}

.profile-qr {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    border: 1px dashed rgba(18, 140, 126, 0.25);
    border-radius: var(--radius-lg);
    background: rgba(18, 140, 126, 0.05);
}

.profile-qr img {
    width: clamp(180px, 40vw, 260px);
    height: clamp(180px, 40vw, 260px);
    object-fit: contain;
}

.profile-qr-token {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(15, 23, 42, 0.06);
    border-radius: var(--radius-md);
    padding: 10px 14px;
    font-size: 0.88rem;
    flex-wrap: wrap;
    justify-content: center;
}

.profile-qr-token code {
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.86rem;
    color: var(--color-text);
    word-break: break-all;
}

.profile-qr-note {
    margin: 0;
    font-size: 0.82rem;
}

.flash {
    padding: 12px 16px;
    border-radius: var(--radius-md);
    border: 1px solid transparent;
    margin-bottom: 18px;
    font-size: 0.9rem;
}

.flash-success {
    background: rgba(34, 197, 94, 0.15);
    border-color: rgba(34, 197, 94, 0.28);
    color: #166534;
}

.flash-error {
    background: rgba(248, 113, 113, 0.15);
    border-color: rgba(248, 113, 113, 0.28);
    color: #b91c1c;
}

.flash-info {
    background: rgba(37, 211, 102, 0.15);
    border-color: rgba(37, 211, 102, 0.28);
    color: #0369a1;
}

.form-stacked {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.form-stacked label {
    font-weight: 600;
    font-size: 0.9rem;
}

.form-stacked input,
.form-stacked select,
.form-stacked textarea {
    padding: 12px 14px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    background: #fff;
    font-size: 0.95rem;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.form-stacked input:focus,
.form-stacked select:focus,
.form-stacked textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(18, 140, 126, 0.18);
}

.form-stacked input.is-readonly {
    background: rgba(226, 232, 240, 0.6);
    cursor: not-allowed;
}

.form-stacked select.is-readonly {
    background: rgba(226, 232, 240, 0.6);
    cursor: not-allowed;
}

.form-stacked .form-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.input-control,
.input {
    width: 100%;
    padding: 12px 14px;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(148, 163, 184, 0.45);
    background: rgba(255, 255, 255, 0.96);
    font-size: 0.95rem;
    line-height: 1.4;
    color: var(--color-text, #0f172a);
    transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
    appearance: none;
}

.input-control::placeholder,
.input::placeholder {
    color: rgba(100, 116, 139, 0.8);
}

.input-control:focus,
.input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(18, 140, 126, 0.18);
    background: #fff;
}

.input-select {
    width: 100%;
    padding: 12px 14px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    background: #fff;
    font-size: 0.95rem;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.input-select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(18, 140, 126, 0.18);
}

.select-multiple {
    min-height: 160px;
}

.form-compact {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.form-compact input,
.form-compact select {
    padding: 10px 12px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    background: #fff;
    font-size: 0.88rem;
}

.form-compact input:focus,
.form-compact select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(18, 140, 126, 0.18);
}

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

.qr-scanner {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: #0f172a;
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 18px;
}

.qr-scanner video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.qr-scanner__overlay {
    position: absolute;
    inset: 12%;
    border: 2px solid rgba(148, 163, 184, 0.6);
    border-radius: var(--radius-lg);
    box-shadow: 0 0 0 999px rgba(15, 23, 42, 0.35);
    pointer-events: none;
}

.qr-scanner__placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(15, 23, 42, 0.82);
    color: rgba(226, 232, 240, 0.92);
    font-weight: 600;
    letter-spacing: 0.02em;
    text-align: center;
    padding: 18px;
}

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

.qr-hint {
    margin-top: 12px;
    font-size: 0.84rem;
}

.qr-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin: 18px 0;
    font-weight: 600;
    color: rgba(15, 23, 42, 0.58);
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.12em;
}

.qr-divider::before,
.qr-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(148, 163, 184, 0.35);
}

.qr-manual {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.qr-manual__input {
    display: flex;
    gap: 10px;
    align-items: stretch;
}

.qr-manual__input input {
    flex: 1;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(148, 163, 184, 0.45);
    padding: 10px 14px;
    font-size: 0.95rem;
}

.qr-manual__input input:focus-visible {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(18, 140, 126, 0.18);
}

.dashboard-stats .stat-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.stat-value {
    margin: 0;
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--color-primary-dark);
}

.stat-subtext {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.88rem;
}

.storage-meter {
    width: 100%;
    height: 14px;
    border-radius: 999px;
    background: rgba(18, 140, 126, 0.12);
    overflow: hidden;
    margin: 14px 0;
}

.meter-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
}

.notifications-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
    height: 100%;
}

.notification-list-wrapper {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding-right: 4px;
}

.notification-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
    min-height: 0;
}

.notification-list li {
    padding: 12px 16px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: #fff;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition);
}

.notification-list li:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.notification-list li.unread {
    border-color: rgba(18, 140, 126, 0.28);
    background: rgba(18, 140, 126, 0.08);
}

.notif-message {
    font-weight: 600;
}

.notif-meta {
    margin-top: 6px;
    font-size: 0.78rem;
    color: var(--color-muted);
}

.file-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.file-row {
    display: flex;
    align-items: stretch;
    gap: 16px;
    padding: 14px 18px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: #fff;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition);
    min-height: 0;
}

.file-row:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.file-row--received {
    border-color: rgba(18, 140, 126, 0.28);
    background: rgba(18, 140, 126, 0.08);
}

.file-row--selected {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(18, 140, 126, 0.18), var(--shadow-md);
}

.file-row__select {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 24px;
    flex-shrink: 0;
    padding-top: 6px;
    cursor: pointer;
}

.file-row__select--disabled {
    cursor: not-allowed;
    opacity: 0.6;
}

.file-row__select--disabled .file-row__checkbox {
    cursor: not-allowed;
}

.file-row__checkbox {
    width: 18px;
    height: 18px;
    margin: 0;
}

.file-row__thumb {
    width: 64px;
    height: 64px;
    border-radius: var(--radius-md);
    background: rgba(148, 163, 184, 0.18);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

.file-row__thumb-media {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.file-row__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-weight: 700;
    font-size: 0.9rem;
    letter-spacing: 0.04em;
    color: var(--color-primary-dark);
    background: rgba(18, 140, 126, 0.16);
    border-radius: inherit;
}

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

.file-row__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    min-width: 0;
}

.file-row__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text);
    word-break: break-word;
    flex: 1;
    min-width: 0;
}

.file-row__size {
    font-size: 0.82rem;
    color: var(--color-muted);
    white-space: nowrap;
}

.file-row__meta {
    font-size: 0.86rem;
    color: var(--color-muted);
}

.file-row__meta--secondary {
    color: var(--color-text);
}

.file-row__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: auto;
}

.upload-progress {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 12px;
}

.upload-progress__bar {
    display: flex;
    align-items: center;
    gap: 12px;
}

.upload-progress__track {
    flex: 1;
    height: 6px;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.28);
    overflow: hidden;
}

.upload-progress__fill {
    display: block;
    width: 0%;
    height: 100%;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
    transition: width 0.2s ease;
}

.upload-progress__label {
    font-size: 0.85rem;
    color: var(--color-muted);
    min-width: 48px;
    text-align: right;
}

.upload-progress__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 18px 24px;
}

.upload-progress__list {
    display: flex;
    flex-wrap: wrap;
    gap: 18px 24px;
    margin: 0;
    padding: 0;
}

.upload-progress__item {
    min-width: 120px;
}

.upload-progress__item dt {
    margin: 0;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--color-muted);
}

.upload-progress__item dd {
    margin: 4px 0 0;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-text);
}

.upload-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.file-section .flash {
    margin-bottom: 12px;
}

.file-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.file-toolbar .file-search {
    flex: 1 1 220px;
    min-width: 180px;
}

.file-toolbar .input-select {
    flex: 0 0 auto;
    min-width: 140px;
}

.file-toolbar .file-per-page {
    min-width: 160px;
}

.file-pagination {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 18px;
}

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

.pagination-controls .button {
    min-width: 110px;
}

.pagination-info {
    font-size: 0.9rem;
    color: var(--color-muted);
}

.pagination-range {
    font-size: 0.85rem;
    color: var(--color-muted);
}

.file-section.is-loading .file-toolbar,
.file-section.is-loading .file-list,
.file-section.is-loading .file-pagination {
    opacity: 0.6;
    pointer-events: none;
}

.file-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    justify-content: flex-start;
    margin-top: auto;
}

@media (max-width: 768px) {
    .file-list {
        grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    }
}

@media (max-width: 640px) {
    .file-list {
        grid-template-columns: 1fr;
    }
}


.share-modal {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s ease, visibility 0.25s ease;
}

.share-modal:not(.hidden) {
    display: flex;
    opacity: 1;
    visibility: visible;
}

.share-dialog {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    padding: 24px;
    width: min(520px, 100%);
    box-shadow: var(--shadow-md);
    transform: translateY(16px) scale(0.98);
    opacity: 0;
    transition: opacity 0.25s ease, transform 0.3s ease;
}

.share-modal:not(.hidden) .share-dialog {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.share-hint {
    font-size: 0.82rem;
    color: var(--color-muted);
    margin-bottom: 10px;
}

.share-targets {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 12px;
}

.preview-dialog {
    width: min(720px, 100%);
    max-height: calc(100vh - 80px);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.preview-body {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 16px;
    overflow-y: auto;
    flex: 1 1 auto;
}

.preview-body img,
.preview-body video,
.preview-body audio,
.preview-body iframe {
    width: 100%;
    border-radius: var(--radius-md);
    max-height: calc(100vh - 200px);
    object-fit: contain;
}

.preview-body video,
.preview-body iframe {
    min-height: clamp(180px, 40vh, 320px);
    background: #000;
}

.preview-body audio {
    min-height: 54px;
}

.preview-actions {
    justify-content: space-between;
}

.preview-note {
    margin: 0;
    font-size: 0.85rem;
    color: var(--color-muted);
}

.status-chat {
    flex: 1;
    display: flex;
    min-height: 0;
}

.status-container {
    display: grid;
    grid-template-columns: minmax(300px, 340px) minmax(0, 1fr);
    min-height: 0;
    height: 100%;
    background: var(--color-surface);
}

.status-mobile-bar {
    display: none;
}

.status-desktop-actions {
    display: none;
}

.status-desktop-toggle {
    width: 100%;
}

@media (min-width: 1280px) {
    .status-desktop-actions {
        display: flex;
        justify-content: flex-end;
        margin-bottom: 12px;
    }

    .status-chat[data-desktop-composer="collapsed"] .status-composer {
        display: none;
    }
}

@media (max-width: 899px) {
    .status-container {
        grid-template-columns: 1fr;
    }

    .status-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--color-border);
        padding: 20px 18px 24px;
        position: static;
        height: auto;
    }

    .status-main {
        min-height: 60vh;
    }

    .status-thread {
        border-left: none;
        border-top: 1px solid var(--color-border);
    }
}

@media (max-width: 899px) {
    .status-chat {
        flex-direction: column;
        min-height: 100vh;
    }

    .status-container {
        display: flex;
        flex-direction: column;
        flex: 1 1 auto;
        min-height: 0;
    }

    .status-mobile-bar {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px 16px;
        background: var(--color-surface);
        border-bottom: 1px solid var(--color-border);
        position: sticky;
        top: 0;
        z-index: 6;
    }

    .status-mobile-bar__title {
        margin: 0;
        flex: 1;
        font-size: 1rem;
        font-weight: 600;
        text-align: center;
        color: var(--color-strong);
    }

    .status-mobile-bar__back {
        display: none;
        align-items: center;
        justify-content: center;
        width: 36px;
        height: 36px;
        border: none;
        background: transparent;
        color: var(--color-strong);
        font-size: 1.25rem;
        padding: 0;
        border-radius: 999px;
        cursor: pointer;
    }

    .status-mobile-bar__back span {
        display: block;
        line-height: 1;
    }

    .status-mobile-bar__action {
        display: none;
        flex-shrink: 0;
        white-space: nowrap;
    }

    .status-chat[data-mobile-view="composer"] .status-mobile-bar__back,
    .status-chat[data-mobile-view="detail"] .status-mobile-bar__back,
    .status-chat[data-mobile-view="comments"] .status-mobile-bar__back {
        display: inline-flex;
    }

    .status-chat[data-mobile-view="list"] .status-mobile-bar__action,
    .status-chat[data-mobile-view="detail"] .status-mobile-bar__action,
    .status-chat[data-mobile-view="comments"] .status-mobile-bar__action {
        display: inline-flex;
    }

    .status-chat .status-sidebar {
        position: static;
        height: auto;
        align-self: stretch;
        padding: 0;
        gap: 0;
        display: flex;
        flex-direction: column;
        border-right: none;
        flex: 1 1 auto;
        min-height: 0;
    }

    .status-chat .status-main {
        display: none;
        flex: 1 1 auto;
        min-height: 0;
    }

    .status-chat .status-composer,
    .status-chat .status-feed {
        padding: 20px 16px 24px;
    }

    .status-chat .status-composer {
        display: none;
        flex: 0 0 auto;
    }

    .status-chat .status-feed {
        display: block;
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .status-chat[data-mobile-view="composer"] .status-composer {
        display: flex;
        flex-direction: column;
        gap: 16px;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .status-chat[data-mobile-view="detail"] .status-sidebar,
    .status-chat[data-mobile-view="comments"] .status-sidebar {
        display: none;
    }

    .status-chat[data-mobile-view="detail"] .status-main,
    .status-chat[data-mobile-view="comments"] .status-main {
        display: flex;
    }

    .status-chat[data-mobile-view="composer"] .status-feed,
    .status-chat[data-mobile-view="detail"] .status-feed,
    .status-chat[data-mobile-view="comments"] .status-feed {
        display: none;
    }

    .status-chat .status-thread {
        border-left: none;
        border-top: none;
        overflow: visible;
        flex: 1 1 auto;
        display: flex;
        flex-direction: column;
        min-height: 0;
    }

    .status-chat .status-thread-header {
        padding: 16px;
        flex: 0 0 auto;
    }

    .status-chat .status-thread-content {
        display: flex;
        flex-direction: column;
        gap: 20px;
        padding: 16px;
        flex: 1 1 auto;
        min-height: 0;
    }

    .status-chat .status-thread-body {
        height: auto;
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .status-chat .status-placeholder {
        padding: 24px 16px;
    }

    .status-chat[data-mobile-view="detail"] .status-comments {
        display: none;
    }

    .status-chat[data-mobile-view="comments"] .status-thread-body {
        display: none;
    }

    .status-chat[data-mobile-view="comments"] .status-comments {
        display: flex;
    }

    .status-chat .status-comments {
        padding: 20px 16px;
        border-left: none;
        height: auto;
        flex: 1 1 auto;
        min-height: 0;
        overflow: hidden;
    }

    .status-chat .status-comments-pane {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
    }

    .status-chat .status-comments-list {
        max-height: none;
        overflow: auto;
        padding-right: 0;
        flex: 1 1 auto;
        min-height: 0;
        -webkit-overflow-scrolling: touch;
    }

    .status-chat .status-comment-form {
        position: static;
        padding-top: 12px;
        flex: 0 0 auto;
    }

    .status-chat .status-content-frame {
        align-items: stretch;
        justify-content: flex-start;
        overflow-y: auto;
    }

    .status-chat .status-body-video-media,
    .status-chat .status-body-youtube-embed {
        width: 100%;
        max-width: 100%;
        align-self: stretch;
        flex-shrink: 0;
    }

    .status-chat .status-body-youtube-embed {
        aspect-ratio: auto;
        height: clamp(210px, 50vh, 320px);
    }

    .status-chat .status-body-youtube-embed iframe {
        height: 100%;
    }

}

.status-sidebar {
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 22px;
    min-height: 0;
    overflow: visible;
    position: sticky;
    top: 0;
    align-self: flex-start;
    height: 100%;
}

.status-composer {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.status-composer-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
    position: relative;
}

.status-composer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.status-composer-header label {
    margin: 0;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--color-strong);
}

.status-composer-submit {
    margin-left: auto;
}

.status-composer-form textarea {
    min-height: 96px;
    resize: vertical;
}

.status-composer-media {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.status-textarea-wrapper {
    position: relative;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: transparent;
    overflow: visible;
}

.status-textarea-wrapper:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(18, 140, 126, 0.15);
}

.status-textarea-inner {
    display: flex;
    align-items: flex-start;
    width: 100%;
}

.status-textarea-inner textarea {
    flex: 1;
    min-height: 96px;
    resize: vertical;
    padding: 12px;
    border: none;
    background: transparent;
    color: inherit;
    font: inherit;
    outline: none;
    min-width: 0;
    box-shadow: none !important;
}

.status-textarea-inner textarea::placeholder {
    color: var(--color-muted);
}

.status-emoji-toggle {
    border: none;
    background: transparent;
    font-size: 1.15rem;
    cursor: pointer;
    line-height: 1;
    padding: 12px;
    color: var(--color-muted);
    border-radius: 50%;
    transition: transform var(--transition), color var(--transition), background var(--transition);
    flex: 0 0 auto;
}

.status-emoji-toggle:hover,
.status-emoji-toggle:focus-visible {
    transform: translateY(-1px);
    background: rgba(18, 140, 126, 0.12);
    color: var(--color-primary-dark);
}

.status-textarea-wrapper .emoji-panel-wrapper {
    position: absolute;
    top: calc(100% + 12px);
    right: 0;
    left: auto;
    bottom: auto;
    z-index: 30;
    width: min(320px, calc(100vw - 48px));
    max-height: min(260px, calc(100vh - 140px));
}

.status-textarea-wrapper .emoji-panel {
    max-height: inherit;
    overflow-y: auto;
}

.status-comment-textarea .emoji-panel-wrapper {
    top: auto;
    bottom: calc(100% + 12px);
    max-height: min(240px, calc(100vh - 160px));
}

.status-composer-media label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-muted-dark, #0f172a);
}

.status-composer-media input[type="file"],
.status-composer-media input[type="url"] {
    width: 100%;
}

.status-composer-note {
    font-size: 0.78rem;
    color: var(--color-muted);
    margin: 4px 0 0;
}

.status-feed {
    display: flex;
    flex-direction: column;
    gap: 18px;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.status-feed-header {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 12px;
}

.status-tabs {
    width: 100%;
    gap: 8px;
    justify-content: space-between;
    flex-wrap: nowrap;
}

.status-tab {
    font-size: 0.85rem;
}

.status-tabs .chat-tab {
    flex: 1 1 0%;
    padding: 8px 16px;
    white-space: nowrap;
}

.status-search {
    width: 100%;
}

.status-search .chat-search {
    flex: 1;
}

.status-item-avatar {
    position: relative;
    display: inline-flex;
    padding: 2px;
    border-radius: 50%;
    --status-count: 1;
    --status-gap-angle: 0deg;
    --status-ring-color: #9ca3af;
}

.status-item-avatar::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    pointer-events: none;
    background: repeating-conic-gradient(
        from -90deg,
        var(--status-ring-color) 0deg,
        var(--status-ring-color) calc((360deg / var(--status-count)) - var(--status-gap-angle)),
        transparent calc((360deg / var(--status-count)) - var(--status-gap-angle)),
        transparent calc(360deg / var(--status-count))
    );
    mask: radial-gradient(farthest-side, transparent calc(50% - 3px), #000 calc(50% - 1px));
    -webkit-mask: radial-gradient(farthest-side, transparent calc(50% - 3px), #000 calc(50% - 1px));
    transition: background var(--transition), opacity var(--transition);
    opacity: 1;
}

.status-item-avatar.has-status-update::after {
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.15);
}

.status-item-avatar img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    position: relative;
    z-index: 1;
    box-shadow: var(--shadow-xs);
}

.status-item-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
    min-width: 0;
}

.status-item-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px;
}

.status-item-header strong {
    font-size: 0.95rem;
    color: var(--color-strong);
}

.status-item-time {
    font-size: 0.76rem;
    color: var(--color-muted);
    white-space: nowrap;
}

.status-item-head-meta {
    display: flex;
    align-items: center;
    gap: 6px;
}

.status-item-preview,
.status-item-last-comment {
    margin: 0;
    font-size: 0.85rem;
    color: var(--color-muted-dark);
}

.status-item-last-comment {
    color: var(--color-muted);
}

.status-item-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.78rem;
    color: var(--color-muted);
    width: 100%;
}

.status-item-meta--expiry {
    display: block;
    font-size: 0.75rem;
    color: var(--color-muted);
    margin: 4px 0;
}

.status-delete-form {
    display: inline-flex;
    align-items: center;
    margin-left: auto;
}

.status-delete-button {
    border: none;
    background: transparent;
    padding: 6px;
    border-radius: var(--radius-sm);
    color: #dc2626;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), transform var(--transition);
}

.status-delete-button:hover,
.status-delete-button:focus-visible {
    background: rgba(220, 38, 38, 0.12);
    color: #b91c1c;
    outline: none;
}

.status-delete-button:active {
    transform: scale(0.95);
}

.status-delete-icon {
    width: 18px;
    height: 18px;
    display: block;
}

.status-main {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    gap: 0;
    background: #fff;
    overflow: hidden;
}

.status-composer-panel {
    display: none;
}

.status-placeholder {
    margin: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 14px;
    color: var(--color-muted);
    max-width: 360px;
}

.status-placeholder img {
    width: 88px;
    height: 88px;
    border-radius: 50%;
    opacity: 0.35;
}

.status-thread {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    background: #fff;
    border-left: 1px solid var(--color-border);
    overflow-y: auto;
    scrollbar-gutter: stable;
}

.status-thread-content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 1.1fr);
    gap: 24px;
    padding: 24px;
    flex: 1;
    min-height: 0;
    align-items: stretch;
}

.status-thread-content>* {
    min-height: 0;
}

.status-thread-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    padding: 20px 24px;
    border-bottom: 1px solid var(--color-border);
}

.status-owner {
    display: flex;
    align-items: center;
    gap: 12px;
}

.status-owner img {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    object-fit: cover;
}

.status-owner strong {
    display: block;
    font-size: 1rem;
}

.status-owner span {
    display: block;
    font-size: 0.82rem;
    color: var(--color-muted);
}

.status-owner-expiry {
    color: var(--color-primary-dark, #075E54);
    font-size: 0.78rem;
    margin-top: 2px;
}

.status-thread-body {
    display: flex;
    flex-direction: column;
    min-height: 0;
    position: relative;
}

.status-thread-body__scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding-right: 4px;
    padding-bottom: 16px;
}

.status-thread-nav {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 0 0;
    margin-top: 12px;
    border-top: 1px solid var(--color-border);
}

.status-thread-nav__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid var(--color-border);
    background: transparent;
    color: var(--color-text);
    font: inherit;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), border-color var(--transition), opacity var(--transition);
}

.status-thread-nav__button:hover:not([disabled]),
.status-thread-nav__button:focus-visible {
    background: rgba(15, 23, 42, 0.08);
    border-color: rgba(15, 23, 42, 0.1);
}

.status-thread-nav__button:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.status-thread-nav__button[disabled] {
    cursor: not-allowed;
    opacity: 0.45;
    background: transparent;
    border-color: var(--color-border);
}

.status-thread-nav__dots {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 20px;
    flex-wrap: wrap;
    row-gap: 6px;
}

.status-thread-nav__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(148, 163, 184, 0.55);
    transition: transform var(--transition), background var(--transition), opacity var(--transition);
    opacity: 0.6;
    pointer-events: none;
}

.status-thread-nav__dot--active {
    background: var(--color-primary, #128C7E);
    opacity: 1;
    transform: scale(1.15);
}

.status-stats {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 14px;
    font-size: 0.82rem;
    color: var(--color-muted);
}

.status-stats-toggle {
    border: none;
    background: transparent;
    font: inherit;
    color: inherit;
    padding: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    transition: color var(--transition);
}

.status-stats-toggle:hover,
.status-stats-toggle:focus-visible {
    color: var(--color-strong);
}

.status-stats-toggle:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.status-stats-toggle.is-active {
    color: var(--color-primary-dark, #075E54);
    font-weight: 600;
}

.status-views-count,
.status-comments-count {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    position: relative;
}

.status-comments-count::after {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: #22c55e;
    opacity: 0;
    transition: width var(--transition), height var(--transition), opacity var(--transition);
    margin-left: 6px;
}

.status-comments-count.has-new::after {
    width: 8px;
    height: 8px;
    opacity: 1;
}

.status-thread-body {
    padding: 24px;
    background: #f1f5f9;
    border: 1px solid rgba(148, 163, 184, 0.35);
    min-height: 140px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xs);
    height: 100%;
    max-height: 100%;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable both-edges;
}

.status-content-frame {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    min-height: 140px;
    flex: 1;
}

.status-comments {
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 0;
    padding: 24px;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xs);
    height: 100%;
}

.status-comments-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.status-comments-pane,
.status-viewers-pane {
    display: flex;
    flex-direction: column;
    gap: 16px;
    flex: 1;
    min-height: 0;
}

.status-viewers-pane {
    gap: 12px;
}

.status-comments-header h4 {
    margin: 0;
    font-size: 1rem;
    color: var(--color-strong);
}

.status-viewers-trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.82rem;
}

.status-viewers-trigger.is-empty {
    opacity: 0.75;
}

.status-viewers-trigger.is-active {
    color: var(--color-primary-dark, #075E54);
}

.status-viewers-trigger:disabled,
.status-viewers-trigger[aria-disabled="true"] {
    opacity: 0.6;
    pointer-events: none;
}

@media (max-width: 1080px) {
    .status-thread-content {
        grid-template-columns: 1fr;
        padding: 20px;
    }

    .status-thread-body,
    .status-comments {
        padding: 20px;
    }
}

@media (max-width: 960px) {
    .status-thread-content {
        padding: 18px 16px;
    }

    .status-comments {
        box-shadow: none;
    }
}

.status-body-text {
    margin: 0;
    font-size: 1rem;
    line-height: 1.6;
    color: var(--color-text);
    white-space: normal;
    word-break: break-word;
}

.status-link-preview {
    align-self: stretch;
    width: 100%;
    max-width: min(520px, 100%);
}

.status-body-link-preview .status-link-preview {
    align-self: stretch;
}

.status-body-text--empty {
    color: var(--color-muted);
    font-style: italic;
}

.status-body-media,
.status-body-image {
    display: flex;
    flex-direction: column;
    gap: 18px;
    align-items: flex-start;
}

.status-body-image-media {
    width: clamp(220px, 50%, 420px);
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    display: block;
    cursor: zoom-in;
    align-self: center;
}

.status-body-image-media:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 4px;
}

.status-body-video-media {
    width: auto;
    max-width: clamp(220px, 60%, 460px);
    max-height: clamp(280px, 65vh, 520px);
    height: auto;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    background: #000;
    display: block;
    object-fit: contain;
    align-self: center;
}

.status-body-youtube-embed {
    width: clamp(220px, 65%, 520px);
    max-width: 100%;
}

.youtube-embed {
    position: relative;
    width: 100%;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: #000;
    aspect-ratio: 16 / 9;
    box-shadow: var(--shadow-sm);
}

.youtube-embed iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

.status-body-text .message-link {
    color: var(--color-primary-dark, #075E54);
    text-decoration: underline;
}

.status-body-text .message-link:hover,
.status-body-text .message-link:focus-visible {
    color: var(--color-primary);
}

.status-youtube-preview {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-self: stretch;
}

.status-youtube-title {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--color-primary-dark, #075E54);
    text-decoration: none;
    word-break: break-word;
}

.status-youtube-title:hover,
.status-youtube-title:focus-visible {
    text-decoration: underline;
}

.status-youtube-description {
    font-size: 0.82rem;
    color: var(--color-muted);
    margin: 0;
}

.status-youtube-meta {
    font-size: 0.75rem;
    color: var(--color-muted);
}

.status-comments-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding-right: 6px;
}

.status-comments-empty {
    padding: 18px;
    border-radius: var(--radius-md);
    background: rgba(148, 163, 184, 0.12);
    text-align: center;
    font-size: 0.88rem;
    color: var(--color-muted);
}

.status-comment {
    display: grid;
    gap: 10px;
    grid-template-columns: auto 1fr;
}

.status-comment.is-self .status-comment-body {
    background: rgba(18, 140, 126, 0.12);
}

.status-comment-avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    object-fit: cover;
}

.status-comment-body {
    background: rgba(148, 163, 184, 0.12);
    padding: 12px 16px;
    border-radius: var(--radius-md);
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.status-comment-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
    font-size: 0.82rem;
    color: var(--color-muted);
}

.status-comment-header strong {
    color: var(--color-text);
    font-size: 0.9rem;
}

.status-comment-text {
    margin: 0;
    font-size: 0.92rem;
    color: var(--color-text);
    white-space: pre-wrap;
    word-break: break-word;
}

.status-comment-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.status-comment-actions .status-bbcode-guide {
    white-space: nowrap;
}

.bbcode-link {
    color: var(--color-primary);
    text-decoration: underline;
    word-break: break-word;
}

.bbcode-link:hover,
.bbcode-link:focus-visible {
    color: var(--color-primary-dark);
}

.bbcode-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: 999px;
    background: var(--color-primary);
    color: #fff;
    border: none;
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
    box-shadow: var(--shadow-xs);
    transition: background var(--transition), box-shadow var(--transition), transform var(--transition);
    white-space: nowrap;
}

.bbcode-button:hover,
.bbcode-button:focus-visible {
    background: var(--color-primary-dark);
    color: #fff;
    transform: translateY(-1px);
    outline: none;
    box-shadow: 0 6px 18px rgba(18, 140, 126, 0.25);
}

.bbcode-button:active {
    transform: translateY(0);
    box-shadow: var(--shadow-xs);
}

.bbcode-underline {
    text-decoration: underline;
}

.bbcode-small {
    font-size: 0.85em;
}

.bbcode-color {
    color: inherit;
}

.bbcode-highlight {
    padding: 0 4px;
    border-radius: var(--radius-sm);
    color: inherit;
}

.bbcode-size {
    display: inline;
}

.bbcode-font {
    font-weight: inherit;
}

.bbcode-align {
    margin: 8px 0;
}

.bbcode-align--left {
    text-align: left;
}

.bbcode-align--center {
    text-align: center;
}

.bbcode-align--right {
    text-align: right;
}

.bbcode-align--justify {
    text-align: justify;
}

.bbcode-indent {
    margin: 8px 0;
    padding-left: 14px;
    border-left: 3px solid rgba(15, 23, 42, 0.16);
}

.bbcode-hr {
    border: 0;
    border-top: 1px solid var(--color-border);
    margin: 12px 0;
}

.bbcode-code {
    background: #0f172a;
    color: #e2e8f0;
    border-radius: var(--radius-md);
    padding: 14px 16px;
    font-family: 'JetBrains Mono', 'Fira Code', 'Courier New', Courier, monospace;
    font-size: 0.86rem;
    overflow-x: auto;
    position: relative;
}

.bbcode-code[data-lang]:not([data-lang=""])::before {
    content: attr(data-lang);
    display: inline-block;
    margin-bottom: 8px;
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(226, 232, 240, 0.7);
}

.bbcode-code code {
    display: block;
    white-space: pre;
}

.bbcode-quote {
    border-left: 4px solid rgba(18, 140, 126, 0.25);
    background: rgba(18, 140, 126, 0.08);
    padding: 12px 16px;
    border-radius: var(--radius-md);
    margin: 12px 0;
}

.bbcode-quote__cite {
    font-weight: 600;
    color: var(--color-primary-dark);
    margin-bottom: 6px;
}

.bbcode-spoiler {
    margin: 12px 0;
}

.bbcode-spoiler>summary {
    cursor: pointer;
    font-weight: 600;
    outline: none;
}

.bbcode-spoiler__content {
    margin-top: 8px;
    padding: 10px 12px;
    border-radius: var(--radius-sm);
    background: rgba(15, 23, 42, 0.08);
}

.bbcode-image {
    display: block;
    max-width: 100%;
    border-radius: var(--radius-md);
}

.bbcode-video,
.bbcode-audio {
    width: 100%;
    margin: 8px 0;
}

.bbcode-video {
    max-width: 100%;
    border-radius: var(--radius-md);
    background: #000;
}

.bbcode-youtube {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    margin: 12px 0;
    background: #000;
    border-radius: var(--radius-md);
    overflow: hidden;
}

.bbcode-youtube iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.bbcode-table {
    width: 100%;
    border-collapse: collapse;
    margin: 12px 0;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    overflow: hidden;
    font-size: 0.9rem;
}

.bbcode-table th,
.bbcode-table td {
    padding: 8px 12px;
    border-bottom: 1px solid var(--color-border);
    text-align: left;
}

.bbcode-table th {
    background: rgba(15, 23, 42, 0.06);
    font-weight: 600;
}

.bbcode-table tr:last-child td {
    border-bottom: none;
}

.status-comment-link-preview {
    align-self: stretch;
    width: 100%;
}

.status-comment-text--empty {
    font-style: italic;
    color: var(--color-muted);
}

.status-comment-form {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.status-comment-form textarea {
    width: 100%;
    min-height: 72px;
    padding: 12px;
    font-size: 0.95rem;
    resize: vertical;
    border: none;
    background: transparent;
    color: inherit;
    outline: none;
    box-shadow: none;
}

.status-comment-form textarea:focus-visible {
    outline: none;
}

.status-comment-input .status-textarea-inner {
    align-items: flex-start;
}

.status-comment-input .status-textarea-inner textarea {
    min-height: 72px;
}

.status-comment-input .status-emoji-toggle {
    padding: 12px;
}

.status-comment-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    font-size: 0.78rem;
    color: var(--color-muted);
}

.status-comment-actions .comment-hint {
    flex: 1;
}

.status-comment-form.is-submitting .button {
    pointer-events: none;
    opacity: 0.6;
}

.status-comment-form .button {
    min-width: 90px;
}

.status-viewers-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
}

.status-viewer-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.85rem;
    color: var(--color-text);
}

.status-viewer-item img {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
}

.status-viewers-empty {
    font-size: 0.82rem;
    color: var(--color-muted);
}

.status-viewer-item strong {
    display: block;
}

.status-viewer-time {
    display: block;
    font-size: 0.78rem;
    color: var(--color-muted);
    margin-top: 2px;
}

.status-viewers-pane .status-viewers-empty {
    padding: 18px;
    border-radius: var(--radius-md);
    background: rgba(148, 163, 184, 0.12);
    text-align: center;
}

.status-viewers-modal {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.55);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    z-index: 1120;
}

.status-viewers-modal:not(.hidden) {
    display: flex;
}

.status-viewers-modal__dialog {
    width: min(420px, 90vw);
    max-height: 80vh;
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 20px 22px;
}

.status-viewers-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.status-viewers-modal__header h4 {
    margin: 0;
    font-size: 1rem;
    color: var(--color-strong);
}

.status-viewers-close {
    border: none;
    background: transparent;
    font-size: 1.6rem;
    line-height: 1;
    color: var(--color-muted-dark);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.status-viewers-close:hover,
.status-viewers-close:focus-visible {
    color: var(--color-primary);
}

.status-viewers-modal__body {
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
    min-height: 0;
}

.status-viewers-modal__body .status-viewers-list {
    max-height: 55vh;
}

.status-viewers-modal__body .status-viewers-empty {
    text-align: center;
}

.status-loading {
    text-align: center;
    padding: 24px;
    color: var(--color-muted);
    font-size: 0.9rem;
}

.status-image-preview {
    position: fixed;
    inset: 0;
    z-index: 1100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.status-image-preview.hidden {
    display: none;
}

.status-image-preview__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.68);
}

.status-image-preview__dialog {
    position: relative;
    z-index: 1;
    background: rgba(15, 23, 42, 0.92);
    padding: 16px;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    max-width: min(90vw, 720px);
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.status-image-preview__dialog img {
    max-width: 100%;
    max-height: 80vh;
    border-radius: var(--radius-md);
    object-fit: contain;
}

.status-image-preview__close {
    align-self: flex-end;
    border: none;
    background: rgba(255, 255, 255, 0.16);
    color: #fff;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-size: 1.4rem;
    font-weight: 600;
    cursor: pointer;
    line-height: 1;
    display: grid;
    place-items: center;
    transition: background var(--transition);
}

.status-image-preview__close:hover {
    background: rgba(255, 255, 255, 0.26);
}

.status-image-preview__close:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 3px;
}

.share-close {
    border: none;
    background: transparent;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--color-muted);
}

.share-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.share-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 18px;
}

.app-modal {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    display: none;
    align-items: center;
    justify-content: center;
    margin: 0 !important;
    padding: 16px;
    z-index: 2100;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s ease, visibility 0.25s ease;
}

.app-modal:not(.hidden) {
    display: flex;
    opacity: 1;
    visibility: visible;
}

.app-modal__dialog {
    width: min(520px, 100%);
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    transform: translateY(16px) scale(0.98);
    opacity: 0;
    transition: opacity 0.25s ease, transform 0.3s ease;
}

.app-modal:not(.hidden) .app-modal__dialog {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.app-modal__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.app-modal__title {
    margin: 0;
    font-size: 1.2rem;
}

.app-modal__close {
    border: none;
    background: none;
    font-size: 1.6rem;
    cursor: pointer;
    color: var(--color-muted);
}

.app-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.letters-card .user-tabs {
    margin-bottom: 16px;
}

.letters-table td {
    vertical-align: top;
}

.letters-controls {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin-bottom: 16px;
}

.letters-search {
    flex: 1 1 240px;
}

.letters-search .input,
.letters-search input[type="search"] {
    width: 100%;
}

.letters-status-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.letters-status-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.15);
    font-size: 0.85rem;
    color: var(--color-muted);
}

.letters-status-checkbox input {
    margin: 0;
}

.letters-table tr.is-unread td {
    background: rgba(18, 140, 126, 0.06);
}

.letters-recipient-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.letters-recipient-list li {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 0.86rem;
    color: var(--color-text);
}

.letters-recipient-list--summary {
    gap: 4px;
}

.letters-recipient-list--summary li {
    flex-direction: row;
    align-items: baseline;
    gap: 8px;
}

.letters-recipient-org {
    font-weight: 600;
    color: var(--color-text);
}

.letters-recipient-org.is-unread {
    color: #dc2626;
}

.letters-recipient-org.is-partial {
    color: #111827;
}

.letters-recipient-org.is-complete {
    color: #047857;
}

.letters-recipient-counter {
    font-weight: 500;
    color: #6b7280;
    margin-left: 4px;
}

.letters-recipient-list li.is-unread {
    color: var(--color-primary-dark, #0d1b3e);
    font-weight: 600;
}

.letters-recipient-meta {
    font-size: 0.78rem;
    color: var(--color-muted);
}

.letters-recipient-meta--pending {
    color: #e46a11;
}

.letters-send-body {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-height: 260px;
    overflow-y: auto;
    padding-right: 4px;
}

.letters-send-list {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.letters-recipient-option {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
}

.letters-send-feedback {
    min-height: 18px;
    margin: 6px 0;
    font-size: 0.85rem;
}

.letters-send-feedback--error {
    color: #dc2626;
}

.letters-send-feedback--muted {
    color: var(--color-muted);
}

.letters-pagination {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
}

.letters-pagination .letters-page-info {
    font-size: 0.9rem;
    color: var(--color-muted);
}

.letters-send-selectors {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 12px;
}

.letters-send-selectors select {
    width: 100%;
    min-height: 42px;
}

.letters-detail .letters-recipient-summary {
    margin-top: 8px;
}

.letters-detail .letters-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 16px 0 4px;
}


:root {
    --emoji-panel-bg: #ecf6f5;
}

* {
    scrollbar-width: none;
    -ms-overflow-style: none;
}

*::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
}

.text-warning {
    color: #b45309;
    font-weight: 600;
}

.chat {
    display: flex;
    flex: 1;
    min-height: 0;
    height: 100%;
    overflow: hidden;
}

.chat-container {
    display: grid;
    grid-template-columns: minmax(420px, 480px) minmax(0, 1fr);
    gap: 0;
    flex: 1;
    min-height: 0;
    height: 100%;
    background: var(--color-surface);
}

.status-chat .chat-container {
    grid-template-columns: minmax(420px, 480px) minmax(0, 1fr);
}

@media (max-width: 1280px) {
    .chat-container {
        grid-template-columns: minmax(360px, 420px) minmax(0, 1fr);
    }
}

@media (max-width: 1280px) {
    .status-chat .chat-container {
        grid-template-columns: minmax(360px, 420px) minmax(0, 1fr);
    }
}

@media (max-width: 960px) {
    .status-chat .chat-container {
        grid-template-columns: 1fr;
    }
}


.chat.sidebar-collapsed .chat-container {
    grid-template-columns: 1fr;
}

.chat.sidebar-collapsed .chat-sidebar {
    display: none;
}

.chat-sidebar,
.chat-main {
    background: transparent;
    border-radius: 0;
    border: none;
    box-shadow: none;
    overflow: hidden;
    height: 100%;
}

.chat-sidebar {
    border-right: 1px solid var(--color-border);
    padding: 22px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.chat-sidebar-section {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.chat-sidebar-profile .chat-profile {
    display: flex;
    align-items: center;
    gap: 14px;
}

.chat-profile img {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    object-fit: cover;
    box-shadow: var(--shadow-xs);
}

.chat-profile strong {
    display: block;
    font-size: 1rem;
    margin-bottom: 0;
}

.chat-profile-info {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.chat-profile-info .chat-tabs {
    width: 100%;
}

.chat-tip {
    font-size: 0.82rem;
    color: var(--color-muted);
    margin: 0;
}

.chat-search {
    padding: 10px 12px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    background: #fff;
}

.chat-search-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.chat-search-row .chat-search {
    flex: 1;
}

.chat-search-add {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    border: 1px solid var(--color-border);
    background: #fff;
    color: var(--color-muted-dark);
    font-size: 1.1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition);
}

.chat-search-add:hover,
.chat-search-add:focus-visible {
    background: rgba(18, 140, 126, 0.1);
    border-color: var(--color-primary);
    color: var(--color-primary-dark);
    transform: translateY(-1px);
}

.chat-tabs {
    display: flex;
    background: rgba(241, 245, 249, 0.7);
    border-radius: var(--radius-md);
    padding: 4px;
    gap: 6px;
}

.chat-tab {
    flex: 1;
    border: none;
    background: transparent;
    padding: 8px 10px;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--color-muted-dark);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    transition: background var(--transition), color var(--transition);
}

.chat-tab.active {
    background: var(--color-primary);
    color: #fff;
    box-shadow: var(--shadow-xs);
}

.chat-tab .badge {
    background: rgba(255, 255, 255, 0.2);
    color: inherit;
}

.chat-tab .badge.hidden {
    display: none;
}

.chat-tab-panel {
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.chat-tab-panel.hidden {
    display: none;
}

.chat-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
    flex: 1;
    min-height: 0;
}

.chat-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px;
    border-radius: var(--radius-md);
    transition: background var(--transition), transform var(--transition);
    border: 1px solid transparent;
}

.chat-item:hover,
.chat-item.active {
    background: rgba(18, 140, 126, 0.12);
    border-color: rgba(18, 140, 126, 0.2);
}

.chat-item-avatar {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.chat-item-avatar img {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    object-fit: cover;
}

.chat-item-avatar .status {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 2px solid #fff;
    background: var(--color-muted);
}

.chat-item-avatar .status.online {
    background: #16a34a;
}

.chat-item-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.chat-item-header {
    display: flex;
    align-items: baseline;
    gap: 8px;
}

.chat-item-header strong {
    flex: 1;
    min-width: 0;
    font-weight: 600;
    color: var(--color-strong);
}

.chat-item-time {
    font-size: 0.75rem;
    color: var(--color-muted);
    white-space: nowrap;
}

.chat-item-row {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 18px;
}

.chat-item-preview {
    flex: 1;
    min-width: 0;
    font-size: 0.82rem;
    color: var(--color-muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-item-unread {
    background: #128C7E;
    color: #fff;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 2px 6px;
    min-width: 22px;
    text-align: center;
}

.chat-item-unread.hidden {
    display: none;
}

.chat-item-remove {
    border: none;
    background: transparent;
    color: var(--color-muted);
    cursor: pointer;
    padding: 4px;
    border-radius: var(--radius-sm);
    transition: color var(--transition), background var(--transition);
    margin-left: auto;
}

.chat-item-remove:hover {
    color: var(--color-accent);
    background: rgba(226, 232, 240, 0.7);
}

.reply-preview {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 12px;
    border-left: 3px solid #128C7E;
    background: rgba(18, 140, 126, 0.08);
    border-radius: var(--radius-sm);
}

.reply-preview.hidden {
    display: none;
}

.reply-preview-body {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    min-width: 0;
}

.reply-preview-media {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    flex-shrink: 0;
    background: rgba(18, 140, 126, 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
}

.reply-preview-media.hidden {
    display: none;
}

.reply-preview-media img,
.reply-preview-media video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.reply-preview-media .reply-preview-icon {
    font-size: 1.3rem;
}

.reply-preview-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
    min-width: 0;
}

.reply-preview-content strong {
    font-size: 0.78rem;
    color: var(--color-strong);
}

.reply-preview-content span {
    font-size: 0.78rem;
    color: var(--color-muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.reply-preview-cancel {
    border: none;
    background: transparent;
    color: var(--color-muted);
    font-size: 1.1rem;
    cursor: pointer;
    padding: 4px;
    line-height: 1;
}

.reply-preview-cancel:hover {
    color: var(--color-accent);
}

.chat-group-toolbar {
    display: flex;
    justify-content: flex-end;
}

.chat-form {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 14px;
    border: 1px dashed rgba(148, 163, 184, 0.6);
    border-radius: var(--radius-md);
    background: rgba(248, 250, 252, 0.7);
}

.chat-form label {
    font-weight: 600;
    font-size: 0.85rem;
}

.chat-form-row {
    display: flex;
    gap: 8px;
    align-items: center;
}

.chat-form-row input {
    flex: 1;
    padding: 10px 12px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    background: #fff;
}

.chat-form-row button {
    flex: 0 0 46px;
    height: 42px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    font-size: 1.3rem;
    line-height: 1;
}

.chat .button:not(.button-primary):not(.button-danger) {
    background: rgba(51, 65, 85, 0.22);
    border-color: rgba(51, 65, 85, 0.55);
    color: rgba(15, 23, 42, 0.9);
}

.chat .button:not(.button-primary):not(.button-danger):hover,
.chat .button:not(.button-primary):not(.button-danger):focus-visible {
    background: rgba(71, 85, 105, 0.32);
    border-color: rgba(71, 85, 105, 0.6);
    color: rgba(15, 23, 42, 1);
}

.chat-form-feedback {
    font-size: 0.78rem;
    margin: 0;
    min-height: 6px;
}

.chat-form-feedback.success {
    color: #15803d;
}

.chat-form-feedback.error {
    color: #dc2626;
}

.md-code {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: rgba(7, 94, 84, 0.1);
    border-radius: var(--radius-sm);
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 0.85rem;
    color: var(--color-primary-dark);
    justify-content: space-between;
}

.md-code__controls {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.md-code__value {
    letter-spacing: 1px;
}

.md-code__copy {
    font-size: 0.75rem;
}

.md-code .button {
    padding: 4px 8px;
    line-height: 1;
}

.chat-tab .badge {
    font-size: 0.7rem;
    padding: 2px 6px;
}

.group-avatar {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    background: rgba(18, 140, 126, 0.12);
    color: var(--color-primary);
    font-weight: 700;
    font-size: 1.1rem;
}

.group-avatar.has-photo {
    background: transparent;
    padding: 0;
}

.group-avatar .group-initial {
    font-family: 'Inter', sans-serif;
}

.chat-main {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0;
    flex: 1;
    height: 100%;
}

.chat-room {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    height: 100%;
}

.chat-room-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 18px 22px;
    border-bottom: 1px solid var(--color-border);
    background: #fff;
}

.chat-room-header-main {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    min-width: 0;
}

.chat-back-button {
    border: none;
    background: transparent;
    color: var(--color-primary);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
    padding: 0;
    line-height: 1;
}

.chat-back-button:hover,
.chat-back-button:focus-visible {
    background: rgba(18, 140, 126, 0.12);
    color: var(--color-primary-dark);
}

.partner-info {
    display: flex;
    align-items: center;
    gap: 12px;
}

.partner-info strong,
.partner-info .status {
    display: block;
    line-height: 1.2;
}

.partner-info .status {
    margin-top: 2px;
}

.partner-info img {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
}

.chat-room-tools {
    display: flex;
    align-items: center;
    gap: 12px;
}

.chat-room-actions {
    position: relative;
}

.chat-room-options-toggle {
    border: 1px solid var(--color-border);
    background: #fff;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    color: var(--color-muted-dark);
    cursor: pointer;
    box-shadow: var(--shadow-xs);
    transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}

.chat-room-options-toggle:hover,
.chat-room-options-toggle:focus-visible {
    background: rgba(18, 140, 126, 0.12);
    color: var(--color-primary-dark);
    border-color: var(--color-primary);
    transform: translateY(-1px);
}

.chat-room-options-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    min-width: 220px;
    display: flex;
    flex-direction: column;
    padding: 8px 0;
    z-index: 40;
}

.chat-room-options-menu.hidden {
    display: none;
}

.chat-room-option {
    border: none;
    background: transparent;
    padding: 10px 14px;
    text-align: left;
    width: 100%;
    font-size: 0.9rem;
    color: var(--color-muted-dark);
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
}

.chat-room-option:hover,
.chat-room-option:focus-visible {
    background: rgba(18, 140, 126, 0.08);
    color: var(--color-primary-dark);
}

.chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 22px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: rgba(241, 245, 249, 0.6);
    min-height: 0;
}

.chat-message {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-width: 72%;
    align-items: flex-start;
    transition: box-shadow 0.3s ease;
}

.message-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    overflow: hidden;
    background: rgba(148, 163, 184, 0.24);
    border: 1px solid var(--color-border);
    display: none;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.message-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.chat-message.with-avatar .message-avatar {
    display: inline-flex;
}

.chat-new-marker {
    align-self: center;
    margin: 12px 0;
    padding: 6px 14px;
    border-radius: 999px;
    background: var(--color-primary);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 600;
    box-shadow: var(--shadow-sm);
}

.chat-message.me {
    margin-left: auto;
    align-items: flex-end;
}

.message-main {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.chat-message.me .message-main {
    flex-direction: row-reverse;
}

.chat-message .bubble {
    position: relative;
}

.chat-message.auto-reply .bubble {
    box-shadow: 0 0 0 2px rgba(37, 211, 102, 0.25);
}

.chat-message.auto-reply:not(.me) .bubble-meta {
    color: var(--color-accent);
}

.message-menu-toggle {
    position: absolute;
    top: -12px;
    right: -12px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid var(--color-border);
    background: #fff;
    /* color: var(--color-muted-dark); */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    cursor: pointer;
    box-shadow: var(--shadow-xs);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition), transform var(--transition), background var(--transition), border-color var(--transition), color var(--transition);
}

.chat-message:hover .message-menu-toggle,
.chat-message:focus-within .message-menu-toggle,
.message-menu-toggle:focus-visible {
    opacity: 1;
    pointer-events: auto;
}

.message-menu-toggle:hover,
.message-menu-toggle:focus-visible {
    background: rgba(18, 140, 126, 0.12);
    border-color: var(--color-primary);
    color: var(--color-primary-dark);
    transform: translateY(-1px);
}

.message-menu {
    position: fixed;
    z-index: 2000;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    width: min(320px, calc(100vw - 32px));
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-height: 320px;
    overflow-y: auto;
}

.message-menu-section {
    display: flex;
    gap: 8px;
}

.message-menu-reactions {
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 4px;
    align-items: center;
    padding-bottom: 2px;
}

.message-menu-actions {
    flex-direction: column;
    align-items: stretch;
}

.message-menu-emoji {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid transparent;
    background: rgba(241, 245, 249, 0.7);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    cursor: pointer;
    transition: background var(--transition), transform var(--transition), border-color var(--transition);
    flex: 0 0 auto;
}

.message-menu-emoji:hover,
.message-menu-emoji:focus-visible {
    background: rgba(18, 140, 126, 0.12);
    border-color: rgba(18, 140, 126, 0.35);
    transform: translateY(-1px);
}

.message-menu-divider {
    height: 1px;
    width: 100%;
    background: rgba(226, 232, 240, 0.9);
    border-radius: 999px;
}

.message-menu-action {
    border: none;
    background: transparent;
    padding: 8px 10px;
    border-radius: var(--radius-sm);
    text-align: left;
    font-size: 0.9rem;
    color: var(--color-muted-dark);
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
}

.message-menu-action:hover,
.message-menu-action:focus-visible {
    background: rgba(18, 140, 126, 0.08);
    color: var(--color-primary-dark);
}

.message-reactions {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
    position: relative;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-self: flex-start;
}

.message-reactions:not(.has-reactions) {
    margin-top: 0;
}

.chat-message.with-avatar:not(.me) .message-reactions {
    margin-left: calc(36px + 8px);
}

.chat-message.me .message-reactions {
    justify-content: flex-end;
    margin-left: auto;
    align-self: flex-end;
}

.chat-message.me .bubble-actions {
    justify-content: flex-end;
}

.chat-message.is-admin:not(.me) .bubble {
    background: #fff7ed;
    border-color: rgba(234, 179, 8, 0.5);
}

.chat-message.is-admin:not(.me) .bubble-meta,
.chat-message.is-admin:not(.me) .bubble-author {
    color: #b45309;
}

.typing-indicator {
    font-size: 0.82rem;
    color: var(--color-primary-dark);
    font-style: italic;
}

.chat-message {
    position: relative;
}

.chat-message.highlight .bubble {
    box-shadow: 0 0 0 4px rgba(18, 140, 126, 0.3);
    animation: chat-highlight 1.6s ease-out;
}

@keyframes chat-highlight {
    0% {
        box-shadow: 0 0 0 6px rgba(18, 140, 126, 0.35);
    }

    60% {
        box-shadow: 0 0 0 2px rgba(18, 140, 126, 0.12);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(18, 140, 126, 0);
    }
}

.bubble {
    padding: 12px 16px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.bubble.has-media {
    padding: 4px 5px;
}

.bubble.has-media .bubble-content {
    gap: 4px;
}

.bubble.has-media .bubble-meta {
    margin-top: 4px;
}

.bubble.has-media .bubble-content> :not(.message-attachment) {
    padding-left: 12px;
    padding-right: 12px;
}

.bubble.has-media .message-text,
.bubble.has-media .message-reply-preview {
    padding-top: 6px;
    padding-bottom: 6px;
}

.bubble-content {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.bubble-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 0;
}

.bubble-author {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-primary-dark);
    margin-bottom: 0;
}

.bubble-author:not(.hidden) {
    margin-bottom: 4px;
}

.bubble-author.hidden {
    display: none;
}

.chat-message.me .bubble {
    background: linear-gradient(120deg, var(--color-primary), var(--color-accent));
    color: #fff;
    border-color: transparent;
}

.chat-message.me .bubble-author,
.chat-message.me .bubble-meta {
    color: rgba(255, 255, 255, 0.82);
}

.bubble-meta {
    font-size: 0.74rem;
    color: var(--color-muted);
    display: flex;
    justify-content: flex-end;
    margin-top: 12px;
    text-align: right;
    align-items: center;
    gap: 6px;
}

.chat-message.pending .bubble-meta {
    color: var(--color-primary-dark);
    font-weight: 600;
}

.chat-message.me.pending .bubble-meta {
    color: #fff;
}

.message-reply-preview {
    border-left: 3px solid rgba(18, 140, 126, 0.35);
    padding-left: 10px;
    margin-bottom: 8px;
    font-size: 0.78rem;
    color: var(--color-muted);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: background var(--transition);
}

.message-reply-preview .reply-author {
    display: block;
    font-weight: 600;
    color: var(--color-primary-dark);
    margin-bottom: 2px;
}

.message-reply-preview .reply-snippet {
    display: block;
}

.message-reply-preview.has-media .reply-snippet {
    display: flex;
    align-items: center;
    gap: 8px;
}

.reply-snippet-media {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    flex-shrink: 0;
    background: rgba(18, 140, 126, 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
}

.reply-snippet-media img,
.reply-snippet-media video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.reply-snippet-media .reply-snippet-icon {
    font-size: 1.1rem;
}

.reply-snippet-text {
    display: block;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-message.me .message-reply-preview {
    border-left-color: rgba(255, 255, 255, 0.6);
    color: rgba(255, 255, 255, 0.88);
}

.chat-message.me .message-reply-preview .reply-author {
    color: #fff;
}

.chat-message.me .message-reply-preview .reply-snippet {
    color: rgba(255, 255, 255, 0.9);
}

.message-reply-preview:hover,
.message-reply-preview:focus {
    background: rgba(18, 140, 126, 0.08);
    outline: none;
}

.chat-message.me .message-reply-preview:hover,
.chat-message.me .message-reply-preview:focus {
    background: rgba(255, 255, 255, 0.18);
}

.message-attachment {
    margin: 0;
}

.message-attachment img,
.message-attachment video {
    max-width: 100%;
    border-radius: var(--radius-md);
    display: block;
}

.message-attachment--pdf .attachment-pdf-image {
    max-width: none;
}

.message-attachment video {
    background: #000;
}

.attachment-content {
    margin-bottom: 6px;
}

.message-attachment--deleted .attachment-content {
    background: rgba(220, 38, 38, 0.08);
    border: 1px dashed rgba(220, 38, 38, 0.4);
    border-radius: var(--radius-md);
    padding: 10px 12px;
    margin-bottom: 0;
}

.attachment-deleted {
    font-size: 0.85rem;
    color: var(--color-danger, #dc2626);
    line-height: 1.4;
}

.attachment-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    font-size: 0.78rem;
    color: var(--color-muted);
    margin-bottom: 6px;
}

.attachment-name {
    font-weight: 600;
}

.attachment-badge {
    background: rgba(18, 140, 126, 0.12);
    color: var(--color-primary-dark);
    border-radius: var(--radius-sm);
    padding: 2px 6px;
    font-size: 0.7rem;
}

.attachment-actions {
    display: flex;
    gap: 12px;
}

.attachment-action {
    font-size: 0.78rem;
    color: var(--color-primary);
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.attachment-action:hover {
    text-decoration: underline;
}

.attachment-action.saved {
    color: var(--color-muted);
    cursor: default;
    text-decoration: none;
}

.attachment-action.saved:hover {
    text-decoration: none;
}

.chat-message.me .attachment-meta {
    color: rgba(255, 255, 255, 0.85);
}

.chat-message.me .attachment-badge {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

.chat-message.me .attachment-action {
    color: #fff;
}

.chat-message.me .attachment-action.saved {
    color: rgba(255, 255, 255, 0.75);
}

.message-attachment-link {
    color: var(--color-primary-dark);
    text-decoration: none;
    font-weight: 500;
}

.message-attachment-link:hover {
    text-decoration: underline;
}

.message-attachment-link.disabled {
    color: var(--color-muted);
    pointer-events: none;
}

.message-attachment--pdf .attachment-content {
    margin-bottom: 10px;
}

.attachment-pdf-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 100%;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-surface);
    text-decoration: none;
    color: inherit;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.attachment-pdf-card:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-xs);
    border-color: rgba(15, 23, 42, 0.12);
}

.attachment-pdf-card.is-disabled {
    pointer-events: none;
    opacity: 0.7;
}

.chat-message.me .attachment-pdf-card {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.28);
}

.chat-message.me .attachment-pdf-card:hover {
    border-color: rgba(255, 255, 255, 0.4);
    box-shadow: none;
}

.attachment-pdf-preview {
    position: relative;
    width: 100%;
    aspect-ratio: 3 / 1;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(30, 64, 175, 0.12), rgba(59, 130, 246, 0.18));
}

@supports not (aspect-ratio: 1) {
    .attachment-pdf-preview {
        height: 0;
        padding-top: 33.333%;
    }
}

.chat-message.me .attachment-pdf-preview {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.08));
}

.attachment-pdf-image {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: opacity 0.25s ease;
}

.attachment-pdf-image.is-placeholder {
    opacity: 0;
}

.attachment-pdf-preview::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.65), rgba(255, 255, 255, 0.05));
    opacity: 0.55;
    transition: opacity 0.3s ease;
}

.attachment-pdf-preview.is-loaded::after {
    opacity: 0.3;
}

.attachment-pdf-info {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 0 14px 14px;
}

.attachment-pdf-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    font-size: 0.95rem;
    line-height: 1.35;
    color: var(--color-text);
}

.chat-message.me .attachment-pdf-title {
    color: #fff;
}

.attachment-pdf-icon {
    font-size: 1.2rem;
    flex-shrink: 0;
}

.attachment-pdf-name {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.attachment-pdf-details {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    font-size: 0.78rem;
    color: var(--color-muted);
}

.chat-message.me .attachment-pdf-details {
    color: rgba(255, 255, 255, 0.75);
}

.attachment-pdf-pages::before {
    content: '📄';
    margin-right: 4px;
}

.attachment-pdf-meta::before {
    content: '⬇️';
    margin-right: 4px;
}

.message-text {
    font-size: 0.92rem;
    line-height: 1.5;
    color: inherit;
    word-break: break-word;
    margin: 0;
}

.message-colored {
    font-weight: inherit;
}

.message-color-merah {
    color: #dc2626;
}

.message-color-biru {
    color: #128C7E;
}

.message-color-hijau {
    color: #15803d;
}

.message-color-kuning {
    color: #ca8a04;
}

.message-color-oranye {
    color: #ea580c;
}

.message-color-ungu {
    color: #7c3aed;
}

.message-color-teal {
    color: #0f766e;
}

.message-color-pink {
    color: #db2777;
}

.message-deleted-notice {
    font-size: 0.85rem;
    color: var(--color-muted);
    font-style: italic;
    margin-bottom: 6px;
}

.message-text.has-toggle .message-text-full.hidden,
.message-text.has-toggle .message-text-short.hidden {
    display: none;
}

.message-text-toggle {
    display: inline-flex;
    margin-top: 4px;
    border: none;
    background: none;
    color: var(--color-primary-dark);
    font-size: 0.78rem;
    padding: 0;
    cursor: pointer;
}

.chat-message.me .message-text-toggle {
    color: rgba(255, 255, 255, 0.92);
    text-decoration: underline;
}

.chat-message.me .message-text-toggle:hover {
    color: #f1f5ff;
}

.message-link {
    color: #075E54;
    text-decoration: underline;
    word-break: break-all;
}

.message-link:hover {
    color: #1e40af;
}

.chat-message.me .message-link {
    color: #fff;
}

.message-text .youtube-embed {
    margin-top: 12px;
    width: 100%;
    max-width: clamp(200px, 65%, 360px);
}

.chat-message.me .message-text .youtube-embed {
    margin-left: auto;
}

.chat-message.me .message-link:hover {
    color: #e0e7ff;
}

.message-link-preview {
    display: flex;
    gap: 12px;
    margin: 0;
    padding: 12px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(18, 140, 126, 0.15);
    background: rgba(18, 140, 126, 0.05);
    transition: transform var(--transition);
}

.message-link-preview:hover {
    transform: translateY(-1px);
}

.message-link-preview--youtube {
    flex-direction: column;
    gap: 10px;
}

.message-link-preview__thumbnail {
    width: 68px;
    height: 68px;
    border-radius: var(--radius-sm);
    background: rgba(148, 163, 184, 0.2);
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
}

.message-link-preview__thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.message-link-preview__body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.message-link-preview__title {
    font-weight: 600;
    color: var(--color-text);
    font-size: 0.93rem;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
}

.message-link-preview__description {
    font-size: 0.85rem;
    color: var(--color-muted-dark);
    max-height: 3.2em;
    overflow: hidden;
    text-overflow: ellipsis;
}

.message-link-preview__meta {
    font-size: 0.78rem;
    color: var(--color-muted);
}

.message-link-preview__youtube-player {
    width: 100%;
    border-radius: var(--radius-md);
    overflow: hidden;
}

.message-link-preview__body--youtube {
    text-decoration: none;
}

.message-link-preview__body--youtube:hover .message-link-preview__title {
    text-decoration: underline;
}

.chat-message.me .message-link-preview {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.25);
}

.chat-message.me .message-link-preview__title,
.chat-message.me .message-link-preview__description,
.chat-message.me .message-link-preview__meta {
    color: rgba(255, 255, 255, 0.9);
}

.message-delete-menu {
    position: fixed;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.15);
    display: flex;
    flex-direction: column;
    min-width: 180px;
    z-index: 15;
}

.message-delete-option {
    border: none;
    background: transparent;
    padding: 10px 14px;
    font-size: 0.86rem;
    text-align: left;
    color: var(--color-strong);
    cursor: pointer;
}

.message-delete-option:hover {
    background: rgba(18, 140, 126, 0.08);
    color: var(--color-primary-dark);
}

.chat-message.pending .bubble {
    opacity: 0.85;
}

.chat-message.pending .bubble-meta {
    color: var(--color-muted);
}

.bubble-actions {
    position: absolute;
    width: 0;
    height: 0;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    opacity: 0;
    pointer-events: none;
}

.message-reactions {
    position: relative;
}

.reaction-detail {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-height: 320px;
    overflow-y: auto;
}

.reaction-detail-summary {
    font-weight: 600;
    font-size: 0.9rem;
}

.reaction-detail-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.reaction-detail-item {
    display: flex;
    align-items: center;
    gap: 12px;
}

.reaction-detail-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
}

.reaction-detail-avatar.placeholder {
    background: rgba(15, 23, 42, 0.08);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.86rem;
    color: var(--color-primary-dark);
    text-transform: uppercase;
}

.reaction-detail-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
}

.reaction-detail-info strong {
    font-size: 0.9rem;
}

.reaction-detail-time {
    font-size: 0.78rem;
    color: var(--color-muted);
}

.reaction-detail-remove {
    border: none;
    background: none;
    color: var(--color-danger, #dc2626);
    font-size: 0.78rem;
    cursor: pointer;
}

.reaction-detail-remove:hover {
    text-decoration: underline;
}

.reaction-detail-empty {
    font-size: 0.86rem;
    color: var(--color-muted);
}

.forward-preview {
    margin-bottom: 12px;
    font-size: 0.86rem;
}

.forward-hint {
    font-size: 0.8rem;
    color: var(--color-muted);
    margin-bottom: 10px;
}

.forward-target-section {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 14px;
}

.forward-target-section h4 {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-muted);
    margin: 0;
}

.forward-target-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 220px;
    overflow-y: auto;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 8px;
    background: rgba(248, 250, 252, 0.7);
}

.forward-target-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background var(--transition);
}

.forward-target-item:hover,
.forward-target-item:focus-within {
    background: rgba(15, 23, 42, 0.06);
}

.forward-target-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;
    flex-shrink: 0;
    align-self: center;
}

.forward-target-avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    background: var(--color-surface, #fff);
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: var(--shadow-xs);
}

.forward-target-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.forward-target-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
    min-width: 0;
}

.forward-target-title {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

.forward-target-name {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--color-text, #0f172a);
}

.forward-target-time {
    font-size: 0.72rem;
    color: var(--color-muted);
    white-space: nowrap;
}

.forward-target-preview {
    font-size: 0.78rem;
    color: var(--color-muted);
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

.forward-target-empty {
    font-size: 0.8rem;
    color: var(--color-muted);
    text-align: center;
    padding: 12px 8px;
}

.message-reactions .reaction-list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.reaction-chip {
    border: 1px solid var(--color-border);
    background: rgba(15, 23, 42, 0.06);
    border-radius: 999px;
    padding: 2px 8px;
    font-size: 0.78rem;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.reaction-chip.self {
    border-color: var(--color-primary);
    background: rgba(18, 140, 126, 0.18);
    color: var(--color-primary-dark);
}

.reaction-more {
    border: 1px solid var(--color-border);
    background: rgba(15, 23, 42, 0.06);
    border-radius: 999px;
    padding: 2px 8px;
    font-size: 0.78rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.reaction-more:hover,
.reaction-more:focus-visible {
    background: rgba(18, 140, 126, 0.12);
    border-color: var(--color-primary);
    color: var(--color-primary-dark);
}

.message-reactions.is-expanded .reaction-more {
    display: none;
}

.reaction-chip:hover,
.reaction-chip:focus-visible {
    border-color: var(--color-primary);
}

.reaction-add {
    border: none;
    background: rgba(15, 23, 42, 0.08);
    color: var(--color-muted-dark);
    border-radius: 999px;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
}

.message-reactions .reaction-add {
    display: none;
}

.reaction-add:hover,
.reaction-add:focus-visible {
    background: rgba(18, 140, 126, 0.18);
    color: var(--color-primary);
}

.reaction-picker {
    position: absolute;
    bottom: calc(100% + 8px);
    left: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: 6px;
    padding: 6px;
    border-radius: var(--radius-md);
    background: #fff;
    border: 1px solid var(--color-border);
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.18);
    z-index: 80;
}

.chat-message.me .reaction-picker {
    left: auto;
    right: 0;
}

.reaction-option {
    border: none;
    background: none;
    font-size: 1.1rem;
    cursor: pointer;
    padding: 4px;
    line-height: 1;
}

.reaction-option:hover,
.reaction-option:focus-visible {
    transform: scale(1.1);
}

.reaction-option-more {
    font-weight: 600;
    font-size: 1rem;
    background: rgba(15, 23, 42, 0.08);
    border-radius: 50%;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.reaction-option-more:hover,
.reaction-option-more:focus-visible {
    background: rgba(18, 140, 126, 0.18);
    color: var(--color-primary);
}

.chat-composer {
    border-top: 1px solid var(--color-border);
    padding: 16px 22px;
    flex-direction: column;
    background: #fff;
    position: relative;
    flex: 0 0 auto;
}

.chat-composer.is-blocked {
    opacity: 0.65;
}

.chat-composer.is-blocked textarea {
    cursor: not-allowed;
}

.chat-typing {
    padding: 0 22px;
}

.chat-typing .typing-indicator {
    font-size: 0.82rem;
    font-style: italic;
    color: var(--color-primary-dark);
    display: none;
    margin-top: 8px;
}

.chat-typing .typing-indicator:not(.hidden) {
    display: block;
}

.composer-row {
    display: flex;
    gap: 12px;
    align-items: stretch;
}

.composer-main {
    flex: 1 1 auto;
    min-width: 0;
}

.composer-field {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 6px 10px;
    position: relative;
    min-height: 48px;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.composer-field.is-multiline {
    align-items: flex-end;
}

.composer-field:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(18, 140, 126, 0.18);
}

.composer-leading-icon {
    font-size: 1.05rem;
    color: var(--color-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4px;
}

.composer-leading-icon:hover,
.composer-leading-icon:focus-visible {
    color: var(--color-primary);
    outline: none;
}

#chat-message {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 0.95rem;
    line-height: 1.5;
    padding: 0;
    resize: none;
    max-height: calc(1.5em * 5);
    overflow-y: hidden;
}

#chat-message:focus {
    outline: none;
}

.composer-more-toggle,
.composer-icon-button {
    border: none;
    background: transparent;
    color: var(--color-muted);
    font-size: 1.15rem;
    padding: 4px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color var(--transition), background var(--transition);
}

.composer-more-toggle:hover,
.composer-more-toggle:focus-visible,
.composer-icon-button:hover,
.composer-icon-button:focus-visible {
    color: var(--color-primary);
    outline: none;
}

.composer-more {
    display: flex;
    align-items: center;
    gap: 8px;
    position: absolute;
    bottom: calc(100% + 12px);
    right: 0;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: 0 16px 30px rgba(15, 23, 42, 0.18);
    padding: 8px 10px;
    z-index: 40;
    min-width: auto;
}

.composer-more.disabled {
    opacity: 0.4;
    pointer-events: none;
}

.composer-more label,
.composer-more button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: var(--radius-sm);
    background: rgba(18, 140, 126, 0.1);
    color: var(--color-primary-dark);
    border: none;
    font-size: 1rem;
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
}

.composer-more label:hover,
.composer-more label:focus-visible,
.composer-more button:hover,
.composer-more button:focus-visible {
    background: rgba(18, 140, 126, 0.2);
    outline: none;
}

label.attachment {
    margin: 0;
}

label.attachment input {
    display: none;
}

label.attachment.disabled,
.composer-more button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.composer-submit {
    display: flex;
    align-items: stretch;
    justify-content: flex-end;
}

.composer-send {
    width: 52px;
    min-height: 48px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
}

.composer-send span {
    font-size: 1.1rem;
}

#camera-toggle {
    font-size: 1.2rem;
}

#emoji-toggle:disabled,
#camera-toggle:disabled,
#library-toggle:disabled,
#composer-more-toggle:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.composer-more-toggle[aria-expanded="true"] {
    color: var(--color-primary);
}

.attachment-preview {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border: 1px solid rgba(18, 140, 126, 0.15);
    border-radius: var(--radius-md);
    background: rgba(18, 140, 126, 0.08);
    margin-bottom: 12px;
}

.attachment-preview-thumb {
    width: 46px;
    height: 46px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    font-size: 1.5rem;
}

.attachment-preview-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.attachment-preview-info {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.attachment-preview-name {
    font-size: 0.9rem;
    color: var(--color-text);
    word-break: break-word;
}

.attachment-preview-remove {
    border: none;
    background: none;
    color: var(--color-primary-dark);
    font-size: 0.85rem;
    cursor: pointer;
    font-weight: 600;
    padding: 4px 6px;
    border-radius: var(--radius-sm);
    transition: background var(--transition), color var(--transition);
}

.attachment-preview-remove:hover {
    background: rgba(18, 140, 126, 0.15);
}

.status-attachment {
    margin: 12px 0;
    padding: 12px;
    border: 1px solid rgba(18, 140, 126, 0.18);
    border-radius: var(--radius-md);
    background: rgba(18, 140, 126, 0.08);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.status-attachment audio {
    width: 100%;
}

.status-attachment-link {
    font-weight: 600;
    color: var(--color-primary-dark);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    word-break: break-word;
}

.status-attachment-link:hover,
.status-attachment-link:focus {
    text-decoration: underline;
}

.status-attachment-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 0.85rem;
    color: var(--color-muted);
}

.status-attachment-meta span {
    background: rgba(18, 140, 126, 0.15);
    border-radius: var(--radius-sm);
    padding: 2px 6px;
}

.status-body-audio audio {
    max-width: 100%;
}

.status-body-file {
    display: block;
}

.emoji-panel-wrapper {
    position: absolute;
    bottom: calc(100% + 12px);
    left: 22px;
    right: 22px;
    z-index: 20;
}

.emoji-panel {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    background: var(--emoji-panel-bg);
    border-radius: var(--radius-sm);
    padding: 12px;
    width: 100%;
    box-shadow: var(--shadow-md);
    max-height: 240px;
    overflow-y: auto;
    margin-top: 0;
    background: var(--emoji-panel-bg);
}

.emoji-item {
    border: none;
    background: rgba(255, 255, 255, 0.9);
    border-radius: var(--radius-sm);
    padding: 6px 10px;
    font-size: 1.1rem;
    cursor: pointer;
}

.emoji-item:hover {
    background: rgba(18, 140, 126, 0.18);
}

.chat-placeholder {
    margin: auto;
    color: var(--color-muted);
    text-align: center;
    max-width: 320px;
}

.chat-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.78rem;
    color: var(--color-muted);
}

.message-attachment {
    margin-top: 8px;
}

.chat-modal {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1200;
    padding: 24px;
}

.chat-modal.hidden {
    display: none;
}

.chat-modal__dialog {
    background: #fff;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    width: min(420px, 90vw);
    max-height: calc(100vh - 64px);
    padding: 22px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    overflow: hidden;
}

.chat-modal__dialog.bbcode-guide-modal {
    width: min(720px, 95vw);
    max-height: calc(100vh - 80px);
    gap: 20px;
}

.bbcode-guide-body {
    overflow-y: auto;
    max-height: calc(100vh - 180px);
    display: flex;
    flex-direction: column;
    gap: 20px;
    font-size: 0.9rem;
    color: var(--color-text);
}

.bbcode-guide-intro {
    padding: 16px 18px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: rgba(15, 23, 42, 0.04);
    line-height: 1.6;
}

.bbcode-guide-intro p {
    margin: 0;
}

.bbcode-guide-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.bbcode-guide-section {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-surface);
    padding: 18px 20px;
    box-shadow: var(--shadow-xs);
}

.bbcode-guide-section__header {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin: 0 0 14px;
}

.bbcode-guide-section__header h4 {
    margin: 0;
    font-size: 1rem;
    color: var(--color-primary-dark);
}

.bbcode-guide-section__summary {
    margin: 0;
    font-size: 0.82rem;
    color: var(--color-muted);
}

.bbcode-guide-section ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    font-size: 0.85rem;
    line-height: 1.6;
}

.bbcode-guide-section li {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 12px 0;
}

.bbcode-guide-section li:first-child {
    padding-top: 0;
}

.bbcode-guide-section li:last-child {
    padding-bottom: 0;
}

.bbcode-guide-section li+li {
    border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.bbcode-guide-section li code {
    background: rgba(15, 23, 42, 0.08);
    padding: 6px 8px;
    border-radius: 6px;
    font-size: 0.84rem;
    display: block;
    overflow-wrap: anywhere;
    line-height: 1.4;
}

.bbcode-guide-section pre {
    margin: 0;
}

.bbcode-guide-section pre code {
    white-space: pre-wrap;
}

.bbcode-guide-note {
    font-size: 0.86rem;
    color: var(--color-primary-dark);
    padding: 12px 16px;
    border-radius: var(--radius-md);
    background: rgba(18, 140, 126, 0.1);
    border-left: 3px solid var(--color-primary);
}


.chat-modal form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.chat-modal label {
    font-weight: 600;
    font-size: 0.85rem;
}

.chat-modal input[type="text"],
.chat-modal input[type="number"],
.chat-modal select {
    width: 100%;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    font-size: 0.95rem;
    background: #fff;
    transition: border var(--transition), box-shadow var(--transition);
}

.chat-modal input[type="text"]:focus,
.chat-modal input[type="number"]:focus,
.chat-modal select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(18, 140, 126, 0.12);
}

.chat-modal fieldset {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    background: rgba(248, 250, 252, 0.7);
}

.chat-modal legend {
    font-weight: 600;
    padding: 0 6px;
    font-size: 0.85rem;
}

#forward-form {
    display: flex;
    flex-direction: column;
    gap: 0;
    flex: 1;
    min-height: 0;
}

.forward-modal-body {
    flex: 1;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-bottom: 4px;
    min-height: 0;
}

#forward-form .chat-modal__actions {
    margin-top: 16px;
}

.chat-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.chat-modal__close {
    border: none;
    background: transparent;
    color: var(--color-muted);
    font-size: 1.6rem;
    line-height: 1;
    cursor: pointer;
}

.chat-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.formatting-guide {
    display: flex;
    flex-direction: column;
    gap: 12px;
    font-size: 0.9rem;
}

.formatting-guide-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.formatting-guide-list li {
    display: flex;
    align-items: center;
    gap: 10px;
}

.formatting-guide-list code {
    background: rgba(15, 23, 42, 0.08);
    border-radius: var(--radius-sm);
    padding: 4px 8px;
    font-size: 0.85rem;
    font-family: "Fira Code", "SFMono-Regular", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.image-preview-overlay {
    position: fixed;
    inset: 0;
    background: rgba(8, 13, 26, 0.95);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 1400;
}

.image-preview-overlay:not(.hidden) {
    display: flex;
}

.app-content>.image-preview-overlay {
    margin-top: 0 !important;
}

.image-preview-overlay img {
    max-width: 100vw;
    max-height: 100vh;
    object-fit: contain;
    border-radius: 0;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
    background: #000;
}

.image-preview-close {
    position: fixed;
    top: 20px;
    right: 24px;
    background: rgba(15, 23, 42, 0.58);
    border: none;
    color: #fff;
    width: 48px;
    height: 48px;
    border-radius: 999px;
    font-size: 1.6rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s ease;
}

.image-preview-close:hover,
.image-preview-close:focus-visible {
    background: rgba(15, 23, 42, 0.85);
    outline: none;
}

body.image-preview-active {
    overscroll-behavior: none;
}

body.image-preview-active .chat-main,
body.image-preview-active #chat-messages {
    overflow: hidden;
}

.camera-modal {
    max-width: 500px;
    padding: 0;
    overflow: hidden;
}

.camera-modal__body {
    padding: 18px 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.camera-preview {
    position: relative;
    background: #000;
    border-radius: var(--radius-md);
    overflow: hidden;
    min-height: 260px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.camera-preview__video,
.camera-preview__canvas {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.camera-preview__placeholder {
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.95rem;
    text-align: center;
    padding: 24px;
}

.camera-modal__controls {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    padding: 0 24px 20px;
}

.camera-status {
    font-size: 0.84rem;
    min-height: 1.2em;
}

.contact-detail {
    max-width: 420px;
}

.contact-detail__body {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.contact-detail__identity {
    display: flex;
    align-items: center;
    gap: 16px;
}

.contact-detail__photo img {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: var(--shadow-sm);
}

.contact-detail__info strong {
    font-size: 1.1rem;
    display: block;
}

.contact-detail__status {
    font-size: 0.86rem;
    color: var(--color-muted-dark);
}

.contact-detail__status.is-online {
    color: var(--color-primary);
    font-weight: 600;
}

.contact-detail__meta {
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
}

.contact-detail__meta dt {
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-muted);
    margin-bottom: 4px;
}

.contact-detail__meta dd {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 600;
}

.contact-detail__actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.contact-detail__actions .button {
    flex: 1 1 120px;
}

.group-detail-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.group-detail-modal {
    margin: 0 !important;
    padding: 0;
    gap: 0;
    width: min(480px, 92vw);
}

.group-detail-form {
    height: 100%;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    gap: 0;
    min-height: 0;
    overflow: hidden;
}

.group-detail-modal__header {
    padding: 22px 22px 16px;
    border-bottom: 1px solid var(--color-border);
}

.group-detail-body {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: 20px 22px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.group-detail-body>label {
    font-weight: 600;
    font-size: 0.85rem;
}

.group-detail-footer {
    padding: 16px 22px 22px;
    border-top: 1px solid var(--color-border);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
}

.group-detail-footer .chat-form-feedback {
    margin: 0;
    flex-basis: 100%;
}

.text-formatting-popup {
    position: absolute;
    z-index: 1600;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    padding: 6px 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.text-formatting-button {
    border: none;
    background: transparent;
    color: var(--color-text, #0f172a);
    font-weight: 700;
    font-size: 0.92rem;
    width: 28px;
    height: 28px;
    line-height: 1;
    border-radius: var(--radius-sm);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition), color var(--transition);
}

.text-formatting-button--color {
    font-weight: 600;
}

.text-formatting-button:hover,
.text-formatting-button:focus-visible {
    background: rgba(18, 140, 126, 0.15);
    outline: none;
}

.text-formatting-color {
    position: relative;
}

.text-formatting-colors {
    position: absolute;
    top: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-xs);
    padding: 6px;
    display: grid;
    grid-template-columns: repeat(4, 20px);
    gap: 6px;
    z-index: 1700;
}

.text-formatting-color__item {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    padding: 0;
}

.text-formatting-color__item:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.text-formatting-color__item--merah {
    background: #dc2626;
}

.text-formatting-color__item--biru {
    background: #128C7E;
}

.text-formatting-color__item--hijau {
    background: #15803d;
}

.text-formatting-color__item--kuning {
    background: #ca8a04;
}

.text-formatting-color__item--oranye {
    background: #ea580c;
}

.text-formatting-color__item--ungu {
    background: #7c3aed;
}

.text-formatting-color__item--teal {
    background: #0f766e;
}

.text-formatting-color__item--pink {
    background: #db2777;
}

.group-photo-settings {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 18px;
}

.group-photo-preview {
    width: 120px;
    height: 120px;
    border-radius: 18px;
    background: rgba(15, 23, 42, 0.06);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    aspect-ratio: 1 / 1;
}

.group-photo-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.group-photo-placeholder {
    font-size: 0.85rem;
    color: var(--color-muted);
    text-align: center;
    padding: 0 8px;
}

.group-photo-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.group-detail-members {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.group-detail-member {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: rgba(248, 250, 252, 0.7);
}

.group-detail-member-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

.group-detail-member-header strong {
    font-size: 0.95rem;
}

.group-detail-member-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.group-detail-role {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-muted);
}

.group-detail-add {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.group-detail-add-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.9rem;
    font-weight: 500;
}

.group-detail-add-item input[type="checkbox"] {
    accent-color: var(--color-primary);
}

.group-member-codes,
.group-detail-add-codes {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 12px;
}

.group-member-codes label,
.group-detail-add-codes label {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--color-muted);
}

.group-member-codes p,
.group-detail-add-codes p {
    margin: 0;
    font-size: 0.78rem;
    color: var(--color-muted);
}

textarea.md-code-textarea {
    display: block;
    width: 100%;
    min-height: 72px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    font-size: 0.95rem;
    line-height: 1.5;
    color: var(--color-text);
    background: #fff;
    resize: vertical;
    transition: border-color var(--transition), box-shadow var(--transition);
}

textarea.md-code-textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(18, 140, 126, 0.12);
}

textarea.md-code-textarea::placeholder {
    color: var(--color-muted);
    opacity: 0.85;
}

.group-detail-danger {
    display: flex;
    gap: 12px;
    margin-top: 0;
    flex-wrap: wrap;
}

.group-detail-danger .button {
    flex: 0 0 auto;
}

.chat-modal__dialog.library-modal {
    width: min(960px, 95vw);
    max-height: calc(100vh - 64px);
    padding: 28px;
}

@media (max-width: 640px) {
    .chat-modal__dialog.library-modal {
        width: 100%;
        height: 100vh;
        max-height: none;
        border-radius: 0;
        padding: 20px 16px 24px;
    }
}

.library-body {
    display: flex;
    flex-direction: column;
    gap: 18px;
    height: 100%;
    overflow: hidden;
}

.library-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
    justify-content: space-between;
}

.library-search {
    flex: 1 1 260px;
}

.library-search input[type="search"] {
    width: 100%;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 10px 14px;
    font-size: 0.95rem;
    background: #fff;
    transition: border var(--transition), box-shadow var(--transition);
}

.library-search input[type="search"]:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(18, 140, 126, 0.18);
}

.library-controls {
    display: flex;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
}

.library-filter-group {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.library-filter-scroller {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    max-width: 100%;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
}

.library-filter-scroller::-webkit-scrollbar {
    height: 6px;
}

.library-filter-scroller::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.6);
    border-radius: 999px;
}

.library-filter-scroller::-webkit-scrollbar-track {
    background: transparent;
}

.library-filter-scroller>.library-filter+.library-filter {
    margin-left: 8px;
}

.library-filter {
    border: 1px solid var(--color-border);
    background: #fff;
    border-radius: var(--radius-sm);
    padding: 8px 14px;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), border var(--transition), transform var(--transition);
    flex: 0 0 auto;
    white-space: nowrap;
}

.library-filter:hover {
    border-color: var(--color-primary);
    transform: translateY(-1px);
}

.library-filter.is-active {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.library-extension {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 150px;
}

.library-extension label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-muted);
}

.library-extension select {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    font-size: 0.9rem;
}

.library-content {
    display: flex;
    gap: 20px;
    flex: 1;
    min-height: 0;
}

.library-results {
    flex: 1 1 60%;
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-width: 0;
}

.library-list {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    overflow-y: auto;
    padding-right: 6px;
}

.library-item {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 10px 14px;
    background: #fff;
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: 12px;
    align-items: center;
    text-align: left;
    cursor: pointer;
    transition: border var(--transition), box-shadow var(--transition), background var(--transition);
    min-height: 68px;
}

.library-item:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-xs);
    background: rgba(18, 140, 126, 0.05);
}

.library-item.is-selected {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(18, 140, 126, 0.4);
    background: rgba(18, 140, 126, 0.08);
}

.library-item__thumb {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-sm);
    background: rgba(148, 163, 184, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
    position: relative;
}

.library-item__thumb img,
.library-item__thumb video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: inherit;
}

.library-item__thumb video {
    background: #000;
}

.library-item__thumb .library-item__icon {
    font-size: 1.4rem;
}

.library-item__body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
    justify-content: center;
}

.library-item__name {
    font-weight: 600;
    font-size: 0.92rem;
    color: var(--color-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.library-item__meta {
    font-size: 0.78rem;
    color: var(--color-muted);
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
    line-height: 1.25;
}

.library-item__expiry {
    font-size: 0.74rem;
    color: var(--color-muted);
    line-height: 1.3;
}

.library-item__meta span {
    display: inline-flex;
    align-items: center;
}

.library-item__meta span+span::before {
    content: '';
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: currentColor;
    margin: 0 6px 0 -3px;
    display: inline-flex;
}

.library-empty {
    text-align: center;
    padding: 36px 12px;
    color: var(--color-muted);
    font-size: 0.9rem;
}

.library-pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    font-size: 0.85rem;
    color: var(--color-muted);
}

.library-pagination-controls {
    display: inline-flex;
    gap: 8px;
    align-items: center;
}

.library-pagination-info {
    flex: 1;
}

.library-pagination-size {
    display: flex;
    align-items: center;
    gap: 6px;
}

.library-pagination-size select {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 6px 10px;
    font-size: 0.85rem;
}

.library-page-indicator {
    font-weight: 600;
}

.library-page-button {
    border: 1px solid var(--color-border);
    background: #fff;
    border-radius: var(--radius-sm);
    padding: 6px 10px;
    font-size: 0.82rem;
    cursor: pointer;
    transition: border var(--transition), background var(--transition);
}

.library-page-button:disabled {
    opacity: 0.5;
    cursor: default;
}

.library-page-button:not(:disabled):hover {
    border-color: var(--color-primary);
    background: rgba(18, 140, 126, 0.08);
}

.library-preview {
    flex: 0 0 300px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: #f8fafc;
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 0;
    overflow-y: auto;
}

.library-preview-placeholder {
    margin: auto 0;
    text-align: center;
    color: var(--color-muted);
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: center;
    justify-content: center;
    min-height: 160px;
}

.library-preview-content {
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 0;
}

.library-preview-media {
    border-radius: var(--radius-md);
    background: rgba(148, 163, 184, 0.15);
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    overflow: hidden;
}

.library-preview-media img,
.library-preview-media video {
    max-width: 100%;
    max-height: 260px;
    border-radius: var(--radius-md);
    display: block;
}

.library-preview-media audio {
    width: 100%;
}

.library-preview-icon {
    font-size: 2.4rem;
    color: var(--color-muted);
}

.library-preview-info {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.library-preview-info h4 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text);
}

.library-preview-meta {
    margin: 0;
    font-size: 0.85rem;
    color: var(--color-muted);
}

#library-use-button {
    align-self: stretch;
    justify-content: center;
}

.library-preview-modal {
    width: min(420px, 90vw);
    max-height: calc(100vh - 80px);
}

.library-preview-modal-body {
    display: flex;
    flex-direction: column;
    gap: 16px;
    max-height: calc(100vh - 160px);
    overflow-y: auto;
}

.library-preview-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

@media (max-width: 960px) {
    .library-content {
        flex-direction: column;
    }

    .library-preview {
        flex: 1 1 auto;
        min-height: 220px;
        margin-top: 8px;
    }

    .library-results {
        min-height: 200px;
    }
}

@media (max-width: 640px) {
    .library-filter-group {
        width: 100%;
        justify-content: flex-start;
    }

    .library-controls {
        width: 100%;
        align-items: stretch;
        flex-direction: column;
    }

    .library-extension {
        width: 100%;
    }

    .library-body {
        overflow-y: auto;
    }

    .library-content {
        flex-direction: column;
        gap: 16px;
    }

    .library-preview {
        display: none;
    }

    #library-use-button {
        display: none;
    }

    .library-preview-modal {
        width: min(90vw, 380px);
    }

    .library-list {
        padding-right: 0;
    }

    .library-pagination {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }

    .library-pagination-controls {
        width: 100%;
        justify-content: space-between;
    }

    .library-pagination-size {
        align-self: flex-end;
    }
}

.group-member-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 200px;
    overflow-y: auto;
}

.group-member-list label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
}

.message-attachment img,
.message-attachment video {
    max-width: 220px;
    border-radius: var(--radius-md);
    display: block;
}

.settings>.card {
    margin-top: 24px;
}

.auto-reply-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.auto-reply-card--rule-form,
.auto-reply-card--rules {
    position: relative;
}

.auto-reply-card--rule-form h3,
.auto-reply-card--rules h2 {
    margin-top: 0;
    margin-bottom: 16px;
    padding-right: 160px;
}

.auto-reply-match-help-button,
.auto-reply-add-button {
    position: absolute;
    top: 16px;
    right: 16px;
}

.auto-reply-match-help-button,
.auto-reply-add-button {
    z-index: 1;
}

.auto-reply-card--rule-form h3,
.auto-reply-card--rules h2 {
    word-break: break-word;
}

.auto-reply-toggle-row {
    display: flex;
    align-items: center;
}

.auto-reply-toggle-form {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.toggle-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.toggle-switch input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

.toggle-switch-slider {
    position: relative;
    display: inline-block;
    width: 52px;
    height: 28px;
    background: rgba(15, 23, 42, 0.2);
    border-radius: 14px;
    transition: background 0.2s ease;
    cursor: pointer;
}

.toggle-switch-slider::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 4px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 6px rgba(15, 23, 42, 0.25);
    transition: transform 0.2s ease;
}

.toggle-switch input:checked + .toggle-switch-slider {
    background: var(--color-success);
}

.toggle-switch input:checked + .toggle-switch-slider::after {
    transform: translateX(24px);
}

.toggle-switch input:focus-visible + .toggle-switch-slider {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.auto-reply-toggle-status {
    font-weight: 600;
    color: var(--color-muted-dark);
}

#autoReplyMatchHelpModal .app-modal__dialog {
    width: min(100%, 960px);
}

@media (min-width: 1024px) {
    #autoReplyMatchHelpModal .app-modal__dialog {
        width: min(80vw, 960px);
    }
}

@media (max-width: 480px) {
    .auto-reply-card--rule-form h3,
    .auto-reply-card--rules h2 {
        padding-right: 120px;
    }
}

.auto-reply-placeholders {
    background: rgba(15, 23, 42, 0.03);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-md);
    padding: 12px 16px;
    font-size: 0.9rem;
}

.placeholder-list {
    list-style: disc;
    margin: 8px 0 0;
    padding-left: 20px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 6px 20px;
}

.placeholder-list code {
    font-family: var(--font-mono);
    background: rgba(15, 23, 42, 0.08);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
}

.auto-reply-rule {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 16px;
    background: #fff;
    margin-top: 16px;
}

.auto-reply-rule:first-of-type {
    margin-top: 12px;
}

.auto-reply-rule-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
}

.auto-reply-rule-meta {
    font-size: 0.85rem;
    color: var(--color-muted);
}

.auto-reply-rule-form label {
    font-weight: 600;
    margin-top: 10px;
    color: var(--color-muted-dark);
}

.auto-reply-rule-form input[type="text"],
.auto-reply-rule-form input[type="number"],
.auto-reply-rule-form select,
.auto-reply-rule-form textarea {
    width: 100%;
}

.auto-reply-rule-form textarea {
    min-height: 96px;
}

.rule-actions {
    display: flex;
    gap: 12px;
    margin-top: 12px;
}

.auto-reply-rule-delete {
    margin-top: 8px;
}

.auto-reply-triggers {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 8px;
}

.auto-reply-trigger-grid {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(220px, 2fr) auto;
    gap: 12px;
    align-items: end;
}

.auto-reply-trigger-field select,
.auto-reply-trigger-field input {
    width: 100%;
    font-size: 0.95rem;
}

.auto-reply-trigger-caption {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-muted-dark);
    margin-bottom: 4px;
}

.auto-reply-trigger-add {
    align-self: flex-start;
    margin-top: 8px;
}

.auto-reply-trigger-always input[disabled] {
    background: rgba(15, 23, 42, 0.05);
    cursor: not-allowed;
}

.auto-reply-admin-trigger-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.auto-reply-admin-trigger-list li {
    margin-bottom: 4px;
}

.auto-reply-admin-trigger-list code {
    font-family: var(--font-mono);
    font-size: 0.85rem;
    margin-left: 4px;
}

@media (max-width: 768px) {
    .auto-reply-trigger-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .auto-reply-trigger-grid>button {
        justify-self: flex-start;
    }
}

.settings img.profile-preview {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    object-fit: cover;
}

.settings img.logo-preview {
    width: 110px;
    height: 110px;
    border-radius: var(--radius-md);
    object-fit: contain;
    background: rgba(18, 140, 126, 0.08);
    padding: 8px;
}

.status-filter-form {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 12px;
}

.status-filter-form label {
    font-weight: 600;
    color: var(--color-muted-dark);
}

.status-filter-form select {
    min-width: 180px;
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: #fff;
    font-size: 0.95rem;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.status-filter-form select:focus-visible {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(18, 140, 126, 0.2);
    outline: none;
}

.app-bottom-nav {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 900;
    display: none;
    padding: 10px 0;
    background: #0f172a;
    border-top: 1px solid rgba(148, 163, 184, 0.2);
    box-shadow: 0 -8px 20px rgba(15, 23, 42, 0.22);
}

.app-bottom-nav__list {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.app-bottom-nav__item {
    flex: 1;
}

.bottom-nav-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 10px 6px;
    border-radius: 0;
    font-size: 0.5rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.72);
    transition: background var(--transition), color var(--transition), transform var(--transition);
    width: 100%;
}

.bottom-nav-link__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    position: relative;
}

.bottom-nav-link__icon .indicator {
    position: absolute;
    top: -2px;
    right: -2px;
}

.bottom-nav-link__icon i {
    font-size: 1.05rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.bottom-nav-link__label {
    line-height: 1;
}

.bottom-nav-link.active,
.bottom-nav-link:hover,
.bottom-nav-link:focus-visible {
    background: rgba(18, 140, 126, 0.28);
    color: #fff;
    transform: translateY(-1px);
}

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

    .chat-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--color-border);
    }
}

@media (max-width: 960px) {
    .app-header {
        padding: 16px 22px 0;
    }

    .app-header-inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 16px;
        flex-wrap: nowrap;
        padding: 16px 20px;
    }

    .app-header-panel {
        gap: 8px;
    }

    .app-header-panel--actions {
        flex: 1 1 auto;
        justify-content: flex-end;
        gap: 6px;
        flex-wrap: nowrap;
        min-width: 0;
    }

    body:not(.header-collapsed) .app-header-panel--end {
        position: static;
        margin-left: -4px;
        flex: 0 0 auto;
        transform: none;
        pointer-events: auto;
    }

    .app-header-action {
        width: 40px;
        height: 40px;
    }

    body.header-collapsed .app-header-inner {
        justify-content: flex-end;
        padding: 12px 14px;
    }

    .app-content {
        padding: 0 22px;
    }

    .app-content.chat-layout {
        padding: 0;
    }

    .status-dialog {
        grid-template-columns: 1fr;
    }

    .status-info {
        border-left: none;
        border-top: 1px solid var(--color-border);
        padding-left: 0;
        padding-top: 18px;
    }
}

@media (max-width: 720px) {
    body {
        padding-bottom: 0;
    }

    .app-header {
        padding: 12px 18px 0;
    }

    .app-header-brand__text {
        display: none;
    }

    .app-header-brand__logo {
        width: 34px;
        height: 34px;
        padding: 4px;
    }

    .app-header-inner {
        gap: 8px;
        padding: 12px 14px;
    }

    .app-header-panel {
        gap: 6px;
    }

    .app-header-panel--start {
        flex: 0 0 auto;
    }

    .app-header-panel--actions {
        gap: 4px;
        flex-wrap: nowrap;
        justify-content: flex-end;
    }

    body:not(.header-collapsed) .app-header-panel--end {
        margin-left: -4px;
    }

    .header-collapse-toggle {
        padding: 2px;
    }

    .app-header-action {
        width: 34px;
        height: 34px;
    }

    .header-collapse-toggle {
        width: 34px;
        height: 34px;
    }

    .app-bottom-nav {
        display: none;
    }

    .app-content {
        margin-top: 24px;
        padding: 0 18px;
        margin-bottom: 0;
    }

    .app-content.chat-layout {
        --chat-layout-padding-x: 0px;
        --chat-layout-padding-y: 0px;
        --chat-layout-offset: calc(24px + env(safe-area-inset-bottom, 0px));
        padding: 0;
        margin: 0;
        min-height: var(--chat-layout-height);
    }

    .card {
        padding: 18px;
    }

    table {
        font-size: 0.88rem;
    }

    th,
    td {
        padding: 10px 12px;
    }

    .file-row {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }

    .file-row__select {
        width: auto;
        justify-content: flex-start;
        padding-top: 0;
        margin-bottom: 4px;
    }

    .file-row__thumb {
        width: 100%;
        height: 180px;
    }

    .file-row__header {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }

    .file-row__actions {
        width: 100%;
        justify-content: flex-start;
    }

    .chat-container {
        gap: 0;
    }

    .chat.is-mobile-list .chat-main {
        display: none;
    }

    .chat.is-mobile-room .chat-sidebar {
        display: none;
    }

    .chat {
        min-height: var(--chat-layout-height);
    }

    .chat.is-mobile-room .chat-main {
        display: flex;
        min-height: var(--chat-layout-height);
    }

    .chat.is-mobile-room .chat-room {
        min-height: var(--chat-layout-height);
    }

    .chat.is-mobile-list .chat-sidebar {
        border-bottom: none;
    }

    .group-detail-danger {
        flex-direction: row;
        flex-wrap: wrap;
    }

    .group-photo-settings {
        flex-direction: column;
        align-items: flex-start;
    }

    .group-photo-preview {
        width: 100%;
        max-width: 240px;
    }

    .chat-sidebar {
        padding: 18px;
    }

    .chat-message {
        max-width: 85%;
    }

    .chat-room-header,
    .chat-composer,
    .chat-messages {
        padding: 16px;
    }

    .chat-composer {
        gap: 10px;
        padding: 14px 16px;
    }

    .composer-row {
        flex-direction: row;
        align-items: stretch;
        gap: 8px;
        width: 100%;
    }

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

    .composer-field {
        min-height: 44px;
    }

    #chat-message {
        max-height: calc(1.5em * 5);
    }

    .composer-submit {
        flex: 0 0 auto;
        justify-content: flex-end;
        align-items: stretch;
    }

    .composer-send {
        width: 48px;
        min-height: 44px;
    }

    .composer-more {
        left: 0;
        right: auto;
        min-width: auto;
        max-width: calc(100vw - 32px);
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 8px;
    }
}

.status-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding-right: 2px;
}

.status-empty {
    margin-top: auto;
    font-size: 0.85rem;
    color: var(--color-muted);
}

.status-list-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px;
    border-radius: var(--radius-md);
    background: transparent;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition);
    position: relative;
}

.status-list-item:hover,
.status-list-item.active {
    background: rgba(18, 140, 126, 0.12);
    border-color: rgba(18, 140, 126, 0.2);
}

.status-item-meta-comments {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    position: relative;
}

.status-item-meta-comments::after {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #22c55e;
    opacity: 0;
    transition: opacity var(--transition), transform var(--transition);
    transform: scale(0);
    order: -1;
}

.status-item-meta-comments.has-new::after {
    opacity: 1;
    transform: scale(1);
}

.app-content>.chat-modal,
.app-content>.status-viewers-modal,
.app-content>.image-preview-overlay {
    margin-top: 0 !important;
}

.composer-field.is-multiline .composer-leading-icon,
.composer-field.is-multiline .composer-more-toggle,
.composer-field.is-multiline .composer-icon-button {
    margin-top: 0;
}

.app-content.auth-login-page {
    padding: 0 !important;
    margin: 0 !important;
}
