:root {
  color-scheme: light;
  --bg: #e9edf3;
  --bg-accent: rgba(61, 137, 227, 0.18);
  --panel: #ffffff;
  --panel-soft: #f8fafc;
  --panel-alt: #edf4fb;
  --panel-raised: #ffffff;
  --text: #12161d;
  --text-soft: #5d6978;
  --text-faint: #8793a3;
  --border: #c9d3e0;
  --border-strong: #b4c0cf;
  --accent: #257fd9;
  --accent-strong: #1768ba;
  --accent-soft: #e8f2ff;
  --accent-border: #bfd4ef;
  --warn-bg: #fff6d9;
  --warn-border: #e4cf84;
  --warn-text: #5d4902;
  --danger: #d84b58;
  --shadow: 0 18px 42px rgba(20, 38, 63, 0.14);
  --shadow-soft: 0 10px 26px rgba(20, 38, 63, 0.1);
  --message-hover: #f1f7ff;
  --input-bg: #ffffff;
  --chip-bg: #f3f5f8;
  --chip-border: #aab5c4;
  --chip-hover: #e7edf5;
  --lightbox-bg: #0f1319;
  --dm-me: #ebf2ff;
  --dm-me-border: #c9daf8;
  --dm-other: #f4f6f8;
  --dm-other-border: #d4dbe4;
}

@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
    --bg: #111317;
    --bg-accent: rgba(96, 132, 196, 0.08);
    --panel: #0f1114;
    --panel-soft: #15181d;
    --panel-alt: #181b20;
    --panel-raised: #171a1f;
    --text: #f7f7f7;
    --text-soft: #b1b5bc;
    --text-faint: #7b818b;
    --border: #252a31;
    --border-strong: #2f353e;
    --accent: #7aa2e8;
    --accent-strong: #9dbdff;
    --accent-soft: #1b2432;
    --accent-border: #35507e;
    --warn-bg: #3a3216;
    --warn-border: #655325;
    --warn-text: #efe0a4;
    --danger: #ff5d5d;
    --shadow: 0 20px 48px rgba(0, 0, 0, 0.55);
    --shadow-soft: 0 12px 28px rgba(0, 0, 0, 0.36);
    --message-hover: #11151a;
    --input-bg: #05080c;
    --chip-bg: #161a20;
    --chip-border: #313844;
    --chip-hover: #1b2129;
    --lightbox-bg: #000000;
    --dm-me: #2a3342;
    --dm-me-border: #41546f;
    --dm-other: #2a2d33;
    --dm-other-border: #3b404a;
  }
}

body.theme-light {
  color-scheme: light;
  --bg: #e9edf3;
  --bg-accent: rgba(61, 137, 227, 0.18);
  --panel: #ffffff;
  --panel-soft: #f8fafc;
  --panel-alt: #edf4fb;
  --panel-raised: #ffffff;
  --text: #12161d;
  --text-soft: #5d6978;
  --text-faint: #8793a3;
  --border: #c9d3e0;
  --border-strong: #b4c0cf;
  --accent: #257fd9;
  --accent-strong: #1768ba;
  --accent-soft: #e8f2ff;
  --accent-border: #bfd4ef;
  --warn-bg: #fff6d9;
  --warn-border: #e4cf84;
  --warn-text: #5d4902;
  --danger: #d84b58;
  --shadow: 0 18px 42px rgba(20, 38, 63, 0.14);
  --shadow-soft: 0 10px 26px rgba(20, 38, 63, 0.1);
  --message-hover: #f1f7ff;
  --input-bg: #ffffff;
  --chip-bg: #f3f5f8;
  --chip-border: #aab5c4;
  --chip-hover: #e7edf5;
  --lightbox-bg: #0f1319;
  --dm-me: #ebf2ff;
  --dm-me-border: #c9daf8;
  --dm-other: #f4f6f8;
  --dm-other-border: #d4dbe4;
}

body.theme-dark {
  color-scheme: dark;
  --bg: #111317;
  --bg-accent: rgba(96, 132, 196, 0.08);
  --panel: #0f1114;
  --panel-soft: #15181d;
  --panel-alt: #181b20;
  --panel-raised: #171a1f;
  --text: #f7f7f7;
  --text-soft: #b1b5bc;
  --text-faint: #7b818b;
  --border: #252a31;
  --border-strong: #2f353e;
  --accent: #7aa2e8;
  --accent-strong: #9dbdff;
  --accent-soft: #1b2432;
  --accent-border: #35507e;
  --warn-bg: #3a3216;
  --warn-border: #655325;
  --warn-text: #efe0a4;
  --danger: #ff5d5d;
  --shadow: 0 20px 48px rgba(0, 0, 0, 0.55);
  --shadow-soft: 0 12px 28px rgba(0, 0, 0, 0.36);
  --message-hover: #11151a;
  --input-bg: #05080c;
  --chip-bg: #161a20;
  --chip-border: #313844;
  --chip-hover: #1b2129;
  --lightbox-bg: #000000;
  --dm-me: #2a3342;
  --dm-me-border: #41546f;
  --dm-other: #2a2d33;
  --dm-other-border: #3b404a;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  min-height: 100%;
  font-family: Tahoma, Verdana, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
}

body {
  min-height: 100dvh;
  background-image:
    radial-gradient(circle at top left, var(--bg-accent), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0));
  background-attachment: fixed;
  will-change: auto;
  transition: background-color 0.18s ease, color 0.18s ease;
}

body.theme-dark {
  background-image: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

button,
input,
select,
textarea,
a {
  transition:
    background-color 0.16s ease,
    border-color 0.16s ease,
    color 0.16s ease,
    box-shadow 0.16s ease,
    opacity 0.16s ease,
    transform 0.16s ease;
}

button:disabled,
input:disabled,
select:disabled,
textarea:disabled {
  cursor: not-allowed;
  opacity: 0.68;
}

.app {
  max-width: 1120px;
  margin: 0 auto;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  padding: 8px 14px 14px;
}

.room-title-stack {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.room-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-faint);
}

.top-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0 10px;
  gap: 12px;
}

.room-title {
  font-size: 30px;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
  letter-spacing: -0.04em;
}

.more-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 12px;
  border: 1px solid color-mix(in srgb, var(--chip-border) 86%, var(--border));
  background: linear-gradient(180deg, color-mix(in srgb, var(--chip-bg) 78%, var(--panel)), var(--chip-bg));
  color: var(--text-soft);
  text-decoration: none;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.more-link:hover {
  background: linear-gradient(180deg, color-mix(in srgb, var(--chip-hover) 84%, var(--panel)), var(--chip-hover));
  border-color: color-mix(in srgb, var(--accent-border) 58%, var(--chip-border));
}

.status {
  min-height: 18px;
  margin: 0 0 8px;
  padding-left: 4px;
  font-size: 13px;
  color: var(--text-soft);
}

.status.error {
  color: var(--danger);
}

.ios-install-nudge {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 8px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 18px;
  background: rgba(13, 15, 18, 0.94);
  color: #ffffff;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28);
}

.ios-install-nudge-copy {
  min-width: 0;
}

.ios-install-nudge-title {
  margin-bottom: 2px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ios-install-nudge-text {
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  line-height: 1.32;
}

.ios-install-nudge-btn {
  flex: 0 0 auto;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(69, 246, 146, 0.45);
  border-radius: 999px;
  background: rgba(69, 246, 146, 0.12);
  color: #45f692;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
}

.ios-install-nudge-btn:active {
  transform: translateY(1px);
}

.room-notice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--warn-bg) 90%, var(--panel)), var(--warn-bg));
  border: 1px solid var(--warn-border);
  color: var(--warn-text);
  padding: 11px 12px;
  margin-bottom: 10px;
  font-size: 14px;
  border-radius: 14px;
  box-shadow: var(--shadow-soft);
}

.room-notice-btn {
  border: 1px solid var(--warn-border);
  background: color-mix(in srgb, var(--warn-bg) 80%, var(--panel));
  color: inherit;
  height: 34px;
  padding: 0 12px;
  cursor: pointer;
  white-space: nowrap;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
}

.room-notice-btn:hover {
  background: color-mix(in srgb, var(--warn-bg) 64%, var(--panel));
}

.main-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 264px;
  gap: 10px;
  flex: 1;
  min-height: 0;
}

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

.chat {
  flex: 1;
  min-height: 560px;
  overflow-y: auto;
}

.user-panel {
  min-height: 560px;
  overflow-y: auto;
}

.chat,
.user-panel {
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-raised) 92%, var(--panel-soft)), var(--panel));
  border: 1px solid var(--border-strong);
  border-radius: 14px;
  box-shadow: var(--shadow-soft);
}

.user-panel-title {
  position: sticky;
  top: 0;
  background: linear-gradient(180deg, var(--panel-soft), color-mix(in srgb, var(--panel-soft) 80%, var(--panel)));
  border-bottom: 1px solid var(--border);
  padding: 10px 12px;
  font-size: 11px;
  color: var(--text-soft);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  z-index: 1;
}

.user-list {
  padding: 8px;
}

.user-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 9px;
  cursor: pointer;
  border-radius: 10px;
  border: 1px solid transparent;
  transition:
    background-color 0.14s ease,
    border-color 0.14s ease;
}

.user-row:hover {
  background: var(--message-hover);
  border-color: color-mix(in srgb, var(--accent-border) 72%, var(--border));
}

.user-row-name {
  min-width: 0;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.1;
  word-break: break-word;
}

.user-row-sub {
  margin-top: 2px;
  font-size: 12px;
  color: var(--text-soft);
  line-height: 1.24;
}

.user-avatar,
.avatar,
.profile-avatar,
.dm-avatar,
.dm-msg-avatar,
.people-card-avatar,
.member-avatar {
  border: 1px solid var(--border-strong);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-soft) 88%, var(--panel)), var(--panel-soft));
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  color: var(--text-soft);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.user-avatar {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  font-size: 16px;
  border-radius: 12px;
}

.avatar {
  width: 54px;
  height: 54px;
  flex-shrink: 0;
  font-size: 24px;
  border-radius: 15px;
}

.profile-avatar {
  width: 98px;
  height: 98px;
  margin: 4px auto 14px;
  font-size: 44px;
  border-radius: 20px;
}

.dm-avatar {
  width: 46px;
  height: 46px;
  font-size: 22px;
  border-radius: 14px;
}

.dm-msg-avatar {
  width: 34px;
  height: 34px;
  flex-shrink: 0;
  font-size: 16px;
  border-radius: 10px;
}

.people-card-avatar,
.member-avatar {
  width: 54px;
  height: 54px;
  font-size: 22px;
  border-radius: 14px;
}

.user-avatar img,
.avatar img,
.profile-avatar img,
.dm-avatar img,
.dm-msg-avatar img,
.people-card-avatar img,
.member-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.protected-avatar {
  background-position: center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
  -webkit-user-drag: none;
}

.protected-avatar img,
.protected-avatar * {
  pointer-events: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
  -webkit-user-drag: none;
}

.avatar.clickable,
.username.clickable {
  cursor: pointer;
}

.avatar.clickable:hover,
.username.clickable:hover {
  opacity: 0.85;
}

.message {
  display: flex;
  gap: 12px;
  padding: 13px 12px;
  border-bottom: 1px solid var(--border);
  transition:
    background-color 0.14s ease,
    transform 0.14s ease;
}

.message:hover {
  background: var(--message-hover);
}

.message-body {
  flex: 1;
  min-width: 0;
}

.meta {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}

.meta-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
}

.username {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.12;
}

.time {
  font-size: 13px;
  color: var(--text-faint);
  white-space: nowrap;
  line-height: 1.1;
}

.mod-mini-btn {
  border: 1px solid var(--chip-border);
  background: var(--chip-bg);
  color: var(--text-soft);
  font-size: 11px;
  padding: 4px 8px;
  cursor: pointer;
  border-radius: 999px;
  font-weight: 700;
}

.mod-mini-btn:hover {
  background: var(--chip-hover);
  border-color: color-mix(in srgb, var(--accent-border) 60%, var(--chip-border));
}

.text {
  font-size: 18px;
  line-height: 1.3;
  color: var(--text);
  word-break: break-word;
}

.msg-image {
  display: block;
  max-width: min(320px, 100%);
  margin-top: 8px;
  border: 1px solid var(--border-strong);
  border-radius: 14px;
  cursor: pointer;
  box-shadow: var(--shadow-soft);
}

.msg-image:hover {
  opacity: 0.92;
}

.msg-audio,
.dm-audio {
  display: block;
  width: min(100%, 320px);
  margin-top: 8px;
  accent-color: var(--accent);
}

.voice-recording {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-soft) 70%, transparent);
  border-color: var(--accent);
  color: var(--accent-strong);
}

.room-identity-panel .field-full textarea {
  min-height: 92px;
}

body.theme-dark .top-bar {
  padding-top: 12px;
}

body.theme-dark .more-link,
body.theme-dark .small-action-btn,
body.theme-dark .tool-btn {
  background: #14181d;
}

body.theme-dark .chat,
body.theme-dark .input-shell,
body.theme-dark .user-panel,
body.theme-dark .room-controls-panel,
body.theme-dark .settings-preview,
body.theme-dark .people-item,
body.theme-dark .members-list,
body.theme-dark .member-row,
body.theme-dark .empty-box,
body.theme-dark .dm-chat {
  background: var(--panel);
}


.reply-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  background: var(--accent-soft);
  border: 1px solid var(--accent-border);
  padding: 8px 10px;
  margin-bottom: 8px;
  border-radius: 12px;
}

.reply-label {
  font-size: 13px;
  color: var(--text);
  min-width: 0;
  word-break: break-word;
}

.reply-cancel-btn {
  border: none;
  background: transparent;
  color: var(--text-soft);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
}

.typing-bar {
  min-height: 18px;
  margin-bottom: 8px;
  font-size: 13px;
  color: var(--text-soft);
  padding-left: 2px;
}

#messageInput,
#dmInput,
#membersSearch,
#membersAgeFilter,
#membersGenderFilter,
.field input,
.field select,
.field textarea {
  background: var(--input-bg);
  border: 1px solid var(--border);
  color: var(--text);
  outline: none;
  border-radius: 12px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

#messageInput:focus,
#dmInput:focus,
#membersSearch:focus,
#membersAgeFilter:focus,
#membersGenderFilter:focus,
.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-soft) 82%, transparent);
}

#messageInput,
#dmInput {
  flex: 1;
  min-width: 0;
  height: 40px;
  padding: 8px 12px;
  font-size: 16px;
}

#membersSearch,
#membersAgeFilter,
#membersGenderFilter,
.field input,
.field select {
  height: 40px;
  padding: 8px 10px;
  font-size: 14px;
}

.field textarea {
  padding: 10px 12px;
  font-size: 14px;
  resize: vertical;
}

#sendBtn,
#sendDmBtn,
.modal-btn,
.small-action-btn {
  border: 1px solid var(--chip-border);
  background: linear-gradient(180deg, color-mix(in srgb, var(--chip-bg) 76%, var(--panel)), var(--chip-bg));
  color: var(--text);
  font-size: 15px;
  cursor: pointer;
  border-radius: 12px;
  font-weight: 700;
}

#sendBtn,
#sendDmBtn,
.modal-btn {
  min-width: 92px;
  height: 40px;
  padding: 0 14px;
}

.small-action-btn {
  min-height: 32px;
  padding: 0 12px;
  font-size: 13px;
  border-radius: 999px;
}

#sendBtn:hover,
#sendDmBtn:hover,
.modal-btn:hover,
.small-action-btn:hover {
  background: linear-gradient(180deg, color-mix(in srgb, var(--chip-hover) 82%, var(--panel)), var(--chip-hover));
  border-color: color-mix(in srgb, var(--accent-border) 56%, var(--chip-border));
}

.hidden {
  display: none !important;
}

.modal {
  position: fixed;
  inset: 0;
  background: rgba(8, 10, 14, 0.54);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  z-index: 999;
}

.modal-card {
  width: 100%;
  max-height: calc(100dvh - 28px);
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-soft) 92%, var(--panel-raised)), var(--panel-soft));
  border: 1px solid var(--border-strong);
  box-shadow: var(--shadow);
  position: relative;
  color: var(--text);
  border-radius: 16px;
}

.profile-card {
  max-width: 440px;
  padding: 24px 20px 20px;
  text-align: center;
}

.settings-card,
.auth-card {
  max-width: 620px;
  padding: 24px 20px 20px;
}

.settings-card,
.auth-card,
.profile-card,
#roomControlsModal .modal-card {
  overflow: visible;
}

.lightbox-card {
  width: 100%;
  max-width: 920px;
  max-height: calc(100dvh - 28px);
  background: var(--lightbox-bg);
  border: 1px solid var(--border-strong);
  position: relative;
  padding: 42px 12px 12px;
  border-radius: 20px;
}

.lightbox-image {
  display: block;
  max-width: 100%;
  max-height: calc(100dvh - 90px);
  margin: 0 auto;
  object-fit: contain;
  border-radius: 14px;
}

.close-btn {
  position: absolute;
  right: 8px;
  top: 6px;
  width: 34px;
  height: 34px;
  border: none;
  background: transparent;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  color: var(--text-soft);
  border-radius: 999px;
}

.close-btn:hover {
  background: color-mix(in srgb, var(--panel-soft) 72%, transparent);
}

.lightbox-card .close-btn {
  color: #ffffff;
}

.profile-name {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.1;
}

.profile-sub {
  font-size: 14px;
  color: var(--text-soft);
  margin-top: 4px;
  line-height: 1.35;
}

.profile-facts {
  margin-top: 12px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
}

.profile-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--chip-border);
  background: linear-gradient(180deg, color-mix(in srgb, var(--chip-bg) 82%, var(--panel)), var(--chip-bg));
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.profile-chip-accent {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-soft) 86%, var(--panel)), var(--accent-soft));
  border-color: color-mix(in srgb, var(--accent-border) 78%, var(--chip-border));
  color: var(--accent-strong);
}

.profile-chip-success {
  background: linear-gradient(180deg, color-mix(in srgb, #dff8e4 82%, var(--panel)), color-mix(in srgb, #c9f0d3 88%, var(--panel)));
  border-color: color-mix(in srgb, #7cc98f 62%, var(--chip-border));
  color: #267143;
}

.profile-chip-danger {
  background: linear-gradient(180deg, color-mix(in srgb, #ffe8eb 82%, var(--panel)), color-mix(in srgb, #ffdadd 86%, var(--panel)));
  border-color: color-mix(in srgb, #ef9aa6 60%, var(--chip-border));
  color: #a23b48;
}

.profile-chip-muted {
  background: linear-gradient(180deg, color-mix(in srgb, var(--chip-bg) 82%, var(--panel)), var(--chip-bg));
  border-color: color-mix(in srgb, var(--chip-border) 82%, var(--border));
  color: var(--text-soft);
}

.profile-bio {
  margin-top: 12px;
  padding: 12px;
  background: color-mix(in srgb, var(--panel) 88%, var(--panel-soft));
  border: 1px solid var(--border);
  border-radius: 14px;
  font-size: 14px;
  color: var(--text);
  white-space: pre-wrap;
  word-break: break-word;
}

.profile-actions {
  margin-top: 18px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
}

.settings-title {
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 10px;
  letter-spacing: -0.02em;
}

.mini-status {
  min-height: 18px;
  font-size: 13px;
  color: var(--text-soft);
  margin-bottom: 10px;
}

.room-controls-overview {
  white-space: pre-wrap;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-soft) 78%, var(--panel)), color-mix(in srgb, var(--panel) 88%, var(--panel-soft)));
  border-color: color-mix(in srgb, var(--accent-border) 72%, var(--border));
}

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

.room-controls-stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.room-controls-panel {
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 90%, var(--panel-soft)), var(--panel));
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.room-controls-actions {
  justify-content: flex-start;
  margin-top: 0;
}

.room-controls-form {
  margin-top: 2px;
}

.auth-note {
  font-size: 13px;
  color: var(--text-soft);
  margin-bottom: 10px;
  line-height: 1.35;
}

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

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

.field span {
  font-size: 13px;
  color: var(--text-soft);
}

.field-full {
  grid-column: 1 / -1;
}

.checkbox-field {
  flex-direction: row;
  align-items: center;
}

.checkbox-field input {
  width: auto;
  height: auto;
}

.settings-preview-wrap {
  margin-top: 14px;
}

.settings-preview-label {
  font-size: 13px;
  color: var(--text-soft);
  margin-bottom: 6px;
}

.settings-preview {
  border: 1px solid var(--border);
  background: linear-gradient(180deg, var(--panel), color-mix(in srgb, var(--panel) 85%, var(--panel-soft)));
  padding: 12px;
  border-radius: 14px;
}

.settings-preview-name {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 4px;
}

.settings-preview-text {
  font-size: 18px;
  line-height: 1.25;
}

.settings-quick-controls {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0 16px;
}

.settings-toggle-row {
  appearance: none;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel-soft) 74%, transparent);
  color: var(--text);
  padding: 12px;
  min-height: 72px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 5px;
  text-align: left;
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.settings-toggle-row span {
  color: var(--text-soft);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.settings-toggle-row strong {
  font-size: 14px;
  line-height: 1.2;
}

.settings-toggle-row:hover,
.settings-toggle-row:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 34%, var(--border));
  outline: none;
}

.settings-push-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel-soft) 74%, transparent);
}

.settings-push-copy {
  min-width: 0;
}

.settings-push-title {
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 3px;
}

.settings-push-card .mini-status {
  min-height: 0;
}

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

.row-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 14px;
  flex-wrap: wrap;
}

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

.dm-card {
  max-width: 680px;
  height: min(82vh, 760px);
  display: flex;
  flex-direction: column;
  padding: 16px 16px 14px;
}

.dm-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-right: 34px;
  margin-bottom: 8px;
}

.dm-person {
  display: flex;
  align-items: center;
  gap: 10px;
}

.dm-name {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.1;
}

.dm-sub {
  font-size: 13px;
  color: var(--text-soft);
}

.dm-status {
  min-height: 18px;
  font-size: 13px;
  color: var(--text-soft);
  margin-bottom: 8px;
}

.dm-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.dm-chat {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 92%, var(--panel-soft)), var(--panel));
  border: 1px solid var(--border);
  padding: 10px;
  border-radius: 14px;
}

.dm-message {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
  align-items: flex-start;
}

.dm-message.from-me {
  flex-direction: row-reverse;
}

.dm-bubble-wrap {
  max-width: 78%;
}

.dm-msg-meta {
  letter-spacing: .01em;
  font-size: 12px;
  color: var(--text-faint);
  margin: 0 0 4px;
}

.dm-message.from-me .dm-msg-meta {
  letter-spacing: .01em;
  text-align: right;
}

.dm-bubble {
  background: var(--dm-other);
  border: 1px solid var(--dm-other-border);
  padding: 9px 11px;
  font-size: 15px;
  line-height: 1.32;
  word-break: break-word;
  border-radius: 14px;
}

.dm-message.from-me .dm-bubble {
  background: var(--dm-me);
  border-color: var(--dm-me-border);
}

.people-card {
  max-width: 1020px;
  height: min(88vh, 860px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.people-header {
  background: linear-gradient(135deg, var(--accent-strong), var(--accent));
  color: #ffffff;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.people-header-title {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.people-close-btn {
  border: none;
  background: transparent;
  color: #ffffff;
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
  border-radius: 999px;
}

.people-close-btn:hover {
  background: rgba(255, 255, 255, 0.12);
}

.people-tabs {
  display: flex;
  gap: 4px;
  padding: 8px 10px 0;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--panel-alt), var(--panel-soft));
  overflow-x: auto;
}

.people-tab {
  border: 1px solid transparent;
  background: transparent;
  color: var(--accent-strong);
  font-size: 18px;
  padding: 11px 14px 12px;
  cursor: pointer;
  border-radius: 12px 12px 0 0;
  white-space: nowrap;
}

.people-tab.active {
  color: var(--text);
  background: var(--panel);
  border-color: var(--border);
  border-bottom-color: var(--panel);
  font-weight: 700;
}

.people-status {
  padding: 8px 14px 0;
  margin-bottom: 0;
}

.people-body {
  flex: 1;
  min-height: 0;
  overflow: hidden;
  padding: 14px;
}

.people-panel {
  display: none;
  height: 100%;
  overflow-y: auto;
}

.people-panel.active {
  display: block;
}

.profile-page-card {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  margin-bottom: 14px;
  padding: 14px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 90%, var(--panel-soft)), var(--panel));
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow-soft);
}

.profile-page-avatar {
  width: 96px;
  height: 96px;
  border-radius: 20px;
  border: 1px solid var(--border-strong);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-soft) 88%, var(--panel)), var(--panel-soft));
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  color: var(--text-soft);
  font-size: 42px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.profile-page-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

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

.profile-page-name {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.05;
  word-break: break-word;
}

.profile-page-sub {
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.35;
  color: var(--text-soft);
}

.profile-page-actions {
  justify-content: flex-start;
  margin-top: 10px;
}

.people-section-title {
  font-size: 12px;
  color: var(--text-soft);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 8px;
}

.people-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.people-item {
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 90%, var(--panel-soft)), var(--panel));
  border: 1px solid var(--border);
  padding: 11px;
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
  border-radius: 12px;
  box-shadow: 0 8px 18px rgba(20, 38, 63, 0.08);
}

.people-item-unread {
  border-color: color-mix(in srgb, var(--accent-border) 82%, var(--border));
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-border) 46%, transparent),
    0 10px 22px rgba(37, 127, 217, 0.14);
}

.people-card-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.people-card-name {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.1;
  word-break: break-word;
}

.people-card-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.people-chip {
  min-height: 24px;
  padding: 0 8px;
  font-size: 11px;
}

.people-card-meta {
  margin-top: 3px;
  font-size: 13px;
  color: var(--text-soft);
  line-height: 1.3;
}

.people-card-preview {
  margin-top: 6px;
  font-size: 14px;
  color: var(--text);
  word-break: break-word;
  white-space: pre-wrap;
  line-height: 1.35;
}

.people-card-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.people-card-actions {
  min-width: 0;
}

.message-bubble.media-only,
.dm-bubble.media-only {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.message-bubble.media-only .msg-image,
.dm-bubble.media-only .msg-image {
  margin-top: 0 !important;
}


.members-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px 120px;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
}

.members-list {
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 90%, var(--panel-soft)), var(--panel));
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.member-row {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
  padding: 11px 13px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition:
    background-color 0.14s ease,
    transform 0.14s ease;
}

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

.member-row:hover {
  background: var(--message-hover);
}

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

.member-topline {
  font-size: 18px;
  line-height: 1.15;
  color: var(--text);
  word-break: break-word;
}

.member-name {
  font-weight: 700;
}

.member-state {
  margin-top: 5px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.member-about {
  margin-top: 5px;
  font-size: 14px;
  color: var(--text);
  line-height: 1.25;
  white-space: pre-wrap;
  word-break: break-word;
}

.member-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-self: center;
}

.empty-box {
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 86%, var(--panel-soft)), var(--panel));
  border: 1px solid var(--border);
  padding: 16px;
  color: var(--text-soft);
  border-radius: 14px;
}

@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
}

/* ===== UI refresh batch: Session-like structure with Chatango separation ===== */
.message {
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px 14px;
  border-bottom: 1px solid var(--border);
}

.message-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.message-bubble {
  background: color-mix(in srgb, var(--panel-raised) 92%, var(--panel-soft));
  border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
  border-radius: 22px;
  padding: 12px 14px;
  box-shadow: var(--shadow-soft);
}

body.theme-dark .message-bubble {
  background: #2d2f35;
  border-color: #3b3f48;
  box-shadow: none;
}

.reply-snippet {
  margin-bottom: 10px;
  padding: 10px 12px;
  border-left: 4px solid var(--accent);
  background: color-mix(in srgb, var(--accent-soft) 72%, var(--panel));
  border-radius: 14px;
}

.reply-snippet-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 3px;
}

.reply-snippet-preview {
  font-size: 13px;
  color: var(--text-soft);
  line-height: 1.25;
}

.text {
  line-height: 1.28;
}

.msg-image,
.msg-audio {
  margin-top: 10px;
}

.dm-card {
  max-width: 760px;
  border-radius: 28px;
}

.dm-chat {
  padding: 14px 12px;
  border-radius: 22px;
}

.dm-message {
  gap: 10px;
  margin-bottom: 14px;
}

.dm-bubble-wrap {
  max-width: min(78%, 520px);
}

.dm-bubble {
  border-radius: 24px;
  padding: 12px 14px;
}

.dm-actions {
  gap: 10px;
}

#roomControlsModal .modal-card,
.settings-card,
.people-card,
.auth-card,
.profile-card {
  border-radius: 28px;
}

body.theme-dark #roomControlsModal .modal-card,
body.theme-dark .settings-card,
body.theme-dark .people-card,
body.theme-dark .auth-card,
body.theme-dark .profile-card,
body.theme-dark .dm-card {
  background: #0f1114;
}

body.theme-dark .people-header {
  background: #0f1114;
  border-bottom: 1px solid #232831;
}

body.theme-dark .people-tab.active {
  color: #fff;
  border-bottom-color: var(--accent);
}

body.theme-dark .people-item,
body.theme-dark .members-list,
body.theme-dark .member-row,
body.theme-dark .empty-box,
body.theme-dark .settings-preview,
body.theme-dark .room-controls-panel,
body.theme-dark #roomControlsModal .field,
body.theme-dark #roomControlsModal .empty-box {
  background: #17191e;
  border-color: #262b34;
}

body.theme-dark .more-link,
body.theme-dark .small-action-btn,
body.theme-dark .tool-btn,
body.theme-dark #sendBtn,
body.theme-dark #sendDmBtn {
  background: #17191e;
  border-color: #2c3340;
}

body.theme-dark #sendBtn,
body.theme-dark #sendDmBtn {
  color: #fff;
}

body.theme-dark .top-bar {
  background: transparent;
}

/* Mention picker and message action base. */
.settings-upload-row { display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }
.mention-picker { position:fixed; left:12px; right:12px; bottom:calc(env(safe-area-inset-bottom) + 110px); z-index:1400; max-height:min(260px,42vh); overflow:auto; background:rgba(20,24,30,.98); border:1px solid rgba(255,255,255,.08); border-radius:20px; box-shadow:0 20px 60px rgba(0,0,0,.45); backdrop-filter:blur(10px); }
body.theme-light .mention-picker { background:rgba(255,255,255,.97); border-color:rgba(0,0,0,.08); }
.mention-item { display:flex; align-items:center; gap:12px; padding:12px 14px; border:0; width:100%; background:transparent; color:var(--text); text-align:left; border-bottom:1px solid rgba(255,255,255,.06); cursor:pointer; }
.mention-item:last-child { border-bottom:none; }
.mention-item:hover, .mention-item.active { background:rgba(255,255,255,.06); }
body.theme-light .mention-item:hover, body.theme-light .mention-item.active { background:rgba(0,0,0,.05); }
.mention-item-name { font-weight:700; }
.mention-item-sub { font-size:12px; color:var(--text-soft); }
.message-bubble, .dm-bubble { position:relative; overflow:hidden; }
.message-bubble > *, .dm-bubble > * { position:relative; z-index:1; }
.settings-preview.has-bg { position:relative; overflow:hidden; }
.settings-preview.has-bg > * { position:relative; z-index:1; }
.reaction-strip { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.reaction-chip { border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.08); border-radius:999px; padding:3px 8px; font-size:13px; line-height:1; }
body.theme-light .reaction-chip { border-color:rgba(0,0,0,.08); background:rgba(0,0,0,.04); }
.message-action-sheet { position:fixed; inset:0; z-index:1600; }
.message-action-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.42); backdrop-filter:blur(6px); }
.message-action-panel { position:absolute; left:50%; bottom:calc(env(safe-area-inset-bottom) + 20px); transform:translateX(-50%); width:min(94vw,420px); background:rgba(18,20,25,.98); border:1px solid rgba(255,255,255,.08); border-radius:26px; box-shadow:0 24px 70px rgba(0,0,0,.5); overflow:hidden; }
body.theme-light .message-action-panel { background:rgba(255,255,255,.98); border-color:rgba(0,0,0,.08); }
.message-action-preview { padding:14px; border-bottom:1px solid rgba(255,255,255,.06); font-size:14px; color:var(--text-soft); }
.message-reaction-row { display:flex; align-items:center; justify-content:space-between; gap:6px; padding:10px 12px; border-bottom:1px solid rgba(255,255,255,.06); }
.reaction-btn { width:44px; height:44px; border:none; border-radius:999px; background:rgba(255,255,255,.08); font-size:24px; cursor:pointer; }
body.theme-light .reaction-btn { background:rgba(0,0,0,.05); }
.message-action-list { display:flex; flex-direction:column; }
.message-action-btn { border:none; background:transparent; color:var(--text); font-size:17px; text-align:left; padding:16px 18px; cursor:pointer; border-top:1px solid rgba(255,255,255,.06); }
.message-action-btn.danger { color:#ff5d66; }
.message-action-btn:hover { background:rgba(255,255,255,.05); }
body.theme-light .message-action-btn:hover { background:rgba(0,0,0,.04); }
.message-bubble.mentioned { outline:2px solid rgba(88,240,170,.35); outline-offset:6px; border-radius:18px; }
/* Session-style structure variables and desktop shell. */
:root {
  --msg-text-on-bg: #f6f8fb;
  --session-shell: #0d0f14;
  --session-panel: #141821;
  --session-panel-2: #1a202b;
  --session-border: rgba(150, 170, 205, 0.22);
  --session-border-strong: rgba(180, 198, 230, 0.34);
}

body.theme-dark {
  color-scheme: dark;
  --bg: #0c0f15;
  --bg-accent: rgba(120, 140, 185, 0.08);
  --panel: #121722;
  --panel-soft: #171d29;
  --panel-alt: #1b2230;
  --panel-raised: #161d29;
  --text: #f5f7fb;
  --text-soft: #b1bbca;
  --text-faint: #7f8b9d;
  --border: rgba(131, 149, 182, 0.26);
  --border-strong: rgba(168, 186, 220, 0.42);
  --accent: #4f8dff;
  --accent-strong: #73a2ff;
  --accent-soft: rgba(79, 141, 255, 0.16);
  --accent-border: rgba(115, 162, 255, 0.32);
  --warn-bg: rgba(182, 126, 43, 0.16);
  --warn-border: rgba(202, 154, 77, 0.34);
  --shadow: 0 20px 44px rgba(0,0,0,0.45);
}

body.theme-dark .app {
  max-width: 1080px;
}

body.theme-dark .top-bar {
  background: transparent;
  border: none;
  padding-bottom: 6px;
}

body.theme-dark .room-title-stack {
  gap: 4px;
}

body.theme-dark .room-kicker {
  letter-spacing: 0.24em;
  color: rgba(223, 230, 242, 0.65);
}

body.theme-dark .room-title {
  color: #fff;
  font-weight: 800;
}

body.theme-dark .chat,
body.theme-dark .user-panel,
body.theme-dark .input-shell,
body.theme-dark .dm-card,
body.theme-dark .people-card,
body.theme-dark .settings-card,
body.theme-dark .auth-card,
body.theme-dark .profile-card,
body.theme-dark #roomControlsModal .modal-card,
body.theme-dark .message-action-panel,
body.theme-dark .mention-picker {
  background: linear-gradient(180deg, rgba(19,24,34,.98), rgba(13,17,25,.98));
  border-color: var(--session-border);
  box-shadow: var(--shadow);
}

body.theme-dark .chat,
body.theme-dark .user-panel {
  border-color: var(--session-border-strong);
}

body.theme-dark .message {
  border-bottom: none;
  gap: 12px;
  padding: 10px 12px 14px;
}

.message-body {
  min-width: 0;
}

.message-bubble {
  border-radius: 26px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  padding: 14px 16px;
}

body.theme-dark .message-bubble {
  background: #2b303b;
  border: 1px solid rgba(255,255,255,0.06);
}

.message.from-me {
  justify-content: flex-end;
}

.message.from-me .avatar {
  order: 2;
}

.message.from-me .message-body {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.message.from-me .meta {
  justify-content: flex-end;
}

.message.from-me .meta-right {
  display: none;
}

.message.from-me .username {
  text-align: right;
}

body.theme-dark .message.from-me .message-bubble {
  background: linear-gradient(180deg, #2a3444, #232d3c);
  border-color: rgba(128, 162, 220, 0.28);
}

.text {
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.3;
}

.msg-image {
  max-width: min(100%, 320px);
  border-radius: 18px;
  object-fit: cover;
}

body.theme-dark .reply-snippet {
  background: rgba(255,255,255,0.04);
  border-left-color: #62d6a0;
  border-radius: 16px;
}

body.theme-dark .input-shell {
  border-radius: 28px;
  border: 1px solid var(--session-border-strong);
}

body.theme-dark #messageInput,
body.theme-dark #dmInput {
  background: #0a0e16;
  border-color: rgba(255,255,255,0.08);
  color: #fff;
}

body.theme-dark #sendBtn,
body.theme-dark #sendDmBtn,
body.theme-dark .tool-btn,
body.theme-dark .small-action-btn,
body.theme-dark .more-link {
  border-color: var(--session-border-strong);
}

body.theme-dark .user-row,
body.theme-dark .member-row,
body.theme-dark .people-item,
body.theme-dark .empty-box,
body.theme-dark .room-controls-panel,
body.theme-dark .settings-preview,
body.theme-dark .field input,
body.theme-dark .field textarea,
body.theme-dark .field select {
  border-color: var(--session-border) !important;
}

body.theme-dark .field input,
body.theme-dark .field textarea,
body.theme-dark .field select,
body.theme-dark .settings-preview,
body.theme-dark .room-controls-panel,
body.theme-dark .empty-box {
  background: rgba(255,255,255,0.03);
}

body.theme-dark .settings-card .field span,
body.theme-dark .settings-card .mini-status,
body.theme-dark .settings-card .people-section-title,
body.theme-dark .room-controls-panel .people-section-title,
body.theme-dark .room-kicker,
body.theme-dark .time,
body.theme-dark .user-row-sub,
body.theme-dark .member-about,
body.theme-dark .profile-sub,
body.theme-dark .profile-facts {
  color: var(--text-soft);
}

body.theme-dark .people-header,
body.theme-dark .dm-top {
  background: transparent;
  border-bottom: none;
}

body.theme-dark .people-tab.active {
  background: rgba(255,255,255,0.06);
  border-bottom-color: transparent;
  border-radius: 999px;
}

body.theme-dark .people-tabs {
  gap: 8px;
  padding: 0 10px 12px;
  border-bottom: none;
  background: transparent;
}

body.theme-dark .people-tab {
  border-radius: 999px;
  padding: 10px 16px;
}

body.theme-dark .mention-picker,
body.theme-dark .message-action-panel {
  border-color: var(--session-border-strong);
}

body.theme-dark .reaction-btn {
  background: rgba(255,255,255,0.08);
}

body.theme-dark .message-action-btn:hover,
body.theme-dark .mention-item:hover,
body.theme-dark .mention-item.active {
  background: rgba(255,255,255,0.06);
}

body.theme-dark .mention-item {
  border-bottom-color: rgba(255,255,255,0.05);
}

.message-bubble.mentioned {
  outline: 2px solid rgba(98,214,160,.4);
  outline-offset: 4px;
}

/* Reply and room-settings stability polish. */
.reply-snippet {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}

.reply-snippet-name,
.reply-snippet-user {
  font-weight: 700;
  line-height: 1.15;
}

.reply-snippet-preview,
.reply-snippet-text {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
  overflow-wrap: anywhere;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.message-body,
.dm-bubble-wrap {
  min-width: 0;
}

.message-bubble,
.dm-bubble {
  width: fit-content;
  max-width: min(100%, 620px);
  box-sizing: border-box;
}

.message .text,
.dm-bubble .text {
  overflow-wrap: anywhere;
  word-break: break-word;
}

body.theme-dark .message-bubble,
body.theme-dark .dm-bubble,
body.theme-dark .input-shell,
body.theme-dark .user-panel,
body.theme-dark .chat,
body.theme-dark .top-bar,
body.theme-dark .room-notice,
body.theme-dark .modal-card,
body.theme-dark .field input,
body.theme-dark .field textarea,
body.theme-dark .field select {
  border-color: rgba(173, 187, 214, 0.22) !important;
}

body.theme-dark .message.from-me .message-bubble {
  background: linear-gradient(180deg, #2f3643, #272d38) !important;
  border-color: rgba(173, 187, 214, 0.24) !important;
}

body.theme-dark .message-action-sheet {
  background: rgba(14, 17, 23, 0.96);
  border: 1px solid rgba(173, 187, 214, 0.20);
  box-shadow: 0 20px 40px rgba(0,0,0,.45);
}

body.theme-dark .reaction-btn {
  background: rgba(255,255,255,0.06);
  border-color: rgba(173, 187, 214, 0.18);
}

body.theme-dark .reaction-btn:hover {
  background: rgba(255,255,255,0.11);
}

body.theme-dark #roomControlsModal .modal-card {
  max-width: 760px;
}

body.theme-dark #roomControlsModal .settings-title {
  letter-spacing: -.02em;
}

/* v8 cleanup overrides */
.voice-preview-card {
  max-width: min(92vw, 520px);
  border-radius: 28px;
}
.voice-preview-player {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 14px 0 8px;
}
.voice-play-btn {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
  font-size: 20px;
}
.voice-seek {
  width: 100%;
}
.voice-duration {
  min-width: 84px;
  text-align: right;
  color: var(--text-soft);
  font-variant-numeric: tabular-nums;
}
.voice-pill {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: 10px;
  min-width: 210px;
  max-width: min(100%, 360px);
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
}
.voice-pill-play {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 0;
  background: #2a2d34;
  color: #fff;
  font-size: 15px;
}
.message.from-me .voice-pill,
.dm-message.from-me .voice-pill {
  background: rgba(88,138,255,.18);
}
.voice-pill-seek {
  width: 100%;
  accent-color: #7aa2ff;
}
.voice-pill-time {
  font-variant-numeric: tabular-nums;
  color: var(--text-soft);
  min-width: 42px;
  text-align: right;
}
.reply-snippet,
.reply-block,
.reply-preview {
  max-width: 100%;
  overflow: hidden;
}
.reply-snippet-user,
.reply-snippet-text,
.reply-snippet-preview,
.reply-snippet {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.message-bubble,
.dm-bubble {
  box-shadow: 0 8px 24px rgba(0,0,0,.18);
}
.message-action-panel {
  border-radius: 30px 30px 18px 18px;
  overflow: hidden;
}
.message-action-preview {
  color: var(--text-soft);
}
.message-action-list .message-action-btn {
  min-height: 58px;
  border-top: 1px solid rgba(255,255,255,.06);
  font-size: 18px;
}
.message-reaction-row {
  padding: 12px 14px;
}
.reaction-btn {
  width: 48px;
  height: 48px;
  border-radius: 999px;
  font-size: 24px;
}
body.theme-dark .message,
body.theme-dark .dm-message {
  border-color: rgba(255,255,255,.04);
}
body.theme-dark .message-bubble,
body.theme-dark .dm-bubble,
body.theme-dark .voice-play-btn,
body.theme-dark .voice-pill,
body.theme-dark .voice-preview-card,
body.theme-dark .message-action-panel {
  border-color: rgba(138,161,255,.16);
}
/* Session-style header and modal controls. */
.icon-nav-btn { appearance:none; border:none; background:transparent; color:var(--text); font-size:46px; line-height:1; width:40px; height:40px; display:flex; align-items:center; justify-content:center; padding:0; }
.room-header-sub { display:none; font-size:14px; color:var(--text-soft); }
.room-header-menu-btn { display:flex; align-items:center; justify-content:center; position:relative; width:44px; height:44px; border:none; background:transparent; padding:0; cursor:pointer; }
.mini-header-avatar { position:absolute; width:28px; height:28px; border-radius:999px; overflow:hidden; border:2px solid rgba(255,255,255,.1); background:#232831; color:#fff; display:flex; align-items:center; justify-content:center; font-size:12px; }
.mini-header-avatar img { width:100%; height:100%; object-fit:cover; display:block; }
.mini-header-avatar:first-child { right:12px; top:2px; }
.mini-header-avatar.second { right:0; bottom:2px; }
.search-result-row { width:100%; text-align:left; border:none; background:transparent; color:var(--text); padding:12px 14px; border-top:1px solid var(--border); cursor:pointer; }
.search-result-row:hover { background:rgba(255,255,255,.04); }
.message.flash-hit { animation: flashHit 1.2s ease; }
@keyframes flashHit { 0%{box-shadow:0 0 0 0 rgba(79,141,255,.35)} 40%{box-shadow:0 0 0 10px rgba(79,141,255,.08)} 100%{box-shadow:0 0 0 0 rgba(79,141,255,0)} }

.message-bubble, .dm-bubble { border-width:1px; }
.reply-snippet { min-width:0; }
.reply-snippet-name, .reply-snippet-user, .reply-snippet-preview, .reply-snippet-text, .text { overflow-wrap:anywhere; }


/* Solid theme and room controls refinements. */
body.theme-dark, body.theme-dark .app, body.theme-dark .top-bar, body.theme-dark .chat, body.theme-dark .input-shell, body.theme-dark .dm-card, body.theme-dark .dm-chat, body.theme-dark .people-card, body.theme-dark .settings-card, body.theme-dark .profile-card, body.theme-dark .auth-card, body.theme-dark #roomControlsModal .modal-card, body.theme-dark .message-action-panel, body.theme-dark .mention-picker { background:#000 !important; color:#fff !important; }
body.theme-light, body.theme-light .app, body.theme-light .top-bar, body.theme-light .chat, body.theme-light .input-shell, body.theme-light .dm-card, body.theme-light .dm-chat, body.theme-light .people-card, body.theme-light .settings-card, body.theme-light .profile-card, body.theme-light .auth-card, body.theme-light #roomControlsModal .modal-card, body.theme-light .message-action-panel, body.theme-light .mention-picker { background:#fff !important; color:#000 !important; }
body.theme-dark { --bg:#000; --panel:#000; --panel-soft:#000; --panel-alt:#000; --panel-raised:#000; --input-bg:#000; --border:#2b2b2b; --border-strong:#3b3b3b; --text:#fff; --text-soft:#c9c9c9; --text-faint:#9a9a9a; --accent:#3ae38f; --accent-strong:#3ae38f; --accent-border:#2b2b2b; --accent-soft:#000; }
body.theme-light { --bg:#fff; --panel:#fff; --panel-soft:#fff; --panel-alt:#fff; --panel-raised:#fff; --input-bg:#fff; --border:#d9d9d9; --border-strong:#bdbdbd; --text:#000; --text-soft:#444; --text-faint:#666; --accent:#111; --accent-strong:#000; --accent-border:#d9d9d9; --accent-soft:#fff; }
body.theme-dark .room-title-stack, body.theme-light .room-title-stack { background:transparent !important; }
body.theme-light .message, body.theme-light .message-bubble, body.theme-light .dm-bubble, body.theme-light .room-controls-panel, body.theme-light .empty-box, body.theme-light .field input, body.theme-light .field textarea, body.theme-light .field select { border-color:#d9d9d9 !important; color:#000 !important; }
body.theme-dark .message, body.theme-dark .message-bubble, body.theme-dark .dm-bubble, body.theme-dark .room-controls-panel, body.theme-dark .empty-box, body.theme-dark .field input, body.theme-dark .field textarea, body.theme-dark .field select { border-color:#2b2b2b !important; color:#fff !important; }
body.theme-dark .message-bubble { background:#2f2f31 !important; border:none !important; }
body.theme-dark .message.from-me .message-bubble, body.theme-dark .dm-message.from-me .dm-bubble { background:#39e58d !important; color:#071109 !important; }
.room-header-menu-btn { width:52px !important; height:52px !important; }
.mini-header-avatar { width:30px !important; height:30px !important; background:#24262b !important; border:2px solid rgba(255,255,255,.14) !important; }
.room-edit-btn { right:62px; }
.room-controls-card { position:relative; }
.room-controls-card .settings-title { margin-top:10px; }
.room-session-actions .room-controls-actions { display:block; }
.room-session-actions .modal-btn, .room-session-actions .small-action-btn, .room-session-admin-card .room-session-row-btn { width:100%; justify-content:flex-start; text-align:left; min-height:72px; border-radius:28px; padding:0 24px; font-size:20px; margin:0 0 12px; background:#17181d; border:1px solid rgba(255,255,255,.08); color:var(--text); }
.room-session-admin-card .room-session-row-btn { display:flex; flex-direction:column; align-items:flex-start; gap:2px; }
.room-session-admin-card .room-session-row-btn small { color:var(--text-soft); font-size:15px; }
.room-session-admin-card .room-session-row-btn.danger { color:#ff5454; }
.room-attachments-section { margin-top:10px; }
.room-attachments-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px; }
.room-attachment-thumb { border:none; background:#111; padding:0; border-radius:16px; overflow:hidden; aspect-ratio:1; }
.room-attachment-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.room-identity-panel.hidden, .room-controls-grid.hidden { display:none !important; }

/* Step 2 Session message/header contract: timeline, bubbles, replies, and header actions. */
.room-header-menu-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto;
  border-radius: 999px;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.room-header-menu-btn:focus-visible {
  outline: 2px solid rgba(57,229,141,.72);
  outline-offset: 4px;
}

.room-header-menu-btn .mini-header-avatar {
  box-shadow: 0 4px 14px rgba(0,0,0,.32);
}

.message,
.dm-message {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  padding: 7px 10px 12px;
  border: 0 !important;
  background: transparent !important;
}

.message-body,
.dm-bubble-wrap {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  max-width: min(76%, 620px);
}

.message.from-me,
.dm-message.from-me {
  justify-content: flex-end;
}

.message.from-me .avatar,
.dm-message.from-me .dm-msg-avatar {
  display: none !important;
}

.message.from-me .message-body,
.dm-message.from-me .dm-bubble-wrap {
  align-items: flex-end;
  margin-left: auto;
}

.meta {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  width: auto;
  max-width: 100%;
  margin: 0 0 2px;
}

.message.from-me .meta {
  justify-content: flex-end;
}

.meta-right {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  opacity: .72;
}

.username,
.dm-msg-meta {
  letter-spacing: .01em;
  font-size: 13px !important;
  line-height: 1.15 !important;
  font-weight: 750 !important;
  letter-spacing: -.01em;
  color: rgba(255,255,255,.86) !important;
}

.time {
  font-size: 11px;
  color: rgba(255,255,255,.46);
}

.message .mod-mini-btn {
  min-height: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.46);
  font-size: 11px;
  line-height: 1;
}

.message .mod-mini-btn:hover,
.message .mod-mini-btn:focus-visible {
  color: #39e58d;
  background: transparent;
}

.message-bubble,
.dm-bubble {
  width: fit-content;
  max-width: 100%;
  border: 0 !important;
  border-radius: 14px 18px 18px 18px !important;
  padding: 8px 12px !important;
  background: #2b2b2d !important;
  color: #f4f4f4 !important;
  box-shadow: none !important;
}

.message.from-me .message-bubble:not(.has-bg):not(.media-only),
.dm-message.from-me .dm-bubble:not(.has-bg):not(.media-only) {
  border-radius: 18px 14px 18px 18px !important;
  background: #39e58d !important;
  color: #041008 !important;
}

.message-bubble.media-only,
.dm-bubble.media-only {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}

.message-bubble .text,
.dm-bubble .text {
  line-height: 1.28 !important;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.reply-snippet {
  margin: 0 0 7px !important;
  padding: 7px 9px 7px 10px !important;
  border: 0 !important;
  border-left: 3px solid #39e58d !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,.07) !important;
  box-shadow: none !important;
}

.reply-snippet-name {
  margin-bottom: 2px;
  color: rgba(255,255,255,.92) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.reply-snippet-preview {
  color: rgba(255,255,255,.68) !important;
  font-size: 12px !important;
  line-height: 1.22 !important;
}

.message.from-me .message-bubble:not(.has-bg) .reply-snippet,
.dm-message.from-me .dm-bubble:not(.has-bg) .reply-snippet {
  background: rgba(4,16,8,.12) !important;
  border-left-color: rgba(4,16,8,.45) !important;
}

.message.from-me .message-bubble:not(.has-bg) .reply-snippet-name,
.message.from-me .message-bubble:not(.has-bg) .reply-snippet-preview,
.dm-message.from-me .dm-bubble:not(.has-bg) .reply-snippet-name,
.dm-message.from-me .dm-bubble:not(.has-bg) .reply-snippet-preview {
  color: rgba(4,16,8,.78) !important;
}

.msg-media-card {
  max-width: min(320px, 74vw);
  border-radius: 18px;
  background: #121315;
}

.message-bubble:not(.media-only) .msg-media-card,
.dm-bubble:not(.media-only) .msg-media-card {
  margin-top: 8px;
}

.msg-media-card .msg-image,
.msg-video-thumb {
  min-width: min(220px, 72vw);
  max-width: min(320px, 74vw);
  border-radius: 18px;
  background: #121315;
}

.msg-video-thumb {
  aspect-ratio: 4 / 5;
}

.msg-video-badge {
  width: 50px;
  height: 50px;
  background: rgba(0,0,0,.52);
}

.reaction-strip {
  margin-top: 6px;
}

body.theme-light .message-bubble:not(.has-bg):not(.media-only),
body.theme-light .dm-bubble:not(.has-bg):not(.media-only) {
  background: #2b2b2d !important;
  color: #f4f4f4 !important;
}

body.theme-light .message.from-me .message-bubble:not(.has-bg):not(.media-only),
body.theme-light .dm-message.from-me .dm-bubble:not(.has-bg):not(.media-only) {
  background: #39e58d !important;
  color: #041008 !important;
}

/* Session-style theme polish. */
body.theme-dark {
  --bg:#000000 !important;
  --panel:#000000 !important;
  --panel-soft:#000000 !important;
  --panel-alt:#000000 !important;
  --panel-raised:#000000 !important;
  --border:#1e1e1e !important;
  --border-strong:#2a2a2a !important;
  --chip-bg:#000000 !important;
  --chip-border:#2a2a2a !important;
  --chip-hover:#0d0d0d !important;
  --input-bg:#000000 !important;
  --text:#ffffff !important;
  --text-soft:#d1d1d1 !important;
  --text-faint:#9a9a9a !important;
}
body.theme-light {
  --bg:#ffffff !important;
  --panel:#ffffff !important;
  --panel-soft:#ffffff !important;
  --panel-alt:#ffffff !important;
  --panel-raised:#ffffff !important;
  --border:#d8d8d8 !important;
  --border-strong:#c7c7c7 !important;
  --chip-bg:#ffffff !important;
  --chip-border:#d8d8d8 !important;
  --chip-hover:#f5f5f5 !important;
  --input-bg:#ffffff !important;
  --text:#000000 !important;
  --text-soft:#2d2d2d !important;
  --text-faint:#666666 !important;
}
body.theme-dark, body.theme-light { background-image:none !important; }
body.theme-dark .app, body.theme-light .app, body.theme-dark .main-layout, body.theme-light .main-layout,
body.theme-dark .chat-panel, body.theme-light .chat-panel, body.theme-dark .composer-bar, body.theme-light .composer-bar,
body.theme-dark .participants-card, body.theme-light .participants-card, body.theme-dark .dm-shell, body.theme-light .dm-shell,
body.theme-dark .room-controls-panel, body.theme-light .room-controls-panel, body.theme-dark .modal-card, body.theme-light .modal-card {
  background:var(--panel) !important;
  box-shadow:none !important;
}
body.theme-dark .chat-panel, body.theme-dark .composer-bar, body.theme-dark .participants-card, body.theme-dark .modal-card,
body.theme-light .chat-panel, body.theme-light .composer-bar, body.theme-light .participants-card, body.theme-light .modal-card {
  border-color:var(--border) !important;
}
/* cleaner session-like room controls */
.room-controls-panel {
  background:var(--panel) !important;
}
.room-controls-panel .room-controls-status {
  margin-bottom:12px;
}
.room-controls-panel .room-control-card {
  background:#17181c !important;
  border:1px solid #24262c !important;
  border-radius:28px !important;
  box-shadow:none !important;
}
body.theme-light .room-controls-panel .room-control-card {
  background:#fff !important;
  border:1px solid #dedede !important;
}
.room-controls-panel .conversation-shortcuts .small-action-btn {
  width:100%;
  justify-content:flex-start;
  min-height:64px;
  border-radius:0 !important;
  border:none !important;
  border-top:1px solid rgba(255,255,255,.08) !important;
  background:transparent !important;
  font-size:18px !important;
  font-weight:600 !important;
  color:var(--text) !important;
  padding:0 24px !important;
}
.room-controls-panel .conversation-shortcuts .small-action-btn:first-child { border-top:none !important; }
body.theme-light .room-controls-panel .conversation-shortcuts .small-action-btn { border-top:1px solid rgba(0,0,0,.08) !important; }
/* top right avatars */
.room-menu-avatar, .room-menu-avatar img {
  object-fit:cover;
}
.room-menu-avatar {
  overflow:hidden;
  background:#2d323b !important;
}
/* Stabilization: account-only room controls should show the simple Chatango-style panels. */
#roomControlsTitle { letter-spacing:-.03em !important; }
.room-controls-card .room-controls-overview:not(.hidden),
#roomControlsOverview:not(.hidden) {
  display:block !important;
  white-space:pre-wrap !important;
}
.room-controls-card .room-session-actions {
  display:block !important;
}
.room-controls-card .room-identity-panel.hidden,
.room-controls-card .room-controls-grid.hidden {
  display:none !important;
}
.room-controls-card #roomAutoModSection:not(.hidden),
.room-controls-card #roomControlsStaffSection:not(.hidden),
.room-controls-card #roomControlsModSection:not(.hidden),
.room-controls-card .room-session-admin-card:not(.hidden) {
  display:block !important;
}
.room-controls-card #roomAutoModSection.hidden,
.room-controls-card #roomControlsStaffSection.hidden,
.room-controls-card #roomControlsModSection.hidden,
.room-controls-card .room-session-admin-card.hidden {
  display:none !important;
}

/* Shared interaction polish. Mobile shell and GIF layout live in the current contract below. */
html {
  min-height:100%;
  -webkit-text-size-adjust:100%;
}

body {
  touch-action:manipulation;
}

button,
input,
textarea,
select {
  font:inherit;
}

button:disabled,
input:disabled {
  cursor:not-allowed !important;
  opacity:.55 !important;
}

.modal {
  backdrop-filter:blur(12px) !important;
  -webkit-backdrop-filter:blur(12px) !important;
}

.modal-card,
.dm-card,
.people-card,
.settings-card,
.auth-card,
.profile-card,
#roomControlsModal .modal-card {
  scrollbar-width:thin;
  overscroll-behavior:contain;
}

/* Room controls: public description card, private mod tools. */
.room-controls-card .room-controls-overview:not(.hidden),
#roomControlsOverview:not(.hidden) {
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  white-space:normal !important;
  padding:18px !important;
}

.room-overview-title {
  font-size:28px !important;
  line-height:1 !important;
  font-weight:900 !important;
  letter-spacing:-.045em !important;
}

.room-overview-label {
  margin-top:4px !important;
  color:var(--text-soft) !important;
  font-size:11px !important;
  font-weight:900 !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
}

.room-overview-description {
  color:var(--text) !important;
  font-size:16px !important;
  line-height:1.45 !important;
  overflow-wrap:anywhere !important;
}

.room-overview-meta,
.room-overview-status {
  color:var(--text-soft) !important;
  font-size:13px !important;
  line-height:1.35 !important;
}

.room-overview-status {
  padding-top:2px !important;
}

@media (max-width: 820px) {
  .room-overview-title {
    font-size:24px !important;
  }

  .room-overview-description {
    font-size:15px !important;
  }
}

/* Mobile component polish: replies, reactions, native emoji entry, and voice preview. */
.reply-bar {
  align-items:center !important;
  gap:10px !important;
  padding:10px 12px !important;
  border-radius:18px !important;
  background:linear-gradient(180deg, rgba(57,229,141,.16), rgba(57,229,141,.08)) !important;
  border:1px solid rgba(57,229,141,.34) !important;
  box-shadow:0 10px 28px rgba(0,0,0,.12) !important;
}

body.theme-light .reply-bar {
  background:linear-gradient(180deg, rgba(15,148,85,.12), rgba(15,148,85,.06)) !important;
  border-color:rgba(15,148,85,.22) !important;
}

.reply-label {
  display:flex !important;
  min-width:0 !important;
  flex:1 1 auto !important;
  flex-direction:column !important;
  gap:2px !important;
  line-height:1.2 !important;
}

.reply-label-kicker {
  color:var(--text-soft) !important;
  font-size:11px !important;
  font-weight:900 !important;
  letter-spacing:.12em !important;
  text-transform:uppercase !important;
}

.reply-label-preview {
  color:var(--text) !important;
  font-size:14px !important;
  font-weight:750 !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
}

.reply-cancel-btn {
  width:36px !important;
  height:36px !important;
  display:grid !important;
  place-items:center !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.08) !important;
  color:var(--text) !important;
}

body.theme-light .reply-cancel-btn {
  background:rgba(0,0,0,.05) !important;
}

.message:not(.from-me) .message-body {
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
}

.message-body > .meta {
  width:100% !important;
}

.message-body > .reaction-strip {
  margin:6px 0 0 4px !important;
  max-width:min(72vw, 540px) !important;
  display:flex !important;
  flex-wrap:wrap !important;
  gap:6px !important;
}

.message.from-me .message-body > .reaction-strip {
  align-self:flex-end !important;
  justify-content:flex-end !important;
  margin:6px 4px 0 0 !important;
  max-width:min(72vw, 540px) !important;
}

.reaction-chip {
  min-height:26px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:4px !important;
  padding:4px 9px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.10) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  box-shadow:0 8px 18px rgba(0,0,0,.12) !important;
  font-size:13px !important;
  line-height:1 !important;
}

body.theme-light .reaction-chip {
  background:rgba(0,0,0,.045) !important;
  border-color:rgba(0,0,0,.075) !important;
  box-shadow:none !important;
}

.message-reaction-row.hidden,
.reaction-custom-panel.hidden {
  display:none !important;
}

.message-action-panel {
  border-radius:30px !important;
}

.message-reaction-label {
  padding:12px 14px 0 !important;
  color:var(--text-soft) !important;
  font-size:11px !important;
  font-weight:900 !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
}

.message-reaction-label.hidden {
  display:none !important;
}

.message-reaction-row {
  display:grid !important;
  grid-template-columns:repeat(6, minmax(0, 1fr)) !important;
  gap:8px !important;
  padding:12px !important;
}

.reaction-btn {
  width:100% !important;
  min-width:0 !important;
  height:52px !important;
  border-radius:18px !important;
  background:rgba(255,255,255,.09) !important;
  transform:translateZ(0) !important;
  touch-action:manipulation !important;
}

.reaction-btn:active {
  transform:scale(.96) !important;
}

body.theme-light .reaction-btn {
  background:rgba(0,0,0,.055) !important;
}

.reaction-more-btn {
  font-weight:900 !important;
}

.reaction-custom-panel {
  padding:0 12px 12px !important;
  border-bottom:1px solid rgba(255,255,255,.06) !important;
}

body.theme-light .reaction-custom-panel {
  border-bottom-color:rgba(0,0,0,.06) !important;
}

.reaction-custom-label {
  display:block !important;
  margin:2px 2px 8px !important;
  color:var(--text-soft) !important;
  font-size:11px !important;
  font-weight:900 !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
}

.reaction-custom-row {
  display:grid !important;
  grid-template-columns:minmax(0, 1fr) 90px !important;
  gap:8px !important;
}

#customReactionInput {
  width:100% !important;
  min-width:0 !important;
  min-height:52px !important;
  border:none !important;
  outline:none !important;
  border-radius:18px !important;
  padding:0 14px !important;
  background:rgba(255,255,255,.08) !important;
  color:var(--text) !important;
  font-size:18px !important;
}

body.theme-light #customReactionInput {
  background:rgba(0,0,0,.055) !important;
}

.reaction-custom-send {
  border:none !important;
  border-radius:18px !important;
  background:#39e58d !important;
  color:#041008 !important;
  font-weight:900 !important;
  cursor:pointer !important;
}

.reaction-custom-hint {
  margin:8px 2px 0 !important;
  color:var(--text-soft) !important;
  font-size:12px !important;
  line-height:1.3 !important;
}

.voice-preview-card {
  max-width:min(92vw, 520px) !important;
  padding:26px 22px 20px !important;
  border-radius:32px !important;
  background:linear-gradient(180deg, color-mix(in srgb, var(--panel-raised) 90%, #ffffff), var(--panel)) !important;
  box-shadow:0 28px 80px rgba(0,0,0,.32) !important;
}

body.theme-dark .voice-preview-card {
  background:linear-gradient(180deg, #181c23, #0d0f14) !important;
}

.voice-preview-card .settings-title,
.voice-preview-card .mini-status {
  text-align:center !important;
}

.voice-preview-meter {
  height:52px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:6px !important;
  margin:18px auto 4px !important;
}

.voice-preview-meter span {
  width:7px !important;
  height:18px !important;
  border-radius:999px !important;
  background:linear-gradient(180deg, #39e58d, #7aa2ff) !important;
  opacity:.9 !important;
  animation:voiceMeterPulse 1.25s ease-in-out infinite;
}

.voice-preview-meter span:nth-child(2) { height:34px !important; animation-delay:.08s; }
.voice-preview-meter span:nth-child(3) { height:24px !important; animation-delay:.16s; }
.voice-preview-meter span:nth-child(4) { height:42px !important; animation-delay:.24s; }
.voice-preview-meter span:nth-child(5) { height:28px !important; animation-delay:.32s; }
.voice-preview-meter span:nth-child(6) { height:20px !important; animation-delay:.40s; }

@keyframes voiceMeterPulse {
  0%, 100% { transform:scaleY(.72); opacity:.55; }
  50% { transform:scaleY(1); opacity:1; }
}

.voice-preview-player {
  grid-template-columns:58px minmax(0, 1fr) auto !important;
  gap:12px !important;
  align-items:center !important;
  padding:14px !important;
  margin:10px 0 16px !important;
  border-radius:24px !important;
  background:rgba(255,255,255,.07) !important;
  border:1px solid rgba(255,255,255,.08) !important;
}

body.theme-light .voice-preview-player {
  background:rgba(0,0,0,.045) !important;
  border-color:rgba(0,0,0,.07) !important;
}

.voice-play-btn,
.voice-pill-play {
  background:#39e58d !important;
  color:#041008 !important;
  font-weight:900 !important;
}

.voice-seek,
.voice-pill-seek {
  accent-color:#39e58d !important;
  min-width:0 !important;
}

.voice-duration,
.voice-pill-time {
  font-variant-numeric:tabular-nums !important;
  color:var(--text-soft) !important;
  white-space:nowrap !important;
}

.voice-pill {
  grid-template-columns:42px minmax(86px, 1fr) auto !important;
  max-width:100% !important;
  min-width:min(250px, 100%) !important;
  border-radius:22px !important;
  padding:9px 10px !important;
}

@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  .modal,
  .chat,
  .dm-chat,
  .gif-picker-grid,
  .people-body,
  #roomControlsModal .modal-card {
    -webkit-overflow-scrolling:touch !important;
  }

  .message-action-panel {
    left:8px !important;
    right:8px !important;
    bottom:calc(env(safe-area-inset-bottom) + 8px) !important;
    width:auto !important;
    max-height:calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px) !important;
    transform:none !important;
    border-radius:28px !important;
  }

  .message-action-preview {
    padding:13px 14px !important;
    font-size:13px !important;
  }

  .message-action-btn {
    min-height:54px !important;
    padding:14px 16px !important;
    font-size:16px !important;
  }

  .reaction-btn {
    height:50px !important;
    border-radius:16px !important;
    font-size:23px !important;
  }

  .reaction-custom-row {
    grid-template-columns:minmax(0, 1fr) 82px !important;
  }

  #customReactionInput {
    min-height:50px !important;
    font-size:18px !important;
  }

  .reply-bar {
    margin-bottom:9px !important;
    border-radius:20px !important;
  }

  .reply-label-preview {
    max-width:calc(100vw - 102px) !important;
  }

  .message-body > .reaction-strip,
  .message.from-me .message-body > .reaction-strip {
    max-width:min(74vw, 520px) !important;
  }

  #voicePreviewModal {
    align-items:flex-end !important;
    justify-content:flex-end !important;
    padding:0 !important;
  }

  #voicePreviewModal .voice-preview-card {
    width:100vw !important;
    max-width:none !important;
    height:auto !important;
    min-height:0 !important;
    max-height:calc(100dvh - 12px) !important;
    border:none !important;
    border-radius:30px 30px 0 0 !important;
    padding:calc(env(safe-area-inset-top) + 18px) 18px calc(env(safe-area-inset-bottom) + 18px) !important;
    overflow-y:auto !important;
  }

  .voice-preview-player {
    grid-template-columns:56px minmax(0, 1fr) auto !important;
    padding:12px !important;
  }

  .voice-duration {
    min-width:64px !important;
    font-size:13px !important;
  }

  .voice-pill {
    min-width:min(230px, 100%) !important;
    grid-template-columns:40px minmax(74px, 1fr) auto !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .voice-preview-meter span {
    animation:none !important;
  }
}


/* Current custom message background contract: raw full-bubble image/GIF with chosen text color. */
.message-bubble.has-bg,
.dm-bubble.has-bg,
.settings-preview.has-bg {
  background-color: transparent !important;
  background-image: var(--msg-bg-url) !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-origin: border-box !important;
  background-clip: border-box !important;
}

.message-bubble.has-bg::before,
.message-bubble.has-bg::after,
.dm-bubble.has-bg::before,
.dm-bubble.has-bg::after,
.settings-preview.has-bg::before,
.settings-preview.has-bg::after {
  content: none !important;
  display: none !important;
  background: none !important;
  opacity: 0 !important;
}


#messageInput,
#dmInput {
  -webkit-appearance: none !important;
  appearance: none !important;
}

body.theme-dark .message.from-me .message-bubble:not(.has-bg):not(.media-only),
body.theme-light .message.from-me .message-bubble:not(.has-bg):not(.media-only),
body.theme-dark .dm-message.from-me .dm-bubble:not(.has-bg):not(.media-only),
body.theme-light .dm-message.from-me .dm-bubble:not(.has-bg):not(.media-only) {
  background: #39e58d !important;
  color: #041008 !important;
}

body.theme-dark .message.from-me .message-bubble:not(.has-bg):not(.media-only) .text,
body.theme-light .message.from-me .message-bubble:not(.has-bg):not(.media-only) .text,
body.theme-dark .dm-message.from-me .dm-bubble:not(.has-bg):not(.media-only) .text,
body.theme-light .dm-message.from-me .dm-bubble:not(.has-bg):not(.media-only) .text {
  color: var(--bubble-text-color, #041008) !important;
}


.message-bubble.has-bg,
.dm-bubble.has-bg,
.settings-preview.has-bg {
  color: var(--bubble-text-color, #ffffff) !important;
}

.message-bubble.has-bg .text,
.message-bubble.has-bg .username,
.message-bubble.has-bg .reply-snippet,
.message-bubble.has-bg .reply-snippet-name,
.message-bubble.has-bg .reply-snippet-user,
.message-bubble.has-bg .reply-snippet-preview,
.message-bubble.has-bg .reply-snippet-text,
.dm-bubble.has-bg .text,
.dm-bubble.has-bg .dm-msg-meta,
.dm-bubble.has-bg .reply-snippet,
.dm-bubble.has-bg .reply-snippet-name,
.dm-bubble.has-bg .reply-snippet-user,
.dm-bubble.has-bg .reply-snippet-preview,
.dm-bubble.has-bg .reply-snippet-text,
.settings-preview.has-bg .settings-preview-name,
.settings-preview.has-bg .settings-preview-text {
  color: var(--bubble-text-color, #ffffff) !important;
  text-shadow: 0 1px 6px rgba(0,0,0,.45) !important;
}

.message-bubble.has-bg .reply-snippet,
.dm-bubble.has-bg .reply-snippet {
  background: transparent !important;
  border-color: rgba(255,255,255,.18) !important;
}

#messageInput,
#dmInput {
  autocomplete: off;
  -webkit-text-size-adjust: 100%;
}

@media (max-width: 700px) {
  .settings-quick-controls {
    grid-template-columns: 1fr;
  }

  .settings-push-card {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .push-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .push-actions .small-action-btn {
    width: 100%;
    min-height: 44px;
  }
}

.auth-secondary-actions {
  display: flex;
  justify-content: flex-start;
  margin-top: 10px;
}

.auth-forgot-link,
.auth-forgot-link:visited {
  -webkit-appearance: none;
  appearance: none;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 4px 0;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none;
  cursor: pointer !important;
  -webkit-tap-highlight-color: transparent;
}

.auth-forgot-link:hover,
.auth-forgot-link:focus-visible {
  text-decoration: underline;
}

.auth-forgot-link.is-busy,
.auth-forgot-link[aria-disabled="true"] {
  cursor: default !important;
  opacity: .62;
  pointer-events: none;
  text-decoration: none;
}

.reset-page {
  min-height: 100dvh;
  background:
    radial-gradient(circle at 18% 12%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 34%),
    linear-gradient(180deg, var(--bg), color-mix(in srgb, var(--bg) 88%, #000));
}

.reset-shell {
  min-height: 100dvh;
  display: grid;
  place-items: center;
  padding: max(22px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(22px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
}

.reset-card {
  width: min(100%, 480px);
}

.reset-brand {
  display: inline-flex;
  margin-bottom: 14px;
  color: var(--accent);
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.reset-actions .reset-login-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

/* Owner role tag editor and polished room controls. */
.role-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 19px;
  padding: 3px 7px;
  border: 1px solid var(--role-tag-border, var(--accent-border));
  border-radius: var(--role-tag-radius, 999px);
  background: var(--role-tag-bg, var(--accent-soft));
  color: var(--role-tag-text, var(--accent));
  box-shadow: var(--role-tag-glow, none);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: .08em;
  text-transform: uppercase;
  vertical-align: middle;
  white-space: nowrap;
}

.role-tag-preview-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel-soft) 72%, transparent);
}

.role-tag-editor-grid input[type="color"] {
  min-height: 48px;
  padding: 6px;
}

.room-controls-card {
  gap: 14px !important;
}

.room-controls-card .settings-title {
  font-size: clamp(26px, 4vw, 34px) !important;
  letter-spacing: -.04em !important;
  line-height: 1 !important;
}

.room-controls-overview,
.room-session-actions,
.room-session-admin-card,
.role-tags-panel,
#roomAutoModSection,
#roomControlsStaffSection .room-controls-panel,
#roomControlsModSection .room-controls-panel {
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 26px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    color-mix(in srgb, var(--panel) 92%, #050608) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.04) inset !important;
}

body.theme-light .room-controls-overview,
body.theme-light .room-session-actions,
body.theme-light .room-session-admin-card,
body.theme-light .role-tags-panel,
body.theme-light #roomAutoModSection,
body.theme-light #roomControlsStaffSection .room-controls-panel,
body.theme-light #roomControlsModSection .room-controls-panel {
  border-color: rgba(0,0,0,.08) !important;
  background: linear-gradient(180deg, #fff, #f7f7f5) !important;
}

.room-session-actions .people-section-title,
.room-session-admin-card .people-section-title,
.role-tags-panel .people-section-title,
#roomAutoModSection .people-section-title,
#roomControlsStaffSection .people-section-title,
#roomControlsModSection .people-section-title {
  margin-bottom: 12px !important;
  color: var(--text-faint) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .16em !important;
}

.room-session-top-actions,
.room-session-admin-menu {
  display: grid !important;
  gap: 8px !important;
}

.room-session-actions .room-controls-actions > button,
.room-session-admin-menu > button {
  width: 100% !important;
  min-height: 56px !important;
  margin: 0 !important;
  padding: 0 16px !important;
  border: 1px solid transparent !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.045) !important;
  color: var(--text) !important;
  justify-content: flex-start !important;
  text-align: left !important;
  font-size: 15px !important;
  font-weight: 850 !important;
  box-shadow: none !important;
}

.room-session-actions .room-controls-actions > button:hover,
.room-session-admin-menu > button:hover {
  background: rgba(255,255,255,.075) !important;
  border-color: rgba(255,255,255,.08) !important;
}

body.theme-light .room-session-actions .room-controls-actions > button,
body.theme-light .room-session-admin-menu > button {
  background: rgba(0,0,0,.035) !important;
  color: #111 !important;
}

.room-session-admin-menu > button.danger {
  color: #ff526c !important;
  background: rgba(255,82,108,.08) !important;
}

.room-session-admin-menu > button.danger:hover {
  border-color: rgba(255,82,108,.22) !important;
  background: rgba(255,82,108,.12) !important;
}

/* Current mobile layout contract: iPhone/PWA shell, top menu, compact composer, attachments, and GIF grid.
   Intentionally phone/coarse-pointer gated so desktop widths do not fall into the app-shell layout. */
.top-bar.session-room-header {
  position: relative;
  overflow: visible;
}

.top-controls-wrap {
  display: none !important;
}

.hamburger-menu-btn {
  appearance: none;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(21,22,24,.92);
  color: #fff;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  padding: 0;
  box-shadow: 0 14px 34px rgba(0,0,0,.28);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.hamburger-menu-btn span {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.main-menu-panel {
  position: absolute;
  left: 12px;
  top: calc(env(safe-area-inset-top) + 60px);
  z-index: 180;
  width: min(238px, calc(100vw - 24px));
  display: grid;
  gap: 6px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 24px;
  background: rgba(18,19,21,.96);
  box-shadow: 0 22px 54px rgba(0,0,0,.42);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.main-menu-item {
  appearance: none;
  width: 100%;
  min-height: 48px;
  border: 0;
  border-radius: 16px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  background: transparent;
  color: #f7f7f7;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -.01em;
  text-align: left;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.main-menu-item:hover,
.main-menu-item:focus-visible {
  background: rgba(255,255,255,.075);
  outline: none;
}

.main-menu-state {
  margin: 4px 4px 0;
  padding: 10px 12px 4px;
  border-top: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.58);
  font-size: 12px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

body.theme-light .hamburger-menu-btn,
body.theme-light .main-menu-panel {
  border-color: rgba(0,0,0,.08);
  background: rgba(255,255,255,.96);
  color: #111;
  box-shadow: 0 20px 48px rgba(0,0,0,.12);
}

body.theme-light .main-menu-item {
  color: #111;
}

body.theme-light .main-menu-item:hover,
body.theme-light .main-menu-item:focus-visible {
  background: rgba(0,0,0,.055);
}

body.theme-light .main-menu-state {
  border-top-color: rgba(0,0,0,.08);
  color: rgba(0,0,0,.58);
}

.gif-picker-grid {
  display: grid !important;
  align-content: start !important;
  align-items: stretch !important;
  grid-template-columns: repeat(auto-fill, minmax(158px, 1fr)) !important;
  grid-auto-rows: 164px !important;
  gap: 12px !important;
  overflow-x: hidden !important;
  isolation: isolate;
}

.gif-thumb {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  aspect-ratio: auto !important;
  border-radius: 16px !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #101114 !important;
  contain: layout paint !important;
  transform: none !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}

.gif-thumb img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #101114 !important;
  transform: none !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}

@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  html,
  body {
    width: 100% !important;
    height: 100% !important;
    min-height: 100% !important;
    max-height: none !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    touch-action: manipulation;
    background: #000 !important;
  }

  input,
  textarea,
  select {
    font-size: 16px !important;
  }

  body {
    position: relative !important;
    inset: auto !important;
  }

  .app {
    position: fixed !important;
    inset: auto !important;
    top: var(--app-top, 0px) !important;
    left: var(--app-left, 0px) !important;
    right: auto !important;
    bottom: auto !important;
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    max-width: var(--app-width, 100vw) !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    background: #000 !important;
  }

  .top-bar.session-room-header {
    position: relative !important;
    flex: 0 0 auto !important;
    top: auto !important;
    min-height: calc(env(safe-area-inset-top) + 56px) !important;
    padding: calc(env(safe-area-inset-top) + 5px) 58px 6px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 0 !important;
    background: #000 !important;
    z-index: 150 !important;
    overflow: visible !important;
  }

  .hamburger-menu-btn {
    display: flex !important;
    position: absolute !important;
    left: 10px !important;
    top: calc(env(safe-area-inset-top) + 5px) !important;
    width: 42px !important;
    height: 42px !important;
    z-index: 190 !important;
    pointer-events: auto !important;
  }

  .main-menu-panel {
    position: fixed !important;
    left: 10px !important;
    top: calc(env(safe-area-inset-top) + 50px) !important;
    z-index: 220 !important;
    max-height: calc(var(--app-height, 100dvh) - env(safe-area-inset-top) - 60px) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .room-header-menu-btn {
    display: block !important;
    position: absolute !important;
    right: 10px !important;
    top: calc(env(safe-area-inset-top) + 5px) !important;
    width: 42px !important;
    height: 42px !important;
    z-index: 170 !important;
    pointer-events: auto !important;
  }

  .room-title-stack {
    max-width: calc(100vw - 132px) !important;
    width: auto !important;
    min-width: 0 !important;
    align-items: center !important;
    text-align: center !important;
    pointer-events: none !important;
  }

  .room-title {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: clamp(20px, 6.2vw, 25px) !important;
    line-height: 1.06 !important;
  }

  .room-kicker {
    display: none !important;
  }

  .room-header-sub {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .more-link {
    display: none !important;
  }

  .status {
    flex: 0 0 auto !important;
    min-height: 0 !important;
    margin: 0 10px 4px !important;
    padding: 4px 8px !important;
    font-size: 12px !important;
    line-height: 1.25 !important;
    border-radius: 12px !important;
  }

  .room-notice {
    flex: 0 0 auto !important;
    margin: 0 10px 6px !important;
    padding: 6px 9px !important;
    border-radius: 14px !important;
  }

  .main-layout {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
  }

  .user-panel {
    display: none !important;
  }

  .chat-column {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
  }

  .chat {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 6px 10px 8px !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important;
    touch-action: pan-y !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #000 !important;
  }

  body.keyboard-open .chat,
  body.text-input-focused .chat,
  body.visual-keyboard-open .chat {
    padding-bottom: 8px !important;
  }

  .reply-bar,
  .typing-bar {
    flex: 0 0 auto !important;
    margin: 0 !important;
  }

  #gifPickerModal {
    position: fixed !important;
    inset: auto !important;
    top: var(--app-top, 0px) !important;
    left: var(--app-left, 0px) !important;
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    padding: 0 !important;
    overflow: hidden !important;
    touch-action: pan-y !important;
  }

  .gif-picker-card {
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    max-width: var(--app-width, 100vw) !important;
    max-height: var(--app-height, 100dvh) !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: #050608 !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    padding: 0 !important;
  }

  .gif-picker-top,
  .gif-search-row,
  #gifPickerStatus,
  .gif-powered {
    flex: 0 0 auto !important;
  }

  .gif-picker-top {
    min-height: calc(env(safe-area-inset-top) + 54px) !important;
    padding: calc(env(safe-area-inset-top) + 8px) 12px 8px !important;
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: center !important;
  }

  .gif-picker-top .settings-title {
    margin: 0 !important;
    font-size: 26px !important;
    line-height: 1 !important;
  }

  .gif-picker-cancel {
    width: max-content !important;
    min-height: 38px !important;
    border-radius: 14px !important;
  }

  .gif-search-row {
    margin: 0 12px 10px !important;
    min-height: 44px !important;
  }

  #gifPickerStatus {
    min-height: 18px !important;
    margin: 0 !important;
    padding: 0 12px 8px !important;
  }

  .gif-picker-grid {
    flex: 1 1 auto !important;
    height: auto !important;
    min-height: 0 !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-auto-rows: 156px !important;
    gap: 10px !important;
    padding: 0 12px max(12px, env(safe-area-inset-bottom)) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important;
    touch-action: pan-y !important;
  }

  .gif-powered {
    padding: 8px 12px max(10px, env(safe-area-inset-bottom)) !important;
    text-align: center !important;
  }

  .gif-thumb {
    height: 156px !important;
    border-radius: 15px !important;
  }

  #roomControlsModal {
    position: fixed !important;
    inset: auto !important;
    top: var(--app-top, 0px) !important;
    left: var(--app-left, 0px) !important;
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  #roomControlsModal .modal-card {
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    max-width: var(--app-width, 100vw) !important;
    max-height: var(--app-height, 100dvh) !important;
    border-radius: 0 !important;
    background: #050608 !important;
    padding: calc(env(safe-area-inset-top) + 14px) 14px max(18px, env(safe-area-inset-bottom)) !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }

  #roomControlsModal .settings-title {
    font-size: 25px !important;
    letter-spacing: -.04em !important;
    margin: 2px 54px 6px !important;
  }

  #roomControlsModal .mini-status {
    border-radius: 18px !important;
  }

  .room-controls-overview,
  .room-session-card,
  .room-role-tags-section,
  .room-style-panel,
  .room-settings-section,
  .mod-tools-section {
    border-radius: 24px !important;
    border-color: rgba(255,255,255,.075) !important;
    background: rgba(255,255,255,.035) !important;
    box-shadow: none !important;
  }

  .room-session-actions .room-controls-actions,
  .room-session-admin-menu {
    gap: 8px !important;
  }

  .room-session-actions .room-controls-actions > button,
  .room-session-admin-menu > button {
    min-height: 58px !important;
    border-radius: 18px !important;
    justify-content: flex-start !important;
    background: rgba(255,255,255,.052) !important;
    border-color: rgba(255,255,255,.065) !important;
  }
}

@media (max-width: 380px) and (hover: none), (max-width: 380px) and (pointer: coarse) {
  .gif-picker-grid {
    grid-auto-rows: 138px !important;
  }

  .gif-thumb {
    height: 138px !important;
  }
}

@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  body.reset-page {
    position: static !important;
    height: auto !important;
    min-height: 100dvh !important;
    max-height: none !important;
    overflow: auto !important;
    overscroll-behavior: auto !important;
  }

  body.reset-page .reset-shell {
    min-height: 100dvh !important;
  }
}

/* Phase 1 mobile chat shell: room and DM are true header / scroller / composer screens. */
@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  .top-bar.session-room-header {
    min-height: calc(env(safe-area-inset-top) + 52px) !important;
    padding: calc(env(safe-area-inset-top) + 4px) 58px 5px !important;
    background: #000 !important;
    color: #fff !important;
  }

  .hamburger-menu-btn,
  .room-header-menu-btn {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    min-height: 42px !important;
    border: 0 !important;
    background: transparent !important;
    color: #f8f8f8 !important;
    box-shadow: none !important;
  }

  .hamburger-menu-btn span {
    width: 18px !important;
    height: 2px !important;
    background: currentColor !important;
  }

  .room-header-menu-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .mini-header-avatar {
    width: 27px !important;
    height: 27px !important;
    border-color: rgba(255,255,255,.16) !important;
    background: #242528 !important;
  }

  .room-title {
    font-size: clamp(20px, 6vw, 24px) !important;
    letter-spacing: -.02em !important;
  }

  .room-header-sub {
    font-size: 12px !important;
    line-height: 1.1 !important;
    color: rgba(255,255,255,.62) !important;
  }

  body.theme-light .app,
  body.theme-light .top-bar.session-room-header,
  body.theme-light .main-layout,
  body.theme-light .chat-column,
  body.theme-light .chat,
  body.theme-light .input-shell,
  body.theme-light #dmModal,
  body.theme-light #dmModal .dm-card,
  body.theme-light .dm-top.session-shell-top,
  body.theme-light .dm-chat,
  body.theme-light .dm-input-row.session-compose-row {
    background: #000 !important;
    color: #fff !important;
  }

  .status:empty,
  .dm-status:empty {
    display: none !important;
  }

  .status:not(:empty) {
    margin: 0 14px 5px !important;
    padding: 5px 9px !important;
    max-height: 36px !important;
    overflow: hidden !important;
    background: rgba(255,255,255,.045) !important;
    border-color: rgba(255,255,255,.055) !important;
  }

  .room-notice:not(.hidden) {
    margin: 0 14px 6px !important;
    max-height: 42px !important;
    overflow: hidden !important;
  }

  .main-layout,
  .chat-column,
  .chat,
  .dm-card,
  .dm-chat,
  .dm-bubble-wrap {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .main-layout {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .chat-column {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .chat,
  .dm-chat {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    width: 100% !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
    touch-action: pan-y !important;
    background: #000 !important;
  }

  .chat {
    padding: 6px 14px 10px !important;
    border-radius: 0 !important;
  }

  .message {
    align-items: flex-end !important;
    padding: 6px 0 13px !important;
    gap: 8px !important;
    border-bottom: 0 !important;
    background: transparent !important;
  }

  .avatar,
  .dm-msg-avatar {
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    border: 0 !important;
    background: #1d1e20 !important;
  }

  .message.from-me .avatar,
  .dm-message.from-me .dm-msg-avatar {
    display: none !important;
  }

  .message-body {
    max-width: min(82%, 620px) !important;
  }

  .message.from-me .message-body {
    margin-left: auto !important;
    align-items: flex-end !important;
  }

  .message-bubble,
  .dm-bubble {
    border: 0 !important;
    border-radius: 14px 18px 18px 18px !important;
    padding: 8px 12px !important;
    box-shadow: none !important;
    background: #2b2b2d !important;
    color: #f4f4f4 !important;
  }

  body.theme-light .message-bubble:not(.has-bg):not(.media-only),
  body.theme-light .dm-bubble:not(.has-bg):not(.media-only) {
    background: #2b2b2d !important;
    color: #f4f4f4 !important;
  }

  .message.from-me .message-bubble:not(.has-bg):not(.media-only),
  .dm-message.from-me .dm-bubble:not(.has-bg):not(.media-only) {
    border-radius: 18px 14px 18px 18px !important;
    background: #39e58d !important;
    color: #041008 !important;
  }

  body.theme-light .message.from-me .message-bubble:not(.has-bg):not(.media-only),
  body.theme-light .dm-message.from-me .dm-bubble:not(.has-bg):not(.media-only) {
    background: #39e58d !important;
    color: #041008 !important;
  }

  .message-bubble.media-only,
  .dm-bubble.media-only {
    background: transparent !important;
    padding: 0 !important;
  }

  .username,
  .dm-msg-meta {
  letter-spacing: .01em;
    font-size: 13px !important;
    line-height: 1.15 !important;
    font-weight: 750 !important;
    color: rgba(255,255,255,.88) !important;
  }

  body.theme-light .username,
  body.theme-light .dm-msg-meta {
  letter-spacing: .01em;
    color: rgba(255,255,255,.88) !important;
  }

  .message-bubble .text,
  .dm-bubble .text {
    line-height: 1.28 !important;
  }

  #dmModal {
    position: fixed !important;
    inset: auto !important;
    top: var(--app-top, 0px) !important;
    left: var(--app-left, 0px) !important;
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: #000 !important;
  }

  #dmModal.hidden {
    display: none !important;
  }

  #dmModal .dm-card {
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    max-width: var(--app-width, 100vw) !important;
    max-height: var(--app-height, 100dvh) !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: #000 !important;
  }

  .dm-top.session-shell-top {
    flex: 0 0 auto !important;
    min-height: calc(env(safe-area-inset-top) + 54px) !important;
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) 44px !important;
    align-items: center !important;
    gap: 8px !important;
    padding: calc(env(safe-area-inset-top) + 5px) 12px 6px !important;
    border: 0 !important;
    background: #000 !important;
  }

  .dm-back-btn,
  .dm-header-avatar-btn {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    min-height: 42px !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #f8f8f8 !important;
  }

  .dm-avatar {
    width: 30px !important;
    height: 30px !important;
    font-size: 13px !important;
    border-color: rgba(255,255,255,.16) !important;
    background: #242528 !important;
  }

  .dm-title-wrap {
    min-width: 0 !important;
    text-align: center !important;
    align-items: center !important;
  }

  .dm-name {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: clamp(20px, 6vw, 24px) !important;
    line-height: 1.1 !important;
    letter-spacing: -.02em !important;
  }

  .dm-sub {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 12px !important;
    line-height: 1.1 !important;
    color: rgba(255,255,255,.62) !important;
  }

  .dm-status:not(:empty) {
    flex: 0 0 auto !important;
    margin: 0 14px 6px !important;
    padding: 5px 9px !important;
    max-height: 36px !important;
    overflow: hidden !important;
    border-radius: 12px !important;
    background: rgba(255,255,255,.045) !important;
  }

  .dm-actions.session-hidden-actions {
    display: none !important;
  }

  .dm-chat {
    padding: 8px 14px 10px !important;
    border: 0 !important;
    border-radius: 0 !important;
  }

  .dm-message {
    gap: 8px !important;
    margin-bottom: 12px !important;
  }

  .dm-bubble-wrap {
    max-width: min(82%, 620px) !important;
  }

  .dm-message.from-me .dm-bubble-wrap {
    margin-left: auto !important;
    align-items: flex-end !important;
  }

  .dm-input-row.session-compose-row {
    flex: 0 0 auto !important;
    padding: 7px 12px max(7px, env(safe-area-inset-bottom)) !important;
  }

  .people-item,
  .member-row,
  .people-card-main,
  .people-card-preview,
  .people-card-meta,
  .dm-msg-meta,
  .text {
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }

  .room-controls-columns {
    grid-template-columns: 1fr !important;
  }

  #gifPickerModal,
  .gif-picker-card,
  .gif-picker-grid {
    overscroll-behavior: contain !important;
    touch-action: pan-y !important;
  }
}

/* Session-style mobile page system: full-screen pages, row lists, and grouped cards. */
@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  :root {
    --session-mobile-bg: #000;
    --session-mobile-card: #18191b;
    --session-mobile-card-2: #202123;
    --session-mobile-line: rgba(255,255,255,.055);
    --session-mobile-text: #f6f6f6;
    --session-mobile-muted: rgba(255,255,255,.58);
    --session-mobile-green: #39e58d;
    --session-mobile-red: #ff4f63;
  }

  #peopleModal,
  #settingsModal,
  #authModal,
  #profileModal,
  #roomControlsModal,
  #notificationsModal {
    position: fixed !important;
    inset: auto !important;
    top: var(--app-top, 0px) !important;
    left: var(--app-left, 0px) !important;
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: var(--session-mobile-bg) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  #peopleModal.hidden,
  #settingsModal.hidden,
  #authModal.hidden,
  #profileModal.hidden,
  #roomControlsModal.hidden,
  #notificationsModal.hidden {
    display: none !important;
  }

  #peopleModal .people-card,
  #settingsModal .settings-card,
  #authModal .auth-card,
  #profileModal .profile-card,
  #roomControlsModal .room-controls-card,
  #notificationsModal .settings-card {
    width: var(--app-width, 100vw) !important;
    height: var(--app-height, 100dvh) !important;
    max-width: var(--app-width, 100vw) !important;
    max-height: var(--app-height, 100dvh) !important;
    min-height: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: var(--session-mobile-bg) !important;
    color: var(--session-mobile-text) !important;
    box-shadow: none !important;
  }

  #settingsModal .settings-card,
  #authModal .auth-card,
  #profileModal .profile-card,
  #roomControlsModal .room-controls-card,
  #notificationsModal .settings-card {
    display: block !important;
    padding: calc(env(safe-area-inset-top) + 14px) 20px max(24px, env(safe-area-inset-bottom)) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }

  #settingsModal .settings-title,
  #authModal .settings-title,
  #roomControlsModal .settings-title,
  #notificationsModal .settings-title {
    min-height: 44px !important;
    margin: 0 46px 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    font-size: 24px !important;
    line-height: 1.1 !important;
    font-weight: 800 !important;
    letter-spacing: -.03em !important;
    color: #fff !important;
    background: transparent !important;
  }

  #settingsModal .close-btn,
  #authModal .close-btn,
  #profileModal .close-btn,
  #roomControlsModal .close-btn,
  #notificationsModal .close-btn {
    position: fixed !important;
    top: calc(env(safe-area-inset-top) + 10px) !important;
    z-index: 1800 !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: transparent !important;
    color: #f6f6f6 !important;
    box-shadow: none !important;
    font-size: 28px !important;
    line-height: 1 !important;
  }

  #settingsModal .close-btn,
  #authModal .close-btn,
  #profileModal .close-btn,
  #notificationsModal .close-btn {
    left: 8px !important;
    right: auto !important;
  }

  #roomControlsModal #closeRoomControlsBtn {
    right: 8px !important;
    left: auto !important;
  }

  #roomControlsModal #roomControlsEditBtn {
    right: 52px !important;
    left: auto !important;
    font-size: 21px !important;
  }

  #peopleModal .people-card {
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    padding: 0 !important;
  }

  .people-header {
    flex: 0 0 auto !important;
    position: relative !important;
    min-height: calc(env(safe-area-inset-top) + 58px) !important;
    padding: calc(env(safe-area-inset-top) + 8px) 58px 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--session-mobile-bg) !important;
    color: #fff !important;
    border: 0 !important;
  }

  .people-header-title {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 24px !important;
    line-height: 1.1 !important;
    font-weight: 800 !important;
    letter-spacing: -.03em !important;
  }

  .people-close-btn {
    position: absolute !important;
    left: 8px !important;
    top: calc(env(safe-area-inset-top) + 9px) !important;
    width: 40px !important;
    height: 40px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: transparent !important;
    color: #fff !important;
    font-size: 28px !important;
    line-height: 1 !important;
    box-shadow: none !important;
  }

  .people-tabs {
    flex: 0 0 auto !important;
    display: flex !important;
    gap: 0 !important;
    padding: 0 12px !important;
    border: 0 !important;
    border-bottom: 1px solid var(--session-mobile-line) !important;
    background: var(--session-mobile-bg) !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .people-tabs::-webkit-scrollbar {
    display: none !important;
  }

  .people-tab {
    flex: 0 0 auto !important;
    min-width: max-content !important;
    min-height: 42px !important;
    border: 0 !important;
    border-radius: 0 !important;
    border-bottom: 2px solid transparent !important;
    padding: 0 14px !important;
    background: transparent !important;
    color: var(--session-mobile-muted) !important;
    font-size: 14px !important;
    font-weight: 750 !important;
  }

  .people-tab.active {
    border-bottom-color: var(--session-mobile-green) !important;
    color: #fff !important;
    background: transparent !important;
  }

  .people-status {
    flex: 0 0 auto !important;
    margin: 0 14px !important;
    padding: 0 !important;
  }

  .people-status:empty {
    display: none !important;
  }

  .people-body {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding: 0 12px max(16px, env(safe-area-inset-bottom)) !important;
    overflow: hidden !important;
    background: var(--session-mobile-bg) !important;
  }

  .people-panel {
    height: 100% !important;
    min-height: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .people-panel.active {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    padding: 12px 0 20px !important;
  }

  .people-list,
  .members-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  .people-item,
  .member-row {
    width: 100% !important;
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: center !important;
    padding: 10px 2px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .people-item + .people-item,
  .member-row + .member-row {
    border-top: 1px solid rgba(255,255,255,.035) !important;
  }

  .people-item-unread {
    box-shadow: inset 3px 0 0 var(--session-mobile-green) !important;
  }

  .people-card-avatar,
  .member-avatar {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: #242528 !important;
    color: #fff !important;
    font-size: 16px !important;
  }

  .people-card-main,
  .member-main {
    min-width: 0 !important;
  }

  .people-card-name,
  .member-topline {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: #f5f5f5 !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
  }

  .people-card-meta,
  .people-card-preview,
  .member-state,
  .member-about {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: var(--session-mobile-muted) !important;
    font-size: 13px !important;
    line-height: 1.25 !important;
  }

  .people-card-preview,
  .member-about {
    margin-top: 2px !important;
  }

  .people-card-badges {
    margin-top: 5px !important;
  }

  .people-card-actions,
  .member-actions {
    grid-column: 2 !important;
    display: flex !important;
    justify-content: flex-start !important;
    gap: 7px !important;
    margin-top: 6px !important;
    flex-wrap: wrap !important;
  }

  .people-card-actions .small-action-btn,
  .member-actions .small-action-btn {
    min-height: 34px !important;
    height: 34px !important;
    border-radius: 999px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
  }

  .members-toolbar {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 0 0 12px !important;
  }

  #membersSearch {
    grid-column: 1 / -1 !important;
  }

  #membersSearch,
  #membersAgeFilter,
  #membersGenderFilter {
    width: 100% !important;
    height: 42px !important;
    border: 0 !important;
    border-radius: 16px !important;
    background: var(--session-mobile-card) !important;
    color: #fff !important;
    padding: 0 13px !important;
  }

  .profile-page-card {
    display: grid !important;
    grid-template-columns: 64px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: center !important;
    margin: 0 0 12px !important;
    padding: 12px 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .profile-page-avatar {
    width: 64px !important;
    height: 64px !important;
    border-radius: 999px !important;
  }

  .profile-page-name {
    font-size: 22px !important;
    color: #fff !important;
  }

  .profile-page-sub {
    color: var(--session-mobile-muted) !important;
  }

  .settings-quick-controls,
  .settings-push-card,
  .profile-page-card + .form-grid,
  #settingsModal .form-grid,
  #authModal .form-grid,
  #roomControlsModal .form-grid,
  .room-controls-panel,
  .room-controls-overview,
  .room-role-tags-section,
  .room-style-panel,
  .room-settings-section,
  .mod-tools-section {
    border: 0 !important;
    border-radius: 18px !important;
    background: var(--session-mobile-card) !important;
    box-shadow: none !important;
  }

  #settingsModal .form-grid,
  #authModal .form-grid,
  #roomControlsModal .form-grid {
    gap: 0 !important;
    padding: 4px 0 !important;
    overflow: hidden !important;
  }

  .field {
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .field + .field,
  .settings-toggle-row + .settings-toggle-row,
  .room-session-admin-menu > button + button,
  .room-controls-actions > button + button {
    border-top: 1px solid var(--session-mobile-line) !important;
  }

  .field input,
  .field textarea,
  .field select {
    border: 0 !important;
    border-radius: 14px !important;
    background: var(--session-mobile-card-2) !important;
    color: #fff !important;
  }

  .settings-toggle-row,
  .room-session-admin-menu > button,
  .room-controls-actions > button,
  .settings-push-card,
  .auth-actions > button {
    min-height: 54px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #fff !important;
    box-shadow: none !important;
  }

  .settings-toggle-row,
  .room-session-admin-menu > button {
    padding: 0 16px !important;
    justify-content: flex-start !important;
    text-align: left !important;
  }

  .settings-toggle-row strong {
    color: var(--session-mobile-muted) !important;
    font-size: 12px !important;
  }

  .people-section-title {
    margin: 14px 2px 7px !important;
    color: var(--session-mobile-muted) !important;
    font-size: 12px !important;
    letter-spacing: .08em !important;
  }

  .mini-status,
  .empty-box {
    border: 0 !important;
    border-radius: 16px !important;
    background: var(--session-mobile-card) !important;
    color: var(--session-mobile-muted) !important;
    box-shadow: none !important;
  }

  .room-overview-title {
    color: #fff !important;
    font-size: 24px !important;
  }

  .room-session-admin-menu > button.danger,
  .message-action-btn.danger,
  .room-controls-actions > button.danger {
    color: var(--session-mobile-red) !important;
  }

  .room-attachments-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 2px !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: transparent !important;
  }

  .room-attachment-thumb {
    aspect-ratio: 1 / 1 !important;
    border-radius: 0 !important;
  }
}

/* Session composer rebuild: replaces the old input-shell/input-row bottom dock. */
.session-composer {
  flex: 0 0 auto;
  position: relative;
  width: 100%;
  max-width: 100%;
  padding: 8px 12px max(8px, env(safe-area-inset-bottom));
  border-top: 1px solid rgba(255,255,255,.08);
  background: #161719;
  box-shadow: none;
  overflow: visible;
  z-index: 130;
}

.session-composer-room {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.session-composer-dm {
  margin-top: 0;
}

.session-composer-row {
  position: relative;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr) 46px;
  gap: 0;
  align-items: center;
  width: 100%;
  min-width: 0;
  min-height: 52px;
  padding: 3px 4px;
  border: 1px solid rgba(255,255,255,.055);
  border-radius: 26px;
  background: #242527;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
  overflow: visible;
}

.session-compose-btn,
#sendBtn.session-compose-btn,
#sendDmBtn.session-compose-btn {
  width: 46px !important;
  min-width: 46px !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  color: #f7f7f7 !important;
  box-shadow: none !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.session-compose-plus {
  font-size: 32px !important;
  font-weight: 200 !important;
  padding-bottom: 2px !important;
  color: rgba(255,255,255,.88) !important;
}

.session-compose-voice {
  position: relative;
  font-size: 0 !important;
}

.session-compose-voice::before {
  content: "";
  width: 12px;
  height: 19px;
  border: 2px solid currentColor;
  border-radius: 999px;
}

.session-compose-voice::after {
  content: "";
  position: absolute;
  width: 18px;
  height: 12px;
  left: 50%;
  top: 25px;
  transform: translateX(-50%);
  border-bottom: 2px solid currentColor;
  border-left: 2px solid currentColor;
  border-right: 2px solid currentColor;
  border-radius: 0 0 10px 10px;
}

.session-compose-voice.voice-recording::before {
  width: 15px;
  height: 15px;
  border: 0;
  border-radius: 4px;
  background: #ff4f6a;
}

.session-compose-voice.voice-recording::after {
  display: none;
}

#sendBtn.session-compose-send,
#sendDmBtn.session-compose-send {
  display: none !important;
  background: transparent !important;
  color: #39e58d !important;
  font-size: 24px !important;
  font-weight: 900 !important;
}

#sendBtn.session-compose-send::before,
#sendDmBtn.session-compose-send::before {
  content: none !important;
}

.session-composer-row.has-text .session-compose-voice {
  display: none !important;
}

.session-composer-row.has-text #sendBtn.session-compose-send,
.session-composer-row.has-text #sendDmBtn.session-compose-send {
  display: flex !important;
}

.composer-field {
  min-width: 0;
  height: 46px;
  display: flex;
  align-items: center;
  border-radius: 0;
  background: transparent;
  border: 0;
  overflow: hidden;
}

.composer-field #messageInput,
.composer-field #dmInput {
  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 0 8px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #f5f5f5 !important;
  font-size: 17px !important;
  line-height: 46px !important;
  caret-color: #39e58d !important;
}

.composer-field #messageInput::placeholder,
.composer-field #dmInput::placeholder {
  color: rgba(255,255,255,.46) !important;
}

.session-attach-menu {
  position: absolute;
  left: 0;
  bottom: calc(100% + 10px);
  z-index: 240;
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 56px;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  overflow: visible;
}

.session-attach-menu.hidden {
  display: none !important;
}

.session-attach-item {
  width: 56px;
  height: 56px;
  min-width: 56px;
  min-height: 56px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 999px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #242527;
  color: #fff;
  box-shadow: 0 12px 28px rgba(0,0,0,.42);
  font-size: 0;
  font-weight: 850;
  letter-spacing: -.04em;
}

.session-attach-gif {
  font-size: 16px;
}

.session-attach-photo::before {
  content: "▧";
  font-size: 25px;
  line-height: 1;
}

.session-attach-video::before {
  content: '';
  width: 22px;
  height: 22px;
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 20px 20px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M8 5.25L18 12L8 18.75Z' stroke='white' stroke-width='2.35' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.session-attach-camera::before {
  content: "⌾";
  font-size: 27px;
  line-height: 1;
}

.session-composer .reply-bar {
  margin: 0;
  border-radius: 18px;
  background: #202123;
  border-color: rgba(255,255,255,.08);
}

.session-composer .typing-bar {
  min-height: 0;
  margin: 0;
  padding: 0 4px;
}

.msg-media-card {
  position: relative;
  display: block;
  max-width: min(320px, 100%);
  margin: 8px 0 0;
  padding: 0;
  border: 0;
  border-radius: 18px;
  background: transparent;
  overflow: hidden;
  cursor: pointer;
  box-shadow: none;
}

.message-bubble.media-only .msg-media-card,
.dm-bubble.media-only .msg-media-card {
  margin-top: 0;
}

.msg-media-card .msg-image,
.msg-video-thumb {
  display: block;
  width: 100%;
  max-width: 100%;
  min-width: min(210px, 72vw);
  max-height: 360px;
  object-fit: cover;
  border: 0;
  border-radius: 18px;
  margin: 0;
  box-shadow: none;
  background: #111;
}

.msg-video-thumb {
  aspect-ratio: 4 / 5;
}

.msg-video-badge {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.58);
  color: #fff;
  font-size: 22px;
  padding-left: 3px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.msg-media-label {
  position: absolute;
  left: 10px;
  bottom: 10px;
  padding: 5px 8px;
  border-radius: 999px;
  background: rgba(0,0,0,.54);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
}

.room-attachment-thumb {
  position: relative;
}

.room-attachment-thumb video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.room-attachment-play {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: 14px;
  padding-left: 2px;
}

.media-preview-page {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  background: #000;
  color: #fff;
}

.media-preview-page.hidden {
  display: none !important;
}

.media-preview-top {
  flex: 0 0 auto;
  min-height: calc(env(safe-area-inset-top) + 58px);
  padding: calc(env(safe-area-inset-top) + 7px) 12px 8px;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) 82px;
  align-items: center;
  gap: 8px;
}

.media-preview-back,
.media-preview-text-btn,
.media-preview-action {
  border: 0;
  background: transparent;
  color: #f5f5f5;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.media-preview-back {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  font-size: 39px;
  line-height: 1;
}

.media-preview-title-wrap {
  min-width: 0;
  text-align: center;
}

.media-preview-title {
  font-size: 21px;
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -.02em;
}

.media-preview-sub {
  margin-top: 2px;
  font-size: 12px;
  line-height: 1.1;
  color: rgba(255,255,255,.58);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.media-preview-text-btn {
  justify-self: end;
  font-size: 13px;
  font-weight: 700;
  color: #39e58d;
}

.media-preview-stage {
  flex: 1 1 0;
  min-height: 0;
  display: grid;
  place-items: center;
  position: relative;
  padding: 10px 0;
  overflow: hidden;
}

.media-preview-image,
.media-preview-video {
  max-width: 100vw;
  max-height: 100%;
  object-fit: contain;
  background: #000;
}

.media-preview-video {
  width: 100%;
  height: 100%;
}

.media-preview-play {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 74px;
  height: 74px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(20,21,23,.74);
  color: #fff;
  font-size: 31px;
  padding-left: 5px;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.media-preview-actions {
  flex: 0 0 auto;
  min-height: calc(env(safe-area-inset-bottom) + 62px);
  padding: 10px 18px max(14px, env(safe-area-inset-bottom));
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid rgba(255,255,255,.08);
}

.media-preview-action {
  min-width: 96px;
  height: 42px;
  padding: 0 18px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: #18191b;
  font-weight: 800;
}

.media-preview-delete {
  color: #ff4f6a;
}

.session-voice-modal {
  align-items: flex-end !important;
  justify-content: flex-end !important;
  padding: 0 !important;
  background: rgba(0,0,0,.45) !important;
}

.session-voice-sheet {
  width: 100%;
  max-width: 560px;
  margin: 0 auto;
  padding: 10px 16px max(16px, env(safe-area-inset-bottom));
  border-radius: 28px 28px 0 0;
  background: #18191b;
  border: 1px solid rgba(255,255,255,.08);
  border-bottom: 0;
  color: #fff;
  box-shadow: 0 -18px 50px rgba(0,0,0,.5);
}

.session-voice-handle {
  width: 44px;
  height: 5px;
  border-radius: 999px;
  margin: 0 auto 14px;
  background: rgba(255,255,255,.18);
}

.session-voice-head {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 12px;
  align-items: center;
}

.session-voice-icon-btn {
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: #202123;
  color: #fff;
  font-size: 28px;
  line-height: 1;
}

.session-voice-title {
  font-size: 20px;
  font-weight: 850;
  letter-spacing: -.02em;
}

.session-voice-sub {
  margin-top: 2px;
  color: rgba(255,255,255,.56);
  font-size: 13px;
}

.session-voice-sheet .voice-preview-meter {
  height: 58px !important;
  margin: 16px 0 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
}

.session-voice-sheet .voice-preview-meter span {
  width: 6px !important;
  border-radius: 999px !important;
  background: #39e58d !important;
}

.session-voice-sheet .voice-preview-player {
  display: grid !important;
  grid-template-columns: 48px minmax(0, 1fr) auto !important;
  gap: 12px !important;
  align-items: center !important;
  padding: 12px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 24px !important;
  background: #202123 !important;
}

.session-voice-sheet .voice-play-btn {
  width: 48px !important;
  height: 48px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #39e58d !important;
  color: #041008 !important;
  font-weight: 900 !important;
}

.session-voice-sheet .voice-seek {
  width: 100%;
  min-width: 0;
  accent-color: #39e58d;
}

.session-voice-sheet .voice-duration {
  min-width: 74px;
  text-align: right;
  color: rgba(255,255,255,.62);
  font-variant-numeric: tabular-nums;
  font-size: 13px;
}

.session-voice-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 14px;
}

.session-voice-cancel,
.session-voice-send {
  height: 46px;
  border-radius: 999px;
  font-weight: 850;
  border: 1px solid rgba(255,255,255,.1);
}

.session-voice-cancel {
  background: #202123;
  color: #fff;
}

.session-voice-send {
  border-color: #39e58d;
  background: #39e58d;
  color: #041008;
}

@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  .session-composer {
    padding: 8px 14px max(8px, env(safe-area-inset-bottom)) !important;
    background: #161719 !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
  }

  body.keyboard-open .session-composer,
  body.text-input-focused .session-composer,
  body.visual-keyboard-open .session-composer {
    padding-bottom: 8px !important;
  }

  .session-composer-row {
    grid-template-columns: 46px minmax(0, 1fr) 46px !important;
    gap: 0 !important;
    min-height: 52px !important;
    padding: 3px 4px !important;
    border-radius: 26px !important;
    background: #242527 !important;
  }

  .session-compose-btn,
  #sendBtn.session-compose-btn,
  #sendDmBtn.session-compose-btn {
    width: 46px !important;
    min-width: 46px !important;
    height: 46px !important;
    min-height: 46px !important;
  }

  .composer-field,
  .composer-field #messageInput,
  .composer-field #dmInput {
    height: 46px !important;
    min-height: 46px !important;
    line-height: 46px !important;
  }

  .composer-field #messageInput,
  .composer-field #dmInput {
    font-size: 17px !important;
    padding: 0 8px !important;
  }

  .session-attach-menu {
    left: 0 !important;
    bottom: calc(100% + 10px) !important;
    gap: 10px !important;
    width: 56px !important;
  }

  .session-attach-item {
    width: 56px !important;
    min-width: 56px !important;
    height: 56px !important;
    min-height: 56px !important;
  }

  .dm-card > .session-composer {
    flex: 0 0 auto !important;
  }

  .media-preview-page {
    position: fixed !important;
    inset: auto !important;
    top: var(--app-top, 0px) !important;
    left: var(--app-left, 0px) !important;
    width: var(--app-width, 100vw);
    height: var(--app-height, 100dvh);
    max-width: var(--app-width, 100vw);
    max-height: var(--app-height, 100dvh);
  }

  .session-voice-sheet {
    max-width: none;
  }
}

/* Step 3: shared Session-style full-screen page system. */
.session-page-modal {
  align-items: stretch !important;
  justify-content: center !important;
  padding: 0 !important;
  background: #000 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  overflow: hidden !important;
}

.session-page-card {
  width: min(100vw, 760px) !important;
  height: 100dvh !important;
  max-height: none !important;
  margin: 0 auto !important;
  padding: calc(env(safe-area-inset-top) + 22px) 22px calc(env(safe-area-inset-bottom) + 28px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #000 !important;
  color: #fff !important;
  box-shadow: none !important;
  overflow-y: auto !important;
  overscroll-behavior: contain !important;
  -webkit-overflow-scrolling: touch !important;
}

.session-page-card > .close-btn,
.session-page-card > .people-header .people-close-btn {
  position: absolute !important;
  left: 12px !important;
  right: auto !important;
  top: calc(env(safe-area-inset-top) + 14px) !important;
  width: 42px !important;
  height: 42px !important;
  display: grid !important;
  place-items: center !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: rgba(255,255,255,.92) !important;
  font-size: 29px !important;
  line-height: 1 !important;
  z-index: 3;
}

.session-page-card > .close-btn:hover,
.session-page-card > .people-header .people-close-btn:hover {
  background: rgba(255,255,255,.08) !important;
}

.session-page-card .settings-title,
.session-page-card .people-header-title {
  min-height: 44px !important;
  margin: 0 48px 16px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #f6f6f6 !important;
  font-size: 24px !important;
  font-weight: 850 !important;
  line-height: 1.1 !important;
  letter-spacing: -.035em !important;
  text-align: center !important;
}

.session-page-card .auth-note,
.session-page-card .mini-status,
.session-page-card .profile-sub,
.session-page-card .profile-page-sub,
.session-page-card .people-card-meta,
.session-page-card .people-card-preview,
.session-page-card .member-state,
.session-page-card .member-about,
.session-page-card .field span,
.session-page-card .room-overview-meta,
.session-page-card .room-overview-status {
  color: rgba(255,255,255,.58) !important;
}

.session-page-card .people-section-title,
.session-page-card .settings-preview-label,
.session-page-card .room-overview-label {
  margin: 18px 8px 8px !important;
  color: rgba(255,255,255,.48) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

.session-page-card .people-header {
  display: block !important;
  position: relative !important;
  margin: 0 0 6px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.session-page-card .people-tabs {
  display: flex !important;
  gap: 0 !important;
  margin: 0 -2px 14px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  overflow-x: auto !important;
  scrollbar-width: none;
}

.session-page-card .people-tabs::-webkit-scrollbar {
  display: none;
}

.session-page-card .people-tab {
  flex: 0 0 auto !important;
  min-height: 44px !important;
  padding: 0 14px !important;
  border: 0 !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: rgba(255,255,255,.58) !important;
  font-size: 15px !important;
  font-weight: 750 !important;
}

.session-page-card .people-tab.active {
  border-bottom-color: #39e58d !important;
  color: #fff !important;
  background: transparent !important;
}

.session-page-card .people-body {
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

.session-page-card .people-panel {
  height: auto !important;
  overflow: visible !important;
}

.session-page-card .people-status:empty {
  display: none;
}

.session-page-card .settings-quick-controls,
.session-page-card .settings-push-card,
.session-page-card .profile-page-card,
.session-page-card .settings-preview,
.session-page-card .room-controls-panel,
.session-page-card .room-controls-overview,
.session-page-card .people-list,
.session-page-card .members-list,
.session-page-card .form-grid,
.session-page-card .profile-bio {
  border: 0 !important;
  border-radius: 14px !important;
  background: #171717 !important;
  box-shadow: none !important;
}

.session-page-card .settings-quick-controls,
.session-page-card .form-grid,
.session-page-card .room-controls-panel,
.session-page-card .room-controls-overview {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

.session-page-card .settings-toggle-row,
.session-page-card .field,
.session-page-card .settings-push-card,
.session-page-card .room-session-row-btn,
.session-page-card .people-item,
.session-page-card .member-row {
  min-height: 58px !important;
  margin: 0 !important;
  padding: 12px 16px !important;
  border: 0 !important;
  border-radius: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.065) !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #fff !important;
}

.session-page-card .settings-toggle-row:last-child,
.session-page-card .field:last-child,
.session-page-card .settings-push-card:last-child,
.session-page-card .room-session-row-btn:last-child,
.session-page-card .people-item:last-child,
.session-page-card .member-row:last-child {
  border-bottom: 0 !important;
}

.session-page-card .field {
  gap: 7px !important;
}

.session-page-card .field input,
.session-page-card .field select,
.session-page-card .field textarea,
.session-page-card #membersSearch,
.session-page-card #membersAgeFilter,
.session-page-card #membersGenderFilter {
  width: 100% !important;
  min-height: 42px !important;
  border: 0 !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.075) !important;
  color: #fff !important;
  outline: none !important;
}

.session-page-card .field textarea {
  min-height: 92px !important;
}

.session-page-card .settings-toggle-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  text-align: left !important;
}

.session-page-card .settings-toggle-row span,
.session-page-card .settings-toggle-row strong,
.session-page-card .settings-push-title {
  color: #fff !important;
}

.session-page-card .settings-toggle-row strong {
  color: rgba(255,255,255,.54) !important;
  font-size: 13px !important;
  font-weight: 650 !important;
}

.session-page-card .settings-push-card {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
}

.session-page-card .push-actions,
.session-page-card .row-actions,
.session-page-card .people-card-actions,
.session-page-card .member-actions,
.session-page-card .room-controls-actions {
  margin-top: 12px !important;
  justify-content: flex-start !important;
  gap: 8px !important;
}

.session-page-card .modal-btn,
.session-page-card .small-action-btn {
  min-height: 40px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: #f4f4f4 !important;
  box-shadow: none !important;
}

.session-page-card .modal-btn:hover,
.session-page-card .small-action-btn:hover {
  background: rgba(255,255,255,.08) !important;
}

.session-page-card .modal-btn.danger,
.session-page-card .small-action-btn.danger,
.session-page-card .room-session-row-btn.danger {
  color: #ff4b67 !important;
}

.session-page-card .profile-avatar,
.session-page-card .profile-page-avatar {
  margin: 10px auto 14px !important;
  width: 112px !important;
  height: 112px !important;
  border-radius: 999px !important;
  border: 0 !important;
  background-color: #252525 !important;
  box-shadow: none !important;
}

.session-page-card .profile-name,
.session-page-card .profile-page-name {
  color: #fff !important;
  text-align: center !important;
}

.session-page-card .profile-page-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  padding: 18px 16px !important;
}

.session-page-card .people-list,
.session-page-card .members-list {
  gap: 0 !important;
  overflow: hidden !important;
}

.session-page-card .people-item,
.session-page-card .member-row {
  display: grid !important;
  grid-template-columns: 46px minmax(0, 1fr) auto !important;
  gap: 12px !important;
  align-items: center !important;
}

.session-page-card .people-card-avatar,
.session-page-card .member-avatar,
.session-page-card .user-avatar,
.session-page-card .dm-avatar,
.session-page-card .mini-header-avatar {
  border: 0 !important;
  border-radius: 999px !important;
  background-color: #252525 !important;
  box-shadow: none !important;
}

.session-page-card .people-card-name,
.session-page-card .member-name,
.session-page-card .member-topline {
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 760 !important;
  line-height: 1.18 !important;
  word-break: normal !important;
  overflow-wrap: anywhere !important;
}

.session-page-card .people-card-preview,
.session-page-card .member-about {
  display: -webkit-box !important;
  max-width: 100% !important;
  overflow: hidden !important;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.session-page-card .members-toolbar {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 92px 92px !important;
  gap: 8px !important;
  margin: 0 0 12px !important;
}

.session-page-card .room-overview-title {
  color: #fff !important;
}

.session-page-card .room-overview-description {
  color: rgba(255,255,255,.86) !important;
}

.session-page-card .room-session-admin-menu {
  display: block !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  background: #171717 !important;
}

.session-page-card .room-attachments-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 2px !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  background: #000 !important;
}

.session-page-card .room-attachment-thumb {
  border-radius: 0 !important;
  background: #151515 !important;
}

.session-group-page .room-edit-btn {
  left: auto !important;
  right: 12px !important;
  top: calc(env(safe-area-inset-top) + 14px) !important;
  display: grid !important;
}

.session-group-page .room-edit-btn.hidden {
  display: none !important;
}

.session-group-page .room-identity-panel:not(.hidden),
.session-group-page .room-session-actions,
.session-group-page #roomAutoModSection:not(.hidden),
.session-group-page .room-session-admin-card:not(.hidden),
.session-group-page #roomControlsStaffSection:not(.hidden),
.session-group-page #roomControlsModSection:not(.hidden) {
  display: block !important;
}

/* Avatar clarity: keep anti-save protection without dimming real photos. */
.protected-avatar,
.user-avatar,
.avatar,
.profile-avatar,
.dm-avatar,
.dm-msg-avatar,
.people-card-avatar,
.member-avatar,
.profile-page-avatar,
.mini-header-avatar {
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
  background-blend-mode: normal !important;
}

.protected-avatar[style*="background-image"] {
  color: transparent !important;
  text-shadow: none !important;
}

.protected-avatar.has-avatar-image {
  background-color: transparent !important;
  box-shadow: none !important;
}

.avatar.clickable:hover,
.username.clickable:hover {
  opacity: 1 !important;
}

.session-notifications-page .settings-push-card {
  border-radius: 14px !important;
  border-bottom: 0 !important;
  background: #171717 !important;
}

/* Final avatar clarity guard: real photos must beat placeholder backgrounds. */
.protected-avatar.has-avatar-image,
.user-avatar.has-avatar-image,
.avatar.has-avatar-image,
.profile-avatar.has-avatar-image,
.dm-avatar.has-avatar-image,
.dm-msg-avatar.has-avatar-image,
.people-card-avatar.has-avatar-image,
.member-avatar.has-avatar-image,
.profile-page-avatar.has-avatar-image,
.mini-header-avatar.has-avatar-image,
.room-header-menu-btn .mini-header-avatar.has-avatar-image,
.session-page-card .people-card-avatar.has-avatar-image,
.session-page-card .member-avatar.has-avatar-image,
.session-page-card .user-avatar.has-avatar-image,
.session-page-card .dm-avatar.has-avatar-image,
.session-page-card .mini-header-avatar.has-avatar-image {
  background-color: transparent !important;
  background-position: center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  box-shadow: none !important;
  color: transparent !important;
  filter: none !important;
  opacity: 1 !important;
  mix-blend-mode: normal !important;
  text-shadow: none !important;
}

.protected-avatar.has-avatar-image::before,
.protected-avatar.has-avatar-image::after {
  content: none !important;
  display: none !important;
}

/* People Hub scroll contract: header/tabs stay fixed, active panel owns scrolling. */
.session-people-page {
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.session-people-page .people-header,
.session-people-page .people-tabs,
.session-people-page .people-status {
  flex: 0 0 auto !important;
}

.session-people-page .people-body {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  height: auto !important;
  padding: 0 12px max(16px, env(safe-area-inset-bottom)) !important;
  overflow: hidden !important;
}

.session-people-page .people-panel {
  display: none !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  overscroll-behavior-y: contain !important;
  -webkit-overflow-scrolling: touch !important;
  touch-action: pan-y !important;
}

.session-people-page .people-panel.active {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  padding: 12px 0 20px !important;
}

.session-people-page .people-list,
.session-people-page .members-list {
  overflow: visible !important;
}

.session-people-page #peoplePanelProfile.active {
  display: block !important;
  padding: 12px 0 calc(env(safe-area-inset-bottom) + 34px) !important;
}

.session-people-page #peoplePanelProfile .profile-page-card {
  display: grid !important;
  grid-template-columns: 92px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: center !important;
  text-align: left !important;
  margin: 0 0 14px !important;
  padding: 14px !important;
  border-radius: 18px !important;
}

.session-people-page #peoplePanelProfile .profile-page-avatar {
  width: 92px !important;
  height: 92px !important;
  margin: 0 !important;
  border-radius: 999px !important;
}

.session-people-page #peoplePanelProfile .profile-page-main {
  min-width: 0 !important;
}

.session-people-page #peoplePanelProfile .profile-page-name,
.session-people-page #peoplePanelProfile .profile-page-sub {
  text-align: left !important;
}

.session-people-page #peoplePanelProfile .profile-page-actions,
.session-people-page #peoplePanelProfile > .row-actions {
  justify-content: flex-start !important;
}

.session-people-page #peoplePanelProfile .form-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  padding: 12px !important;
  overflow: visible !important;
}

.session-people-page #peoplePanelProfile .field {
  min-height: auto !important;
  padding: 0 !important;
  border-bottom: 0 !important;
  background: transparent !important;
}

.session-people-page #peoplePanelProfile .field input,
.session-people-page #peoplePanelProfile .field select,
.session-people-page #peoplePanelProfile .field textarea {
  display: block !important;
  width: 100% !important;
  min-height: 44px !important;
  padding: 9px 12px !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.075) !important;
}

.session-people-page #peoplePanelProfile .field textarea {
  min-height: 118px !important;
  line-height: 1.35 !important;
  resize: vertical !important;
}

.session-people-page #peoplePanelProfile .checkbox-field {
  min-height: 48px !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 0 2px !important;
}

.session-people-page #peoplePanelProfile .checkbox-field input {
  width: auto !important;
  min-height: auto !important;
}

.session-people-page #peoplePanelProfile > .row-actions {
  margin: 14px 0 0 !important;
  padding-bottom: 8px !important;
}

@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  .session-page-card {
    width: 100vw !important;
    padding: calc(env(safe-area-inset-top) + 18px) 14px calc(env(safe-area-inset-bottom) + 22px) !important;
  }

  .session-page-card .settings-title,
  .session-page-card .people-header-title {
    font-size: 22px !important;
    margin-bottom: 12px !important;
  }

  .session-page-card .people-item,
  .session-page-card .member-row {
    grid-template-columns: 44px minmax(0, 1fr) auto !important;
    padding: 11px 10px !important;
  }

  .session-page-card .people-card-actions,
  .session-page-card .member-actions {
    grid-column: 2 / -1 !important;
    justify-content: flex-start !important;
    margin-top: 4px !important;
  }

  .session-page-card .settings-push-card {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  .session-page-card .members-toolbar {
    grid-template-columns: 1fr !important;
  }
}



/* App-feel polish pass */

.app-sync-banner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:0 0 8px;
  padding:10px 12px;
  border:1px solid color-mix(in srgb, var(--warn-border) 72%, var(--border));
  border-radius:18px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--warn-bg) 88%, var(--panel)), var(--panel));
  box-shadow:var(--shadow-soft);
}
.app-sync-btn {
  background: color-mix(in srgb, var(--panel) 30%, var(--accent));
}
.app-sync-pill {
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:28px;
  margin:0 0 6px 4px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--border-strong) 78%, transparent);
  background:color-mix(in srgb, var(--panel-soft) 84%, var(--panel));
  color:var(--text-soft);
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.app-sync-pill::before {
  content:'';
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--accent);
  box-shadow:0 0 0 6px color-mix(in srgb, var(--accent-soft) 55%, transparent);
  animation:chatangonyxPulse 1.2s ease-in-out infinite;
}
.app-sync-pill.is-alert::before {
  background:var(--danger);
  box-shadow:0 0 0 6px color-mix(in srgb, rgba(255,92,92,.22) 76%, transparent);
}
@keyframes chatangonyxPulse {
  0%, 100% { transform: scale(1); opacity: .95; }
  50% { transform: scale(.76); opacity: .5; }
}

.app-update-banner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:0 0 8px;
  padding:10px 12px;
  border:1px solid color-mix(in srgb, var(--accent-border) 70%, var(--border));
  border-radius:18px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent-soft) 92%, var(--panel)), var(--panel));
  box-shadow:var(--shadow-soft);
}
.app-update-copy { min-width:0; }
.app-update-title { font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--text-faint); }
.app-update-text { font-size:13px; line-height:1.32; color:var(--text-soft); }
.app-update-btn {
  flex:0 0 auto;
  min-height:36px;
  padding:0 14px;
  border:none;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  font-weight:800;
}
.app-tab-bar {
  position:fixed;
  left:max(10px, env(safe-area-inset-left));
  right:max(10px, env(safe-area-inset-right));
  bottom:max(10px, env(safe-area-inset-bottom));
  z-index:1200;
  display:none;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
  padding:10px;
  border:1px solid color-mix(in srgb, var(--border-strong) 78%, transparent);
  border-radius:24px;
  background:color-mix(in srgb, var(--panel) 86%, rgba(9, 11, 15, 0.75));
  backdrop-filter:blur(18px);
  box-shadow:0 18px 46px rgba(0,0,0,.22);
}
.app-tab-btn {
  position:relative;
  min-height:58px;
  border:none;
  border-radius:18px;
  background:transparent;
  color:var(--text-soft);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  font-weight:700;
}
.app-tab-btn.is-active {
  color:var(--text);
  background:color-mix(in srgb, var(--accent-soft) 88%, var(--panel));
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent-border) 70%, transparent);
}
.app-tab-icon { font-size:18px; line-height:1; }
.app-tab-label { font-size:11px; letter-spacing:.02em; }
.app-tab-badge {
  position:absolute;
  top:6px;
  right:14px;
  min-width:18px;
  height:18px;
  padding:0 5px;
  border-radius:999px;
  background:var(--danger);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
  font-weight:800;
}
textarea#messageInput,
textarea#dmInput {
  width:100%;
  min-height:44px;
  max-height:132px;
  resize:none;
  padding:12px 14px;
  line-height:1.32;
  overflow-y:hidden;
}
.session-page-modal:not(.hidden) .modal-card,
#dmModal:not(.hidden) .modal-card {
  animation:chatangonyxPageIn .22s cubic-bezier(.22,.9,.22,1);
}
@keyframes chatangonyxPageIn {
  from { opacity:0; transform:translateY(14px) scale(.985); }
  to { opacity:1; transform:translateY(0) scale(1); }
}
@media (max-width: 950px) {
  .app {
    padding-bottom:calc(96px + env(safe-area-inset-bottom));
  }
  .app-tab-bar {
    display:grid;
  }
}


/* Premium PWA polish pass */
:root {
  --premium-composer-height: 78px;
  --premium-composer-side-gap: 12px;
  --premium-composer-bottom-gap: 12px;
  --ios-composer-keyboard-shift: 0px;
}

body.is-ios-standalone {
  background:#000;
}

body.has-bottom-tabbar .app-tab-bar {
  display:grid;
}

body:not(.has-bottom-tabbar) .app-tab-bar {
  display:none !important;
}

.app-tab-bar {
  border-radius: 28px;
  gap: 6px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(24,26,31,.92), rgba(10,11,14,.88));
  box-shadow: 0 28px 70px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.06);
  -webkit-backdrop-filter: blur(24px) saturate(1.2);
  backdrop-filter: blur(24px) saturate(1.2);
}

.app-tab-btn {
  min-height: 56px;
  border-radius: 20px;
}

.app-tab-btn.is-active {
  background: linear-gradient(180deg, rgba(62,68,79,.72), rgba(29,32,38,.88));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 10px 22px rgba(0,0,0,.16);
}

.app-update-banner {
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(28,31,37,.9), rgba(13,16,20,.92));
  color: #f5f7fb;
  box-shadow: 0 24px 60px rgba(0,0,0,.24);
  -webkit-backdrop-filter: blur(20px) saturate(1.15);
  backdrop-filter: blur(20px) saturate(1.15);
}

.app-update-title,
.app-update-text {
  color: inherit;
}

@media (max-width: 950px) {
  .app {
    padding-bottom: calc(var(--premium-composer-height) + 20px + (96px * (var(--show-tabbar, 1))) + env(safe-area-inset-bottom));
  }

  body:not(.has-bottom-tabbar) .app {
    padding-bottom: calc(var(--premium-composer-height) + 18px + env(safe-area-inset-bottom));
  }

  .chat,
  .dm-chat {
    padding-bottom: calc(var(--premium-composer-height) + 28px + env(safe-area-inset-bottom)) !important;
  }

  body.has-bottom-tabbar .chat,
  body.has-bottom-tabbar .dm-chat {
    padding-bottom: calc(var(--premium-composer-height) + 106px + env(safe-area-inset-bottom)) !important;
  }

  .session-composer {
    position: fixed !important;
    left: max(var(--premium-composer-side-gap), env(safe-area-inset-left)) !important;
    right: max(var(--premium-composer-side-gap), env(safe-area-inset-right)) !important;
    bottom: calc(var(--premium-composer-bottom-gap) + env(safe-area-inset-bottom)) !important;
    width: auto !important;
    max-width: none !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    z-index: 1450 !important;
    pointer-events: none;
  }

  body.has-bottom-tabbar .session-composer {
    bottom: calc(96px + var(--premium-composer-bottom-gap) + env(safe-area-inset-bottom)) !important;
  }

  .session-composer > * {
    pointer-events: auto;
  }

  .session-composer-room,
  .session-composer-dm {
    gap: 8px !important;
  }

  .session-composer .reply-bar,
  .session-composer .typing-bar {
    margin-left: 4px !important;
    margin-right: 4px !important;
  }

  .session-composer .reply-bar {
    border-radius: 20px !important;
    border: 1px solid rgba(255,255,255,.07) !important;
    background: linear-gradient(180deg, rgba(31,34,39,.9), rgba(14,16,20,.94)) !important;
    color: #f5f7fb !important;
    box-shadow: 0 16px 40px rgba(0,0,0,.26) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.15);
    backdrop-filter: blur(18px) saturate(1.15);
  }

  .session-composer .typing-bar {
    color: rgba(255,255,255,.58) !important;
    padding: 0 10px !important;
  }

  .session-composer-row {
    min-height: 62px !important;
    padding: 4px !important;
    grid-template-columns: 50px minmax(0, 1fr) 50px !important;
    border-radius: 31px !important;
    border: 1px solid rgba(255,255,255,.075) !important;
    background: linear-gradient(180deg, rgba(31,34,40,.96), rgba(13,15,19,.96)) !important;
    box-shadow: 0 22px 60px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.06) !important;
    -webkit-backdrop-filter: blur(26px) saturate(1.18);
    backdrop-filter: blur(26px) saturate(1.18);
  }

  .session-compose-btn,
  #sendBtn.session-compose-btn,
  #sendDmBtn.session-compose-btn {
    width: 50px !important;
    min-width: 50px !important;
    height: 50px !important;
    min-height: 50px !important;
    border-radius: 25px !important;
  }

  .session-compose-plus,
  .session-compose-voice,
  #sendBtn.session-compose-send,
  #sendDmBtn.session-compose-send {
    background: rgba(255,255,255,.035) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
  }

  .session-compose-plus {
    font-size: 34px !important;
    color: rgba(255,255,255,.92) !important;
  }

  .session-compose-voice,
  #sendBtn.session-compose-send,
  #sendDmBtn.session-compose-send {
    color: #f7f9fc !important;
  }

  .session-composer-row.has-text #sendBtn.session-compose-send,
  .session-composer-row.has-text #sendDmBtn.session-compose-send {
    background: linear-gradient(180deg, rgba(68,241,146,.92), rgba(42,215,122,.94)) !important;
    color: #041109 !important;
    box-shadow: 0 10px 24px rgba(58,229,141,.28), inset 0 1px 0 rgba(255,255,255,.26) !important;
  }

  .composer-field {
    min-height: 54px !important;
    height: auto !important;
    align-items: center !important;
    padding: 0 2px !important;
  }

  .composer-field #messageInput,
  .composer-field #dmInput,
  textarea#messageInput,
  textarea#dmInput {
    min-height: 24px !important;
    height: 44px !important;
    max-height: 120px !important;
    padding: 10px 6px !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #f6f8fb !important;
    font-size: 17px !important;
    font-weight: 500 !important;
    line-height: 1.28 !important;
    letter-spacing: -.01em !important;
    overflow-y: auto !important;
  }

  .composer-field #messageInput::placeholder,
  .composer-field #dmInput::placeholder {
    color: rgba(255,255,255,.48) !important;
  }

  .session-attach-menu {
    left: 2px !important;
    bottom: calc(100% + 12px) !important;
  }

  .session-attach-item {
    background: linear-gradient(180deg, rgba(31,34,40,.96), rgba(13,15,19,.96)) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: 0 18px 36px rgba(0,0,0,.42) !important;
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
  }
}

@media (display-mode: standalone) and (max-width: 950px) {
  :root {
    --premium-composer-bottom-gap: 6px;
    --premium-composer-side-gap: 10px;
  }

  .app-tab-bar {
    bottom: max(6px, env(safe-area-inset-bottom)) !important;
  }

  .session-composer {
    bottom: max(4px, env(safe-area-inset-bottom)) !important;
  }

  body.has-bottom-tabbar .session-composer {
    bottom: calc(92px + env(safe-area-inset-bottom)) !important;
  }
}


/* Premium DM inbox and final composer polish */
.main-menu-unread-badge {
  position: absolute;
  top: -3px;
  right: -2px;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(180deg, rgba(68,241,146,.98), rgba(39,210,119,.98));
  color: #04110a;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(44,224,132,.28);
}

.dm-inbox-notice {
  position: fixed;
  left: max(10px, env(safe-area-inset-left));
  right: max(10px, env(safe-area-inset-right));
  bottom: calc(var(--premium-composer-height) + 12px + env(safe-area-inset-bottom));
  z-index: 1415;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(21,24,30,.96), rgba(9,11,15,.98));
  box-shadow: 0 20px 44px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05);
  -webkit-backdrop-filter: blur(24px) saturate(1.16);
  backdrop-filter: blur(24px) saturate(1.16);
}

.dm-inbox-open {
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  text-align: left;
}

.dm-inbox-avatar {
  width: 46px;
  height: 46px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 800;
  overflow: hidden;
}

.dm-inbox-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.dm-inbox-eyebrow {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(92,245,163,.9);
}

.dm-inbox-title {
  font-size: 16px;
  font-weight: 800;
  color: #f7f9fc;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dm-inbox-preview {
  font-size: 13px;
  line-height: 1.3;
  color: rgba(233,238,246,.72);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dm-inbox-count {
  min-width: 28px;
  height: 28px;
  padding: 0 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(68,241,146,.98), rgba(39,210,119,.98));
  color: #04110a;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 900;
  box-shadow: 0 10px 24px rgba(46,221,131,.28);
}

.dm-inbox-dismiss {
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.78);
  font-size: 24px;
  line-height: 1;
}

.dm-inbox-notice.is-pulsing {
  animation: dmInboxPulse .78s cubic-bezier(.22,.9,.28,1);
}

@keyframes dmInboxPulse {
  0% { transform: translateY(10px) scale(.985); opacity: 0; }
  40% { transform: translateY(0) scale(1.01); opacity: 1; }
  100% { transform: translateY(0) scale(1); opacity: 1; }
}

.app-tab-bar {
  display: none !important;
}

@media (max-width: 950px) {
  .app {
    padding-bottom: calc(var(--premium-composer-height) + 20px + env(safe-area-inset-bottom)) !important;
  }

  body.has-dm-inbox-notice .app {
    padding-bottom: calc(var(--premium-composer-height) + 102px + env(safe-area-inset-bottom)) !important;
  }

  .chat,
  .dm-chat {
    padding-bottom: calc(var(--premium-composer-height) + 26px + env(safe-area-inset-bottom)) !important;
  }

  body.has-dm-inbox-notice .chat,
  body.has-dm-inbox-notice .dm-chat {
    padding-bottom: calc(var(--premium-composer-height) + 108px + env(safe-area-inset-bottom)) !important;
  }

  .session-composer {
    left: max(8px, env(safe-area-inset-left)) !important;
    right: max(8px, env(safe-area-inset-right)) !important;
    bottom: max(2px, env(safe-area-inset-bottom)) !important;
  }

  body.has-bottom-tabbar .session-composer {
    bottom: max(2px, env(safe-area-inset-bottom)) !important;
  }

  .session-composer-row {
    min-height: 58px !important;
    padding: 3px 6px !important;
    grid-template-columns: 46px minmax(0, 1fr) 46px !important;
    border-radius: 28px !important;
    background: linear-gradient(180deg, rgba(17,20,26,.985), rgba(7,9,13,.992)) !important;
    border: 1px solid rgba(255,255,255,.07) !important;
    box-shadow: 0 10px 26px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.04) !important;
  }

  .session-compose-btn,
  #sendBtn.session-compose-btn,
  #sendDmBtn.session-compose-btn {
    width: 46px !important;
    min-width: 46px !important;
    height: 46px !important;
    min-height: 46px !important;
  }

  .session-compose-plus,
  .session-compose-voice,
  #sendBtn.session-compose-send,
  #sendDmBtn.session-compose-send {
    background: transparent !important;
    box-shadow: none !important;
  }

  .session-compose-plus {
    font-size: 32px !important;
    color: rgba(255,255,255,.94) !important;
  }

  .session-compose-voice,
  #sendBtn.session-compose-send,
  #sendDmBtn.session-compose-send {
    color: rgba(255,255,255,.95) !important;
  }

  .session-composer-row.has-text #sendBtn.session-compose-send,
  .session-composer-row.has-text #sendDmBtn.session-compose-send {
    background: transparent !important;
    color: rgba(77,241,151,.98) !important;
    box-shadow: none !important;
  }

  .composer-field {
    min-height: 50px !important;
    padding: 0 !important;
  }

  .composer-field #messageInput,
  .composer-field #dmInput,
  textarea#messageInput,
  textarea#dmInput {
    height: 42px !important;
    min-height: 22px !important;
    max-height: 108px !important;
    padding: 10px 8px !important;
    font-size: 16px !important;
    line-height: 1.32 !important;
  }

  .dm-inbox-notice {
    left: max(8px, env(safe-area-inset-left));
    right: max(8px, env(safe-area-inset-right));
    bottom: calc(var(--premium-composer-height) + 10px + env(safe-area-inset-bottom));
  }
}

@media (display-mode: standalone) and (max-width: 950px) {
  :root {
    --premium-composer-bottom-gap: 0px;
  }

  .session-composer {
    bottom: max(0px, env(safe-area-inset-bottom)) !important;
  }

  .dm-inbox-notice {
    bottom: calc(var(--premium-composer-height) + 8px + env(safe-area-inset-bottom));
  }
}


/* Premium composer repair pass */
@media (max-width: 950px) {
  :root {
    --premium-composer-height: 74px;
    --premium-composer-side-gap: 8px;
    --premium-composer-bottom-gap: 0px;
  }

  .app {
    padding-bottom: calc(var(--premium-composer-height) + 16px + env(safe-area-inset-bottom)) !important;
  }

  body.has-dm-inbox-notice .app {
    padding-bottom: calc(var(--premium-composer-height) + 98px + env(safe-area-inset-bottom)) !important;
  }

  .chat,
  #chat,
  .dm-chat {
    padding-bottom: calc(var(--premium-composer-height) + 22px + env(safe-area-inset-bottom)) !important;
  }

  body.has-dm-inbox-notice .chat,
  body.has-dm-inbox-notice #chat,
  body.has-dm-inbox-notice .dm-chat {
    padding-bottom: calc(var(--premium-composer-height) + 106px + env(safe-area-inset-bottom)) !important;
  }

  .session-composer {
    position: fixed !important;
    left: max(var(--premium-composer-side-gap), env(safe-area-inset-left)) !important;
    right: max(var(--premium-composer-side-gap), env(safe-area-inset-right)) !important;
    bottom: max(0px, env(safe-area-inset-bottom)) !important;
    width: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    z-index: 1500 !important;
    pointer-events: none !important;
    transform: translateY(var(--ios-composer-keyboard-shift, 0px)) !important;
    transition: transform 0.18s ease !important;
  }

  body.keyboard-open .session-composer,
  body.visual-keyboard-open .session-composer,
  body.text-input-focused .session-composer {
    bottom: max(0px, env(safe-area-inset-bottom)) !important;
  }

  body.is-ios-standalone.keyboard-open .session-composer,
  body.is-ios-standalone.visual-keyboard-open .session-composer,
  body.is-ios-standalone.text-input-focused .session-composer {
    transform: translateY(var(--ios-composer-keyboard-shift, 0px)) !important;
  }

  .session-composer > * {
    pointer-events: auto !important;
  }

  .session-composer-row {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 60px !important;
    width: 100% !important;
    padding: 5px 6px !important;
    border-radius: 30px !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    background: linear-gradient(180deg, rgba(17,20,26,.985), rgba(7,9,13,.992)) !important;
    box-shadow: 0 10px 28px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.04) !important;
    -webkit-backdrop-filter: blur(22px) saturate(1.12);
    backdrop-filter: blur(22px) saturate(1.12);
  }

  .session-compose-btn,
  #sendBtn.session-compose-btn,
  #sendDmBtn.session-compose-btn {
    flex: 0 0 46px !important;
    width: 46px !important;
    min-width: 46px !important;
    height: 46px !important;
    min-height: 46px !important;
    border-radius: 23px !important;
  }

  .composer-field {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    min-height: 48px !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 2px !important;
  }

  .composer-field #messageInput,
  .composer-field #dmInput,
  textarea#messageInput,
  textarea#dmInput {
    display: block !important;
    flex: 1 1 auto !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 22px !important;
    height: 42px !important;
    max-height: 108px !important;
    margin: 0 !important;
    padding: 0 6px !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
    color: #f6f8fb !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    line-height: 42px !important;
    letter-spacing: -.01em !important;
    overflow-y: auto !important;
  }

  .composer-field #messageInput::placeholder,
  .composer-field #dmInput::placeholder {
    color: rgba(255,255,255,.48) !important;
  }

  .dm-inbox-notice {
    left: max(8px, env(safe-area-inset-left));
    right: max(8px, env(safe-area-inset-right));
    bottom: calc(var(--premium-composer-height) + 10px + env(safe-area-inset-bottom));
  }

  body.keyboard-open .dm-inbox-notice,
  body.visual-keyboard-open .dm-inbox-notice,
  body.text-input-focused .dm-inbox-notice {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(10px) !important;
  }
}

@media (display-mode: standalone) and (max-width: 950px) {
  .session-composer {
    bottom: max(0px, env(safe-area-inset-bottom)) !important;
  }
}


/* Composer ghost bar cleanup */
@media (max-width: 950px) {
  .session-composer-room,
  .session-composer-dm {
    gap: 0 !important;
  }

  .session-composer .typing-bar:empty,
  .session-composer .typing-bar.hidden {
    display: none !important;
  }

  .session-composer .reply-bar.hidden {
    display: none !important;
  }

  .session-composer .reply-bar:not(.hidden),
  .session-composer .typing-bar:not(:empty):not(.hidden) {
    margin-left: 4px !important;
    margin-right: 4px !important;
    margin-bottom: 8px !important;
  }
}

/* Premium polish v7 */
.message-avatar-spacer {
  opacity: 0 !important;
  pointer-events: none !important;
}

.message.is-grouped {
  padding-top: 4px !important;
}

.message.is-grouped .message-body {
  margin-top: -4px !important;
}

.message.is-grouped .message-bubble {
  margin-top: 0 !important;
}

.dm-message.is-grouped {
  margin-top: 2px !important;
}

.dm-message.is-grouped .dm-bubble-wrap {
  margin-top: -2px !important;
}

.dm-message.is-grouped .dm-bubble {
  margin-top: 0 !important;
}

.message.is-grouped .meta,
.dm-message.is-grouped .dm-msg-meta {
  letter-spacing: .01em;
  display: none !important;
}

.message.is-grouped .message-avatar-spacer,
.dm-message.is-grouped .message-avatar-spacer {
  visibility: hidden !important;
}

@media (max-width: 820px) {
  .people-header {
    min-height: calc(env(safe-area-inset-top) + 70px) !important;
    padding: calc(env(safe-area-inset-top) + 18px) 58px 10px !important;
  }

  .people-close-btn {
    top: calc(env(safe-area-inset-top) + 18px) !important;
  }

  .people-tabs {
    padding-top: 4px !important;
  }
}

/* Stability pass v10: reduce viewport jumpiness while typing and keep scrollers anchored. */
.chat,
.dm-chat {
  overflow-anchor: auto !important;
}

.message,
.dm-message,
.session-composer,
.reply-bar,
.typing-bar {
  overflow-anchor: none !important;
}

body.keyboard-open .chat,
body.keyboard-open .dm-chat,
body.visual-keyboard-open .chat,
body.visual-keyboard-open .dm-chat,
body.text-input-focused .chat,
body.text-input-focused .dm-chat {
  scroll-padding-bottom: calc(var(--premium-composer-height, 74px) + 20px + env(safe-area-inset-bottom)) !important;
}


/* v12 from v11: stability hotfix for composer shadow + keyboard jump */
@media (max-width: 950px) {
  .app {
    padding-bottom: calc(var(--premium-composer-height) + 8px + env(safe-area-inset-bottom)) !important;
  }

  .chat,
  #chat,
  .dm-chat {
    padding-bottom: 8px !important;
    scroll-padding-bottom: calc(var(--premium-composer-height) + 10px + env(safe-area-inset-bottom)) !important;
  }

  .session-composer {
    bottom: max(0px, env(safe-area-inset-bottom)) !important;
    transform: none !important;
    transition: none !important;
  }

  .session-composer-room,
  .session-composer-dm {
    gap: 0 !important;
  }

  .session-composer .reply-bar.hidden,
  .session-composer .typing-bar.hidden,
  .session-composer .typing-bar:empty {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
    height: 0 !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  .session-composer-row {
    box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
    filter: none !important;
  }

  body.keyboard-open .chat,
  body.keyboard-open #chat,
  body.keyboard-open .dm-chat,
  body.visual-keyboard-open .chat,
  body.visual-keyboard-open #chat,
  body.visual-keyboard-open .dm-chat,
  body.text-input-focused .chat,
  body.text-input-focused #chat,
  body.text-input-focused .dm-chat {
    padding-bottom: 4px !important;
    scroll-padding-bottom: calc(var(--premium-composer-height) + 6px + env(safe-area-inset-bottom)) !important;
  }
}

@media (display-mode: standalone) and (max-width: 950px) {
  .session-composer {
    bottom: max(0px, env(safe-area-inset-bottom)) !important;
    transform: none !important;
  }
}


/* v13 standalone stability dock pass */
@media (display-mode: standalone) and (max-width: 950px) {
  html,
  body {
    height: 100%;
    min-height: 100%;
    overflow: hidden !important;
  }

  body {
    position: fixed;
    inset: 0;
    width: 100%;
    overscroll-behavior: none;
    touch-action: manipulation;
  }

  .app {
    height: var(--app-height, 100dvh) !important;
    min-height: var(--app-height, 100dvh) !important;
    max-height: var(--app-height, 100dvh) !important;
    overflow: hidden !important;
    padding: calc(env(safe-area-inset-top) + 8px) 8px calc(var(--premium-composer-height) + 2px) 8px !important;
  }

  .main-layout,
  .chat-column {
    min-height: 0 !important;
    height: 100% !important;
    overflow: hidden !important;
  }

  .chat,
  #chat,
  .dm-chat {
    min-height: 0 !important;
    height: 100% !important;
    padding-bottom: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch;
    scroll-padding-bottom: calc(var(--premium-composer-height) + 2px) !important;
  }

  body.keyboard-open .chat,
  body.keyboard-open #chat,
  body.keyboard-open .dm-chat,
  body.visual-keyboard-open .chat,
  body.visual-keyboard-open #chat,
  body.visual-keyboard-open .dm-chat,
  body.text-input-focused .chat,
  body.text-input-focused #chat,
  body.text-input-focused .dm-chat {
    padding-bottom: 0 !important;
    scroll-padding-bottom: calc(var(--premium-composer-height) + 2px) !important;
  }

  .session-composer {
    bottom: -1px !important;
    left: max(8px, env(safe-area-inset-left)) !important;
    right: max(8px, env(safe-area-inset-right)) !important;
  }

  body.keyboard-open .session-composer,
  body.visual-keyboard-open .session-composer,
  body.text-input-focused .session-composer {
    bottom: -5px !important;
  }

  .session-composer-row {
    margin: 0 !important;
  }
}


/* v14 final standalone composer + scroller stabilization */
.chat,
#chat,
.dm-chat {
  overflow-anchor: none !important;
}

@media (display-mode: standalone) and (max-width: 950px) {
  html,
  body {
    height: 100% !important;
    min-height: 100% !important;
    overflow: hidden !important;
  }

  body {
    position: fixed !important;
    inset: 0 !important;
    width: 100% !important;
    overscroll-behavior: none !important;
    touch-action: manipulation !important;
  }

  .app {
    height: var(--app-height, 100dvh) !important;
    min-height: var(--app-height, 100dvh) !important;
    max-height: var(--app-height, 100dvh) !important;
    overflow: hidden !important;
    padding: calc(env(safe-area-inset-top) + 8px) 8px 0 8px !important;
  }

  .main-layout,
  .chat-column {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    height: 100% !important;
    overflow: hidden !important;
  }

  .chat,
  #chat,
  .dm-chat {
    flex: 1 1 auto !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    margin-bottom: 0 !important;
    padding-bottom: 8px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    scroll-padding-bottom: 12px !important;
  }

  body.keyboard-open .chat,
  body.keyboard-open #chat,
  body.keyboard-open .dm-chat,
  body.visual-keyboard-open .chat,
  body.visual-keyboard-open #chat,
  body.visual-keyboard-open .dm-chat,
  body.text-input-focused .chat,
  body.text-input-focused #chat,
  body.text-input-focused .dm-chat {
    padding-bottom: 8px !important;
    scroll-padding-bottom: 12px !important;
  }

  .session-composer {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: auto !important;
    margin: 8px 0 0 0 !important;
    padding: 0 0 max(0px, env(safe-area-inset-bottom)) 0 !important;
    transform: none !important;
    transition: none !important;
    z-index: 20 !important;
    pointer-events: auto !important;
  }

  .session-composer > * {
    pointer-events: auto !important;
  }

  .session-composer-room,
  .session-composer-dm {
    gap: 0 !important;
  }

  .session-composer-row {
    margin: 0 !important;
  }

  .dm-inbox-notice {
    bottom: calc(var(--premium-composer-height) + 8px + env(safe-area-inset-bottom)) !important;
  }
}

/* v15 nuclear standalone reset: simpler sticky composer, chat-only scrolling, less viewport fighting */
@media (display-mode: standalone) and (max-width: 950px) {
  :root {
    --premium-composer-height: 72px;
  }

  html,
  body {
    height: 100%;
    min-height: 100%;
    overflow: hidden !important;
  }

  body {
    position: static !important;
    inset: auto !important;
    width: auto !important;
  }

  .app {
    height: var(--app-height, 100dvh) !important;
    min-height: var(--app-height, 100dvh) !important;
    max-height: var(--app-height, 100dvh) !important;
    overflow: hidden !important;
    padding: max(0px, env(safe-area-inset-top)) 8px max(2px, env(safe-area-inset-bottom)) 8px !important;
  }

  .top-bar,
  body.theme-dark .top-bar {
    padding: 0 0 8px !important;
    margin: 0 !important;
  }

  .main-layout,
  .chat-column {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    height: 100% !important;
    overflow: hidden !important;
    gap: 0 !important;
  }

  .chat,
  #chat,
  .dm-chat {
    flex: 1 1 auto !important;
    height: auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-bottom: 6px !important;
    margin-bottom: 0 !important;
    scroll-padding-bottom: 8px !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain !important;
  }

  body.keyboard-open .chat,
  body.keyboard-open #chat,
  body.keyboard-open .dm-chat,
  body.visual-keyboard-open .chat,
  body.visual-keyboard-open #chat,
  body.visual-keyboard-open .dm-chat,
  body.text-input-focused .chat,
  body.text-input-focused #chat,
  body.text-input-focused .dm-chat {
    padding-bottom: 2px !important;
    scroll-padding-bottom: 6px !important;
  }

  .session-composer {
    position: sticky !important;
    left: auto !important;
    right: auto !important;
    bottom: 0 !important;
    width: 100% !important;
    margin: auto 0 0 0 !important;
    padding: 6px 0 max(2px, env(safe-area-inset-bottom)) 0 !important;
    background: #000 !important;
    box-shadow: none !important;
    z-index: 12 !important;
    transform: none !important;
  }

  body.keyboard-open .session-composer,
  body.visual-keyboard-open .session-composer,
  body.text-input-focused .session-composer {
    bottom: 0 !important;
    padding-bottom: 0 !important;
    transform: none !important;
  }

  .session-composer-room,
  .session-composer-dm {
    gap: 0 !important;
  }

  .session-composer .reply-bar.hidden,
  .session-composer .typing-bar.hidden,
  .session-composer .typing-bar:empty {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
    height: 0 !important;
  }

  .session-composer .reply-bar:not(.hidden),
  .session-composer .typing-bar:not(:empty):not(.hidden) {
    margin: 0 0 6px 0 !important;
  }

  .session-composer-row {
    margin: 0 !important;
  }

  .dm-inbox-notice {
    bottom: calc(var(--premium-composer-height) + 6px + env(safe-area-inset-bottom)) !important;
  }
}


/* v16 standalone hotfix: fixed composer dock + no typing bar + higher header */
@media (max-width: 950px) {
  body.is-ios-standalone {
    overflow: hidden !important;
  }

  body.is-ios-standalone .app {
    height: var(--app-height, 100dvh) !important;
    min-height: var(--app-height, 100dvh) !important;
    max-height: var(--app-height, 100dvh) !important;
    padding: max(0px, env(safe-area-inset-top)) 8px 0 8px !important;
    overflow: hidden !important;
  }

  body.is-ios-standalone .top-bar,
  body.is-ios-standalone.theme-dark .top-bar,
  body.is-ios-standalone.theme-light .top-bar {
    padding: 0 0 6px !important;
    margin: 0 !important;
  }

  body.is-ios-standalone .main-layout,
  body.is-ios-standalone .chat-column {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    height: 100% !important;
    overflow: hidden !important;
    gap: 0 !important;
  }

  body.is-ios-standalone .chat,
  body.is-ios-standalone #chat,
  body.is-ios-standalone .dm-chat {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-bottom: calc(var(--premium-composer-height, 72px) + 10px + env(safe-area-inset-bottom)) !important;
    margin-bottom: 0 !important;
    scroll-padding-bottom: calc(var(--premium-composer-height, 72px) + 10px) !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch;
  }

  body.is-ios-standalone .session-composer {
    position: fixed !important;
    left: max(8px, env(safe-area-inset-left)) !important;
    right: max(8px, env(safe-area-inset-right)) !important;
    bottom: calc(env(safe-area-inset-bottom) + var(--standalone-keyboard-lift, 0px)) !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 0 2px 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
    z-index: 60 !important;
  }

  body.is-ios-standalone.keyboard-open .session-composer,
  body.is-ios-standalone.visual-keyboard-open .session-composer,
  body.is-ios-standalone.text-input-focused .session-composer {
    bottom: calc(var(--standalone-keyboard-lift, 0px)) !important;
    padding-bottom: 0 !important;
  }

  body.is-ios-standalone .session-composer .typing-bar,
  body.is-ios-standalone .session-composer .typing-bar.hidden,
  body.is-ios-standalone .session-composer .typing-bar:empty {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body.is-ios-standalone .session-composer .reply-bar.hidden {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body.is-ios-standalone .dm-inbox-notice {
    bottom: calc(var(--premium-composer-height, 72px) + 10px + env(safe-area-inset-bottom) + var(--standalone-keyboard-lift, 0px)) !important;
  }
}


/* v17 iOS standalone header/composer spacing hotfix */
@media (max-width: 950px) {
  body.is-ios-standalone .app {
    padding-top: 0 !important;
  }

  body.is-ios-standalone .top-bar.session-room-header {
    min-height: calc(env(safe-area-inset-top) + 56px) !important;
    padding: calc(env(safe-area-inset-top) + 2px) 58px 4px !important;
    margin: 0 !important;
    align-items: center !important;
  }

  body.is-ios-standalone .hamburger-menu-btn,
  body.is-ios-standalone .room-header-menu-btn {
    align-self: center !important;
  }

  body.is-ios-standalone .room-title-stack {
    gap: 0 !important;
  }

  body.is-ios-standalone .room-title {
    line-height: 1.02 !important;
    margin: 0 !important;
  }

  body.is-ios-standalone .main-layout,
  body.is-ios-standalone .chat-column {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }

  body.is-ios-standalone .chat,
  body.is-ios-standalone #chat,
  body.is-ios-standalone .dm-chat {
    padding-top: 0 !important;
  }

  body.is-ios-standalone .session-composer {
    bottom: max(0px, env(safe-area-inset-bottom)) !important;
  }

  body.is-ios-standalone.keyboard-open .session-composer,
  body.is-ios-standalone.visual-keyboard-open .session-composer,
  body.is-ios-standalone.text-input-focused .session-composer {
    bottom: var(--standalone-keyboard-lift, 0px) !important;
  }
}

/* v18 messages inbox */
.session-messages-page {
  padding-bottom: 18px;
}

.messages-inbox-toolbar {
  padding: 4px 24px 8px;
}

.messages-inbox-toolbar input {
  width: 100%;
  min-height: 50px;
  padding: 0 18px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--border) 88%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-soft) 92%, var(--panel)), color-mix(in srgb, var(--panel) 96%, transparent));
  color: var(--text);
  outline: none;
}

.messages-inbox-toolbar input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-soft) 56%, transparent);
}

.messages-inbox-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 24px 12px;
  color: var(--text-soft);
  font-size: 13px;
}

#messagesSummaryTitle {
  font-weight: 800;
  color: var(--text);
}

.messages-list {
  padding-top: 0;
}

.messages-inbox-row {
  display: flex;
  width: 100%;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.messages-inbox-row:hover,
.messages-inbox-row:focus-visible {
  background: color-mix(in srgb, var(--panel-soft) 80%, transparent);
  outline: none;
}

.messages-inbox-row.is-unread {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-soft) 34%, transparent), transparent 78%);
}

.messages-inbox-avatar {
  width: 56px;
  height: 56px;
  flex: 0 0 56px;
  border-radius: 18px;
}

.messages-inbox-main {
  min-width: 0;
  flex: 1 1 auto;
}

.messages-inbox-head,
.messages-inbox-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.messages-inbox-head {
  margin-bottom: 6px;
}

.messages-inbox-name {
  min-width: 0;
  font-size: 22px;
  font-weight: 800;
  line-height: 1.05;
}

.messages-inbox-meta {
  flex: 0 0 auto;
  color: var(--text-faint);
  font-size: 13px;
  white-space: nowrap;
}

.messages-inbox-preview {
  color: var(--text-soft);
  font-size: 15px;
  line-height: 1.34;
  word-break: break-word;
}

.messages-inbox-foot {
  margin-top: 10px;
}

.messages-inbox-presence {
  color: var(--text-faint);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.messages-inbox-unread-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  min-height: 28px;
  padding: 0 9px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 84%, #0f1f38);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  box-shadow: 0 8px 18px color-mix(in srgb, var(--accent) 26%, transparent);
}

.messages-inbox-actions {
  display: flex;
  gap: 10px;
  margin-top: 14px;
}

.messages-inbox-actions .small-action-btn {
  min-height: 38px;
  padding: 0 14px;
}

.dm-unread-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px 8px;
}

.dm-unread-line {
  height: 1px;
  flex: 1 1 auto;
  background: color-mix(in srgb, var(--border) 78%, transparent);
}

.dm-unread-text {
  flex: 0 0 auto;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

@media (max-width: 700px) {
  .messages-inbox-toolbar,
  .messages-inbox-summary {
    padding-left: 18px;
    padding-right: 18px;
  }

  .messages-inbox-summary {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }

  .messages-inbox-row {
    padding: 16px 18px;
  }

  .messages-inbox-name {
    font-size: 18px;
  }

  .messages-inbox-meta {
    font-size: 12px;
  }

  .messages-inbox-actions {
    flex-wrap: wrap;
  }
}

.people-hub-toolbar {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0 24px 8px;
}

.people-hub-toolbar.hidden,
.people-hub-summary.hidden {
  display: none;
}

.people-hub-search {
  width: 100%;
  min-height: 50px;
  padding: 0 18px;
  border-radius: 22px;
  border: 1px solid var(--border-strong);
  background: linear-gradient(180deg, rgba(18, 24, 34, 0.96), rgba(8, 10, 16, 0.98));
  color: var(--text);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.03);
}

.people-hub-filters {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.people-hub-filters::-webkit-scrollbar { display: none; }

.people-filter-chip {
  flex: 0 0 auto;
  min-height: 38px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(20, 24, 32, 0.82);
  color: var(--text-soft);
  font-weight: 800;
  letter-spacing: 0.01em;
}

.people-filter-chip.active {
  color: #050608;
  background: linear-gradient(180deg, rgba(101,255,211,0.96), rgba(64,245,201,0.88));
  border-color: rgba(101,255,211,0.6);
  box-shadow: 0 10px 24px rgba(52, 221, 167, 0.22);
}

.people-hub-summary {
  padding: 0 24px 10px;
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.35;
}

.session-people-page .people-item {
  position: relative;
}

.session-people-page .people-item-unread::after {
  content: '';
  position: absolute;
  left: 12px;
  top: 14px;
  bottom: 14px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(89,255,198,0.95), rgba(77,226,174,0.75));
}

.session-people-page .people-card-preview {
  line-height: 1.35;
}

@media (max-width: 520px) {
  .people-hub-toolbar,
  .people-hub-summary {
    padding-left: 24px;
    padding-right: 24px;
  }
}


/* v20 DM composer stability hotfix */
@media (max-width: 950px) {
  body.is-ios-standalone #dmModal .session-composer-dm {
    position: fixed !important;
    left: max(8px, env(safe-area-inset-left)) !important;
    right: max(8px, env(safe-area-inset-right)) !important;
    bottom: calc(max(0px, env(safe-area-inset-bottom)) + var(--standalone-keyboard-lift, 0px)) !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    z-index: 80 !important;
    transform: none !important;
  }

  body.is-ios-standalone #dmModal .session-composer-dm .session-composer-row {
    margin: 0 !important;
  }

  body.is-ios-standalone #dmModal .dm-chat {
    padding-bottom: calc(var(--premium-composer-height, 72px) + 18px + env(safe-area-inset-bottom) + var(--standalone-keyboard-lift, 0px)) !important;
    scroll-padding-bottom: calc(var(--premium-composer-height, 72px) + 18px + env(safe-area-inset-bottom) + var(--standalone-keyboard-lift, 0px)) !important;
  }

  body.is-ios-standalone #dmModal .session-composer-dm .typing-bar,
  body.is-ios-standalone #dmModal .session-composer-dm .typing-bar.hidden,
  body.is-ios-standalone #dmModal .session-composer-dm .typing-bar:empty,
  body.is-ios-standalone #dmModal .session-composer-dm .reply-bar.hidden {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
  }
}


/* v21 optimistic send + retry states */
.bubble-send-state {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}

.bubble-send-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.18);
  color: rgba(255,255,255,0.9);
}

.bubble-send-badge.is-sending {
  background: rgba(79, 141, 255, 0.18);
  border-color: rgba(116, 167, 255, 0.34);
  color: #dbe8ff;
}

.bubble-send-badge.is-failed {
  background: rgba(255, 94, 114, 0.18);
  border-color: rgba(255, 122, 139, 0.36);
  color: #ffd5dc;
}

.bubble-send-badge.is-sent {
  background: rgba(58, 227, 143, 0.16);
  border-color: rgba(58, 227, 143, 0.28);
  color: #dcffee;
}

.bubble-send-retry {
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.08);
  color: inherit;
  border-radius: 999px;
  min-height: 24px;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.bubble-send-retry:hover {
  background: rgba(255,255,255,0.14);
}

.message.send-state-sending .message-bubble,
.dm-message.send-state-sending .dm-bubble {
  box-shadow: 0 0 0 1px rgba(116, 167, 255, 0.16), 0 14px 28px rgba(18, 24, 36, 0.18);
}

.message.send-state-failed .message-bubble,
.dm-message.send-state-failed .dm-bubble {
  box-shadow: 0 0 0 1px rgba(255, 122, 139, 0.22), 0 14px 28px rgba(18, 24, 36, 0.18);
}

#sendBtn.session-compose-send.is-busy,
#sendDmBtn.session-compose-send.is-busy {
  opacity: 0.96;
  transform: scale(1.03);
}

/* v21 room controls cleanup */
.room-controls-clean {
  gap: 18px;
}

.room-controls-shell {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.room-controls-section {
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(17,20,27,0.96), rgba(10,12,18,0.96));
  overflow: hidden;
  box-shadow: 0 18px 44px rgba(0,0,0,0.28);
}

.room-controls-section-toggle {
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 12px;
  align-items: center;
  padding: 18px 20px 16px;
  text-align: left;
  cursor: pointer;
}

.room-controls-section-title {
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.94);
}

.room-controls-section-meta {
  font-size: 13px;
  color: rgba(255,255,255,0.56);
  grid-column: 1 / 2;
}

.room-controls-chevron {
  font-size: 28px;
  line-height: 1;
  color: rgba(255,255,255,0.55);
  transform: rotate(-90deg);
  transition: transform .18s ease, color .18s ease;
}

.room-controls-section.is-open .room-controls-chevron {
  transform: rotate(0deg);
  color: rgba(255,255,255,0.84);
}

.room-controls-section-body {
  padding: 0 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.room-controls-soft-panel {
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.02);
  box-shadow: none;
}

.room-controls-duo-grid,
.room-controls-admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.room-controls-block-stack {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.room-controls-chip-row {
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}

.room-controls-chip {
  min-height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 13px;
}

.room-controls-admin-menu,
.room-controls-danger-menu {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.room-controls-admin-row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
}

.room-controls-admin-row span {
  font-size: 17px;
  font-weight: 800;
  color: #fff;
}

.room-controls-admin-row small {
  font-size: 12px;
  color: rgba(255,255,255,0.58);
}

.room-controls-admin-row.danger {
  background: rgba(255, 63, 93, 0.08);
  border-color: rgba(255, 93, 93, 0.24);
}

.room-controls-danger-confirm {
  margin-top: 10px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255, 93, 93, 0.3);
  background: rgba(255, 63, 93, 0.08);
}

.room-controls-danger-text {
  font-size: 14px;
  color: rgba(255,255,255,0.92);
  margin-bottom: 10px;
}

.room-controls-danger-actions {
  justify-content: flex-start;
}

.room-controls-danger-actions .modal-btn.danger {
  background: #ff4b72;
  border-color: #ff6a87;
  color: #fff;
}

.room-controls-compact-grid .field,
.room-controls-compact-field {
  min-width: 0;
}

.room-controls-overview {
  padding: 20px 20px 18px !important;
  border-radius: 24px !important;
}

.room-overview-title {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.04em;
  margin-bottom: 16px;
}

.room-overview-label {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.44);
  margin-bottom: 10px;
}

.room-overview-description {
  font-size: 17px;
  line-height: 1.45;
  color: rgba(255,255,255,0.92);
  margin-bottom: 18px;
}

.room-overview-meta,
.room-overview-status {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 14px;
  background: rgba(255,255,255,0.04);
  font-size: 14px;
  color: rgba(255,255,255,0.72);
}

.room-overview-status {
  margin-top: 8px;
}

#roomControlsModal .people-section-title {
  margin-bottom: 12px;
}

#roomControlsModal .mini-status {
  margin-top: 8px;
  margin-bottom: 0;
}

#roomControlsModal .field {
  padding: 16px 16px 14px;
}

#roomControlsModal .room-controls-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 780px) {
  .room-controls-duo-grid,
  .room-controls-admin-grid,
  #roomControlsModal .room-controls-columns {
    grid-template-columns: 1fr;
  }

  .room-controls-section-toggle {
    padding: 16px 16px 14px;
  }

  .room-controls-section-body {
    padding: 0 14px 14px;
  }

  .room-controls-admin-row span {
    font-size: 16px;
  }
}

/* V22 Style & Privacy split */
.settings-section-card {
  margin: 16px 0 0;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 92%, var(--panel-soft)), color-mix(in srgb, var(--panel) 82%, var(--panel-soft)));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.settings-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.settings-section-kicker {
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--text-soft);
  margin-bottom: 6px;
}

.settings-section-title {
  margin: 0;
  font-size: 20px;
  line-height: 1.15;
  font-weight: 800;
  color: var(--text);
}

.settings-section-meta {
  flex: 0 0 auto;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--border));
  background: color-mix(in srgb, var(--accent-soft) 70%, var(--panel));
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.settings-section-card .form-grid {
  margin-top: 0;
}

.settings-section-card .mini-status:last-child {
  margin-bottom: 0;
}

.settings-contrast-hint {
  margin: 12px 0 0;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
  background: color-mix(in srgb, var(--panel-soft) 78%, var(--panel));
}

.settings-notify-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-soft) 74%, var(--panel));
}

.settings-notify-copy {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.settings-notify-copy strong {
  font-size: 15px;
}

.settings-notify-copy span {
  font-size: 13px;
  color: var(--text-soft);
  line-height: 1.35;
}

.settings-save-row {
  margin-top: 18px;
  justify-content: space-between;
}

.app-toast {
  position: fixed;
  left: 50%;
  bottom: calc(env(safe-area-inset-bottom) + 18px);
  transform: translateX(-50%);
  z-index: 2400;
  min-width: min(86vw, 320px);
  max-width: min(90vw, 360px);
  padding: 14px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(11,13,16,.94);
  color: #fff;
  box-shadow: 0 18px 40px rgba(0,0,0,.38);
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.app-toast.hidden {
  display: none !important;
}

.app-toast-success {
  border-color: rgba(58,227,143,.26);
}

.app-toast-error {
  border-color: rgba(255,79,99,.26);
}

@media (max-width: 520px), (hover: none) and (pointer: coarse) and (max-width: 950px) {
  .settings-section-card {
    margin-top: 14px;
    padding: 16px;
    border-radius: 20px;
    background: #141517;
  }

  .settings-section-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .settings-section-meta {
    white-space: normal;
  }

  .settings-quick-controls {
    grid-template-columns: 1fr;
    margin-bottom: 0;
  }

  .settings-toggle-row {
    min-height: 64px;
  }

  .settings-notify-row {
    flex-direction: column;
    align-items: stretch;
  }

  .settings-save-row {
    position: static;
    bottom: auto;
    padding-top: 16px;
    background: transparent;
  }

  .settings-save-row .modal-btn {
    width: 100%;
  }
}

/* v23 notifications center + badge system */
.main-menu-item.has-side-badge {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.main-menu-item-badge {
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-border) 72%, var(--border));
  background: color-mix(in srgb, var(--accent-soft) 78%, var(--panel));
  color: var(--accent-strong);
  font-size: 12px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

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

.notifications-summary-card,
.notifications-settings-card,
.notifications-center-card {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-raised) 92%, var(--panel-soft)), var(--panel));
  box-shadow: var(--shadow-soft);
}

.notifications-summary-card {
  padding: 14px 16px;
}

.notifications-summary-label {
  color: var(--text-soft);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 800;
}

.notifications-summary-value {
  margin-top: 8px;
  font-size: 34px;
  font-weight: 900;
  line-height: 1;
}

.notifications-summary-meta {
  margin-top: 8px;
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.3;
}

.notifications-settings-card,
.notifications-center-card {
  padding: 16px;
  margin-top: 14px;
}

.notifications-settings-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.notifications-settings-head.compact {
  margin-bottom: 10px;
}

.notifications-inline-status {
  min-height: 18px;
  text-align: right;
  max-width: 180px;
}

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

.notifications-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 76px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel-soft) 80%, var(--panel));
}

.notifications-toggle-row strong,
.notifications-time-field span,
.notifications-muted-title,
.notification-center-section-head {
  display: block;
  font-weight: 800;
}

.notifications-toggle-row span {
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.3;
}

.notifications-toggle-row input[type='checkbox'] {
  width: 22px;
  height: 22px;
  accent-color: var(--accent);
  flex: 0 0 auto;
}

.notifications-time-field {
  padding: 0;
}

.notifications-time-field input {
  width: 100%;
}

.notifications-settings-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}

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

.notifications-muted-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.notifications-muted-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--panel-soft) 82%, var(--panel));
  border: 1px solid var(--border);
}

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

.notification-center-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.notification-center-section-head {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-soft);
}

.notification-center-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-soft) 78%, var(--panel));
}

.notification-center-row.is-unread {
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--accent) 82%, transparent);
}

.notification-center-main {
  flex: 1;
  min-width: 0;
}

.notification-center-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.notification-center-title {
  font-weight: 800;
  font-size: 16px;
  line-height: 1.15;
}

.notification-center-meta {
  color: var(--text-faint);
  font-size: 12px;
  white-space: nowrap;
}

.notification-center-preview {
  margin-top: 6px;
  color: var(--text-soft);
  font-size: 14px;
  line-height: 1.35;
  word-break: break-word;
}

.notification-center-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.notification-center-row.is-dm .messages-inbox-avatar {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent-border) 62%, transparent);
}

.notification-center-row.is-mention {
  background: color-mix(in srgb, var(--accent-soft) 38%, var(--panel));
}

@media (max-width: 720px) {
  .notifications-summary-grid,
  .notifications-settings-grid,
  .notifications-muted-columns {
    grid-template-columns: 1fr;
  }

  .notifications-settings-head {
    flex-direction: column;
    align-items: stretch;
  }

  .notifications-inline-status {
    max-width: none;
    text-align: left;
  }
}


/* v24 reliability fix3: stop floating save row and calmer sync surfaces */
.settings-save-row {
  position: static !important;
  inset: auto !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  z-index: auto !important;
  background: transparent !important;
  box-shadow: none !important;
  padding-bottom: max(8px, env(safe-area-inset-bottom)) !important;
}

.settings-save-row .modal-btn {
  position: static !important;
  width: 100% !important;
}

.app-sync-banner.hidden,
.app-sync-pill.hidden {
  display: none !important;
}


/* v26 premium people hub + profile banner refresh */
.session-people-page .people-tab[data-tab="blocked"],
.session-people-page .people-tab.people-tab-aux {
  display: none !important;
}

.session-people-page .people-header {
  padding-bottom: 10px !important;
}

.session-people-page .people-tabs {
  position: sticky;
  top: 0;
  z-index: 4;
  display: flex !important;
  gap: 10px !important;
  padding: 0 0 8px !important;
  background: transparent !important;
  border: 0 !important;
  overflow-x: auto !important;
}

.session-people-page .people-tabs::-webkit-scrollbar {
  display: none;
}

.session-people-page .people-tab {
  flex: 0 0 auto !important;
  min-height: 42px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  background: rgba(22, 25, 34, .92) !important;
  color: rgba(255,255,255,.72) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: -.01em !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.session-people-page .people-tab.active {
  color: #03130b !important;
  border-color: rgba(102,255,212,.66) !important;
  background: linear-gradient(180deg, rgba(111,255,216,.98), rgba(67,241,188,.90)) !important;
  box-shadow: 0 12px 26px rgba(67, 241, 188, .18) !important;
}

.session-people-page .people-hub-toolbar {
  padding: 4px 0 10px !important;
}

.session-people-page .people-hub-search {
  min-height: 54px !important;
  border-radius: 24px !important;
  border: 1px solid rgba(108, 127, 170, .26) !important;
  background: linear-gradient(180deg, rgba(10,15,25,.98), rgba(7,10,18,.98)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 10px 28px rgba(0,0,0,.18) !important;
}

.session-people-page .people-hub-summary {
  padding: 0 2px 12px !important;
  color: rgba(255,255,255,.66) !important;
}

.session-people-page .people-list,
.session-people-page .members-list {
  gap: 12px !important;
  overflow: visible !important;
}

.session-people-page .people-item,
.session-people-page .member-row,
.session-page-card .session-people-page .people-item,
.session-page-card .session-people-page .member-row {
  position: relative !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: 52px minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: start !important;
  padding: 14px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 22px !important;
  background: linear-gradient(180deg, rgba(18,20,26,.96), rgba(11,13,18,.98)) !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.22) !important;
}

.session-people-page .people-item + .people-item,
.session-people-page .member-row + .member-row {
  border-top: 0 !important;
}

.session-people-page .people-item.has-profile-bg::before,
.session-people-page .member-row.has-profile-bg::before,
.session-people-page #peoplePanelProfile .profile-page-card.has-profile-bg::before,
#profileModal .profile-card.has-profile-bg::before,
.messages-inbox-row.has-profile-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(180deg, rgba(7,10,14,.20), rgba(7,10,14,.84) 46%, rgba(7,10,14,.96)),
    radial-gradient(circle at top right, rgba(112,255,220,.18), transparent 32%),
    var(--profile-bg-image);
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}

.session-people-page .people-item > *,
.session-people-page .member-row > *,
.session-people-page #peoplePanelProfile .profile-page-card > *,
#profileModal .profile-card > *,
.messages-inbox-row > * {
  position: relative;
  z-index: 1;
}

.session-people-page .people-card-avatar,
.session-people-page .member-avatar {
  width: 52px !important;
  height: 52px !important;
  min-width: 52px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  background: rgba(255,255,255,.08) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.24) !important;
}

.session-people-page .people-card-main,
.session-people-page .member-main {
  min-width: 0 !important;
}

.session-people-page .people-card-name,
.session-people-page .member-name,
.session-people-page .member-topline {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: initial !important;
  font-size: 20px !important;
  line-height: 1.08 !important;
  color: #fff !important;
}

.session-people-page .people-card-meta,
.session-people-page .member-state {
  margin-top: 4px !important;
  color: rgba(255,255,255,.68) !important;
  font-size: 13px !important;
  white-space: normal !important;
}

.session-people-page .people-card-preview,
.session-people-page .member-about {
  margin-top: 6px !important;
  color: rgba(255,255,255,.88) !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: initial !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.session-people-page .people-card-badges {
  margin-top: 7px !important;
}

.session-people-page .people-card-actions,
.session-people-page .member-actions,
.session-page-card .session-people-page .people-card-actions,
.session-page-card .session-people-page .member-actions {
  grid-column: 2 !important;
  display: flex !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  margin-top: 12px !important;
  flex-wrap: wrap !important;
}

.session-people-page .people-card-actions .small-action-btn,
.session-people-page .member-actions .small-action-btn {
  min-height: 36px !important;
  padding: 0 13px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  background: rgba(255,255,255,.05) !important;
  color: #f7f7f7 !important;
}

.session-people-page .people-card-actions .small-action-btn:hover,
.session-people-page .member-actions .small-action-btn:hover {
  background: rgba(255,255,255,.10) !important;
}

.session-people-page #peoplePanelProfile .profile-page-card,
.session-page-card .session-people-page #peoplePanelProfile .profile-page-card {
  position: relative !important;
  overflow: hidden !important;
  min-height: 240px !important;
  display: grid !important;
  grid-template-columns: 96px minmax(0, 1fr) !important;
  gap: 16px !important;
  align-items: end !important;
  padding: 22px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 30px !important;
  background: linear-gradient(180deg, rgba(18,20,26,.96), rgba(10,12,16,.98)) !important;
  box-shadow: 0 20px 44px rgba(0,0,0,.25) !important;
  text-align: left !important;
}

.session-people-page #peoplePanelProfile .profile-page-avatar,
#profileModal .profile-avatar {
  border: 2px solid rgba(255,255,255,.22) !important;
  box-shadow: 0 18px 36px rgba(0,0,0,.28) !important;
  background-color: rgba(255,255,255,.08) !important;
}

.session-people-page #peoplePanelProfile .profile-page-name,
.session-people-page #peoplePanelProfile .profile-page-sub {
  text-align: left !important;
}

.session-people-page #peoplePanelProfile .profile-page-name {
  font-size: 28px !important;
  line-height: 1.02 !important;
}

.session-people-page #peoplePanelProfile .profile-page-sub {
  max-width: 520px;
  margin-top: 8px !important;
  color: rgba(255,255,255,.82) !important;
}

.session-people-page #peoplePanelProfile .profile-page-actions,
.session-people-page #peoplePanelProfile > .row-actions {
  justify-content: flex-start !important;
}

#profileModal .profile-card {
  position: relative;
  overflow: hidden !important;
  padding-top: 34px !important;
  border-radius: 28px !important;
  background: linear-gradient(180deg, rgba(18,20,26,.96), rgba(10,12,16,.98)) !important;
}

#profileModal .profile-avatar {
  position: relative;
  z-index: 1;
  margin-top: 22px !important;
}

#profileModal .profile-sub,
#profileModal .profile-bio,
#profileModal .profile-facts {
  position: relative;
  z-index: 1;
}

.people-profile-upload-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 2px;
}

.people-profile-bg-note {
  margin: -2px 2px 4px;
  color: var(--text-soft);
}

.messages-inbox-row {
  position: relative;
  overflow: hidden;
}

@media (max-width: 700px) {
  .session-people-page .people-item,
  .session-people-page .member-row {
    grid-template-columns: 48px minmax(0, 1fr) !important;
    padding: 13px !important;
    border-radius: 20px !important;
  }

  .session-people-page .people-card-name,
  .session-people-page .member-name,
  .session-people-page .member-topline {
    font-size: 18px !important;
  }

  .session-people-page #peoplePanelProfile .profile-page-card {
    min-height: 220px !important;
    grid-template-columns: 1fr !important;
    align-items: end !important;
    padding: 20px !important;
  }

  .session-people-page #peoplePanelProfile .profile-page-avatar {
    width: 88px !important;
    height: 88px !important;
    margin: 0 !important;
  }
}

/* Performance pass v1: cut mobile paint/layout cost without changing the visual language too much. */
.message,
.dm-message,
.people-item,
.messages-inbox-row,
.room-attachment-thumb,
.notification-center-row {
  content-visibility: auto;
  contain: layout paint style;
}

.message,
.dm-message {
  contain-intrinsic-size: 120px;
}

.people-item,
.messages-inbox-row,
.notification-center-row {
  contain-intrinsic-size: 96px;
}

.room-attachment-thumb {
  contain-intrinsic-size: 140px;
}

.msg-image,
.msg-video-thumb,
.room-attachment-thumb img,
.room-attachment-thumb video {
  image-rendering: auto;
  backface-visibility: hidden;
  transform: translateZ(0);
}

@media (hover: none) and (pointer: coarse) {
  .message,
  .dm-message,
  .people-item,
  .messages-inbox-row,
  .room-attachment-thumb,
  .notification-center-row {
    content-visibility: auto;
    contain: layout paint style;
  }

  .message-bubble,
  .dm-bubble,
  .people-item,
  .messages-inbox-row,
  .room-notice,
  .ios-install-nudge,
  .app-update-banner,
  .app-sync-banner {
    box-shadow: var(--shadow-soft);
  }

  button,
  input,
  select,
  textarea,
  a {
    transition-duration: 0.12s;
  }
}


body.perf-fluid {
  --shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
  --shadow-soft: 0 6px 16px rgba(0, 0, 0, 0.18);
}

body.perf-fluid,
body.perf-fluid * {
  scroll-behavior: auto !important;
}

body.perf-fluid .app,
body.perf-fluid .chat,
body.perf-fluid .user-panel,
body.perf-fluid .dm-chat,
body.perf-fluid .people-body,
body.perf-fluid .modal-card,
body.perf-fluid .messages-list,
body.perf-fluid .members-list,
body.perf-fluid .recent-list,
body.perf-fluid .friends-list,
body.perf-fluid .participants-list,
body.perf-fluid .notifications-center-list {
  -webkit-overflow-scrolling: touch;
  contain: layout paint style;
}

body.perf-fluid .chat,
body.perf-fluid .dm-chat,
body.perf-fluid .members-list,
body.perf-fluid .recent-list,
body.perf-fluid .friends-list,
body.perf-fluid .participants-list,
body.perf-fluid .notifications-center-list {
  content-visibility: auto;
  contain-intrinsic-size: 1px 900px;
}

body.perf-fluid .ios-install-nudge,
body.perf-fluid .message-action-backdrop,
body.perf-fluid .mention-picker,
body.perf-fluid .message-action-panel,
body.perf-fluid .session-composer,
body.perf-fluid .main-menu-panel,
body.perf-fluid .top-bar,
body.perf-fluid .room-controls-card,
body.perf-fluid .modal-card {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.perf-fluid .chat,
body.perf-fluid .user-panel,
body.perf-fluid .room-controls-panel,
body.perf-fluid .settings-preview,
body.perf-fluid .people-item,
body.perf-fluid .members-list,
body.perf-fluid .member-row,
body.perf-fluid .empty-box,
body.perf-fluid .dm-chat,
body.perf-fluid .main-menu-panel,
body.perf-fluid .modal-card,
body.perf-fluid .session-composer,
body.perf-fluid .people-card,
body.perf-fluid .messages-inbox-row,
body.perf-fluid .room-notice,
body.perf-fluid .app-update-banner,
body.perf-fluid .app-sync-banner {
  box-shadow: none !important;
}

body.perf-fluid .message,
body.perf-fluid .dm-msg,
body.perf-fluid .people-row,
body.perf-fluid .member-row,
body.perf-fluid .messages-inbox-row,
body.perf-fluid .notification-center-item,
body.perf-fluid .user-row {
  contain: layout paint style;
  transform: translateZ(0);
}

body.perf-fluid .msg-image,
body.perf-fluid .msg-video-thumb,
body.perf-fluid .profile-avatar img,
body.perf-fluid .avatar img,
body.perf-fluid .user-avatar img,
body.perf-fluid .dm-avatar img,
body.perf-fluid .dm-msg-avatar img,
body.perf-fluid .people-card-avatar img,
body.perf-fluid .member-avatar img {
  backface-visibility: hidden;
  transform: translateZ(0);
}

@media (hover: none) and (pointer: coarse) {
  body {
    background-attachment: scroll;
  }

  .app,
  .chat,
  .user-panel,
  .dm-chat,
  .modal-card,
  .main-menu-panel,
  .session-composer,
  .message,
  .dm-msg,
  .people-row,
  .member-row,
  .messages-inbox-row,
  .notification-center-item,
  .user-row {
    contain: layout paint style;
  }
}

/* v31 edge-to-edge composer rebuild: full-width dock, bottom pinned, smoother motion */
@keyframes composerSendIn {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.92);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes composerMenuPop {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes composerAttachRise {
  from {
    opacity: 0;
    transform: translateY(12px) scale(0.94);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 950px) {
  :root {
    --edge-composer-height: 70px;
  }

  .chat,
  #chat,
  .dm-chat {
    padding-bottom: calc(var(--edge-composer-height) + 12px + env(safe-area-inset-bottom)) !important;
    scroll-padding-bottom: calc(var(--edge-composer-height) + 12px + env(safe-area-inset-bottom)) !important;
  }

  .session-composer {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 0 env(safe-area-inset-bottom) 0 !important;
    background: linear-gradient(180deg, rgba(11, 12, 14, 0.88), rgba(14, 15, 18, 0.98) 18%, #121316 100%) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 -14px 36px rgba(0, 0, 0, 0.34) !important;
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
    transform: none !important;
    z-index: 120 !important;
  }

  body.keyboard-open .session-composer,
  body.visual-keyboard-open .session-composer,
  body.text-input-focused .session-composer,
  body.is-ios-standalone .session-composer,
  body.is-ios-standalone.keyboard-open .session-composer,
  body.is-ios-standalone.visual-keyboard-open .session-composer,
  body.is-ios-standalone.text-input-focused .session-composer {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    padding: 0 0 env(safe-area-inset-bottom) 0 !important;
    background: linear-gradient(180deg, rgba(11, 12, 14, 0.88), rgba(14, 15, 18, 0.98) 18%, #121316 100%) !important;
    box-shadow: 0 -14px 36px rgba(0, 0, 0, 0.34) !important;
    transform: none !important;
  }

  .session-composer-room,
  .session-composer-dm {
    gap: 0 !important;
  }

  .session-composer > * {
    width: 100%;
  }

  .session-composer .reply-bar.hidden,
  .session-composer .typing-bar.hidden,
  .session-composer .typing-bar:empty {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
    height: 0 !important;
    border: 0 !important;
  }

  .session-composer .reply-bar:not(.hidden),
  .session-composer .typing-bar:not(:empty):not(.hidden) {
    margin: 0 !important;
    padding: 10px 18px !important;
    border-radius: 0 !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
    background: rgba(255, 255, 255, 0.025) !important;
    box-shadow: none !important;
  }

  .session-composer-row {
    grid-template-columns: 56px minmax(0, 1fr) 56px !important;
    min-height: var(--edge-composer-height) !important;
    margin: 0 !important;
    padding: 8px 10px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    align-items: center !important;
    transition: background-color 0.2s ease, transform 0.18s ease !important;
  }

  body.text-input-focused .session-composer-row,
  body.keyboard-open .session-composer-row,
  body.visual-keyboard-open .session-composer-row {
    background: rgba(255, 255, 255, 0.018) !important;
  }

  .session-compose-btn,
  #sendBtn.session-compose-btn,
  #sendDmBtn.session-compose-btn {
    width: 48px !important;
    min-width: 48px !important;
    height: 48px !important;
    min-height: 48px !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, 0.055) !important;
    color: rgba(255, 255, 255, 0.92) !important;
    transition: transform 0.16s ease, background-color 0.18s ease, opacity 0.16s ease, color 0.18s ease !important;
  }

  .session-compose-btn:active,
  #sendBtn.session-compose-btn:active,
  #sendDmBtn.session-compose-btn:active {
    transform: scale(0.94) !important;
  }

  .session-compose-plus {
    font-size: 34px !important;
    font-weight: 300 !important;
  }

  .composer-field {
    min-width: 0 !important;
    height: 52px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    overflow: hidden !important;
  }

  .composer-field #messageInput,
  .composer-field #dmInput,
  textarea#messageInput,
  textarea#dmInput {
    height: 52px !important;
    min-height: 52px !important;
    padding: 12px 14px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    font-size: 18px !important;
    line-height: 28px !important;
    letter-spacing: -0.01em !important;
  }

  .session-composer-row.has-text .session-compose-voice {
    opacity: 0 !important;
    transform: scale(0.92) !important;
  }

  .session-composer-row.has-text #sendBtn.session-compose-send,
  .session-composer-row.has-text #sendDmBtn.session-compose-send {
    display: flex !important;
    opacity: 1 !important;
    transform: translateY(0) scale(1) !important;
    animation: composerSendIn 0.18s ease !important;
    background: rgba(57, 229, 141, 0.14) !important;
    color: #45f692 !important;
    border: 1px solid rgba(69, 246, 146, 0.28) !important;
  }

  .session-attach-menu {
    left: 10px !important;
    bottom: calc(100% + 12px) !important;
    gap: 12px !important;
  }

  .session-attach-menu:not(.hidden) {
    animation: composerMenuPop 0.18s ease !important;
  }

  .session-attach-menu:not(.hidden) .session-attach-item {
    animation: composerAttachRise 0.22s ease backwards !important;
  }

  .session-attach-menu:not(.hidden) .session-attach-item:nth-child(1) {
    animation-delay: 0.01s !important;
  }

  .session-attach-menu:not(.hidden) .session-attach-item:nth-child(2) {
    animation-delay: 0.04s !important;
  }

  .session-attach-menu:not(.hidden) .session-attach-item:nth-child(3) {
    animation-delay: 0.07s !important;
  }

  .session-attach-menu:not(.hidden) .session-attach-item:nth-child(4) {
    animation-delay: 0.1s !important;
  }

  .session-attach-item {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    min-height: 52px !important;
    border-radius: 18px !important;
    background: rgba(31, 33, 37, 0.96) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.44) !important;
  }

  .dm-inbox-notice {
    bottom: calc(var(--edge-composer-height) + 8px + env(safe-area-inset-bottom)) !important;
  }
}


/* v32 composer dock refinement: slimmer, lower, and safer attach affordance */
@media (max-width: 950px) {
  :root {
    --edge-composer-height: 56px;
  }

  .chat,
  #chat,
  .dm-chat {
    padding-bottom: calc(var(--edge-composer-height) + env(safe-area-inset-bottom) + 6px) !important;
    scroll-padding-bottom: calc(var(--edge-composer-height) + env(safe-area-inset-bottom) + 6px) !important;
  }

  .session-composer {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border-top: 0 !important;
    box-shadow: none !important;
    z-index: 520 !important;
    overflow: visible !important;
  }

  body.keyboard-open .session-composer,
  body.visual-keyboard-open .session-composer,
  body.text-input-focused .session-composer,
  body.is-ios-standalone .session-composer,
  body.is-ios-standalone.keyboard-open .session-composer,
  body.is-ios-standalone.visual-keyboard-open .session-composer,
  body.is-ios-standalone.text-input-focused .session-composer {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border-top: 0 !important;
    box-shadow: none !important;
    z-index: 520 !important;
  }

  .session-composer-row {
    position: relative !important;
    grid-template-columns: 48px minmax(0, 1fr) 48px !important;
    min-height: calc(var(--edge-composer-height) + env(safe-area-inset-bottom)) !important;
    height: auto !important;
    margin: 0 !important;
    padding: 6px 10px calc(6px + env(safe-area-inset-bottom)) 10px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: rgba(15, 16, 19, 0.98) !important;
    box-shadow: 0 -1px 0 rgba(255, 255, 255, 0.06), 0 -18px 34px rgba(0, 0, 0, 0.22) !important;
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
    overflow: visible !important;
    align-items: center !important;
  }

  .session-compose-btn,
  #sendBtn.session-compose-btn,
  #sendDmBtn.session-compose-btn {
    position: relative !important;
    z-index: 3 !important;
    width: 42px !important;
    min-width: 42px !important;
    height: 42px !important;
    min-height: 42px !important;
    border-radius: 14px !important;
    background: rgba(255, 255, 255, 0.04) !important;
    touch-action: manipulation !important;
  }

  .session-compose-plus {
    font-size: 30px !important;
    line-height: 1 !important;
  }

  .composer-field {
    height: 42px !important;
    min-height: 42px !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  .composer-field #messageInput,
  .composer-field #dmInput,
  textarea#messageInput,
  textarea#dmInput {
    height: 42px !important;
    min-height: 42px !important;
    padding: 8px 12px !important;
    font-size: 17px !important;
    line-height: 24px !important;
  }

  .session-attach-menu {
    left: 10px !important;
    bottom: calc(100% + 8px) !important;
    z-index: 900 !important;
    gap: 10px !important;
    pointer-events: auto !important;
  }

  .session-attach-item {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    min-height: 48px !important;
    border-radius: 16px !important;
  }

  .dm-inbox-notice {
    bottom: calc(var(--edge-composer-height) + env(safe-area-inset-bottom) + 6px) !important;
  }
}


/* Inline composer voice preview */
.composer-voice-preview {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 8px 14px 4px;
  border-top: 1px solid rgba(255,255,255,0.05);
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0));
}
.composer-voice-seek {
  flex: 1 1 auto;
  min-width: 0;
  accent-color: var(--accent);
  margin: 0;
}
.composer-voice-preview-meta {
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-soft);
  white-space: nowrap;
}
.composer-voice-preview-cancel {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 84%, var(--panel-soft));
  color: var(--text-soft);
  font-size: 22px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.session-composer.has-inline-voice-preview .composer-field textarea,
.session-composer-row.voice-preview-active .composer-field textarea {
  opacity: 0.72;
}
.session-compose-btn.is-voice-preview-toggle {
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
  background: color-mix(in srgb, var(--accent-soft) 70%, var(--panel));
}
@media (max-width: 900px) {
  .composer-voice-preview {
    padding: 8px 14px 4px;
    gap: 8px;
  }
  .composer-voice-preview-meta {
    font-size: 11px;
    max-width: 108px;
    text-align: right;
    white-space: normal;
    line-height: 1.15;
  }
}

/* Voice preview polish fix */
.composer-voice-preview {
  min-height: 34px;
  padding: 6px 12px 4px;
  gap: 10px;
  border-top: 1px solid rgba(255,255,255,0.04);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  backdrop-filter: blur(10px);
}
.composer-voice-preview-meta {
  font-size: 11px;
  letter-spacing: 0.01em;
  font-weight: 700;
}
.composer-voice-preview-cancel {
  width: 34px;
  height: 34px;
  min-width: 34px;
  min-height: 34px;
  border-radius: 999px;
  font-size: 21px;
  font-weight: 700;
  color: rgba(255,255,255,0.9);
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.09);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.composer-voice-preview-cancel:active {
  transform: scale(0.96);
}
.session-composer.has-inline-voice-preview .composer-field textarea,
.session-composer-row.voice-preview-active .composer-field textarea {
  opacity: 1;
  color: rgba(255,255,255,0.82);
}
.session-compose-btn.is-voice-preview-toggle {
  color: #fff;
  border-color: rgba(74, 255, 175, 0.42);
  background: linear-gradient(180deg, rgba(54, 241, 154, 0.28), rgba(19, 25, 34, 0.9));
  box-shadow: 0 8px 20px rgba(0,0,0,0.24), inset 0 1px 0 rgba(255,255,255,0.12);
}
.session-compose-btn.is-voice-preview-toggle:active {
  transform: scale(0.96);
}
body.is-ios-standalone .composer-voice-preview,
body.is-ios-standalone .session-composer-row.voice-preview-active {
  pointer-events: auto;
}
@media (max-width: 900px) {
  .composer-voice-preview {
    padding: 6px 12px 3px;
    gap: 8px;
  }
  .composer-voice-preview-meta {
    max-width: none;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}


/* Premium playback glyph system */
.has-playback-glyph {
  font-size: 0 !important;
  line-height: 0 !important;
}
.playback-glyph-shell {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  pointer-events: none;
}
.playback-glyph-shell.is-badge {
  width: 18px;
  height: 18px;
}
.playback-glyph-shell.is-mini {
  width: 16px;
  height: 16px;
}
.playback-glyph {
  width: 100%;
  height: 100%;
  display: block;
}
.playback-glyph-play {
  transform: translateX(0.5px);
}
.session-compose-btn.has-playback-glyph .playback-glyph-shell,
.voice-play-btn .playback-glyph-shell,
.voice-pill-play .playback-glyph-shell,
.media-preview-play .playback-glyph-shell {
  width: 20px;
  height: 20px;
}
.msg-video-badge,
.room-attachment-play {
  font-size: 0 !important;
  line-height: 0 !important;
}
.msg-video-badge .playback-glyph-shell,
.room-attachment-play .playback-glyph-shell {
  width: 15px;
  height: 15px;
}
.voice-play-btn,
.voice-pill-play,
.media-preview-play,
.session-compose-btn.is-voice-preview-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.voice-pill-play,
.voice-play-btn,
.media-preview-play {
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.18), 0 8px 18px rgba(0,0,0,0.18);
}
.voice-pill-play .playback-glyph-play,
.voice-play-btn .playback-glyph-play,
.media-preview-play .playback-glyph-play,
.session-compose-btn.is-voice-preview-toggle .playback-glyph-play {
  filter: drop-shadow(0 1px 0 rgba(255,255,255,0.08));
}
.room-attachment-play,
.msg-video-badge {
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.12);
}


/* v36 attach rail + voice preview stability */
@media (max-width: 950px) {
  .session-attach-menu {
    display: grid !important;
    grid-auto-flow: column !important;
    grid-auto-columns: 50px !important;
    align-items: center !important;
    justify-content: start !important;
    width: auto !important;
    min-width: max-content !important;
    padding: 10px !important;
    border-radius: 22px !important;
    background: rgba(14, 16, 20, 0.96) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    box-shadow: 0 18px 44px rgba(0,0,0,0.38) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    gap: 10px !important;
    left: 12px !important;
    bottom: calc(100% + 10px) !important;
    z-index: 980 !important;
  }
  .session-attach-item {
    width: 50px !important;
    height: 50px !important;
    min-width: 50px !important;
    min-height: 50px !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,0.045) !important;
    border: 1px solid rgba(255,255,255,0.09) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05) !important;
  }
  .session-attach-item:active {
    transform: scale(0.96) !important;
  }
  .composer-voice-preview {
    min-height: 38px !important;
    padding: 6px 10px 4px !important;
    gap: 10px !important;
    background: linear-gradient(180deg, rgba(20,23,28,0.96), rgba(16,18,22,0.82)) !important;
    border-top: 1px solid rgba(255,255,255,0.06) !important;
  }
  .composer-voice-seek {
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }
  .composer-voice-preview-meta {
    flex: 0 0 auto !important;
    max-width: none !important;
    white-space: nowrap !important;
    font-size: 11px !important;
    color: rgba(255,255,255,0.76) !important;
  }
  .composer-voice-preview-cancel {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    color: rgba(255,255,255,0.92) !important;
  }
  .session-compose-plus.is-voice-preview-toggle {
    background: linear-gradient(180deg, rgba(64, 244, 156, 0.26), rgba(21, 26, 34, 0.94)) !important;
    border-color: rgba(76, 255, 177, 0.42) !important;
    color: #ffffff !important;
  }
}

/* v37 attach menu hard fix: fixed overlay anchored above composer button */
@media (max-width: 950px) {
  .session-attach-menu {
    position: fixed !important;
    left: 12px !important;
    bottom: calc(86px + env(safe-area-inset-bottom)) !important;
    display: grid !important;
    grid-auto-flow: column !important;
    grid-auto-columns: 52px !important;
    align-items: center !important;
    justify-content: start !important;
    width: auto !important;
    min-width: max-content !important;
    padding: 10px !important;
    gap: 10px !important;
    border-radius: 22px !important;
    background: rgba(15, 17, 21, 0.97) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.42) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    backdrop-filter: blur(18px) !important;
    z-index: 4000 !important;
    transform-origin: bottom left !important;
  }

  .session-attach-menu.hidden {
    display: none !important;
  }

  .session-attach-menu:not(.hidden) {
    animation: composerMenuPop 0.18s ease !important;
  }

  .session-attach-item {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    min-height: 52px !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,0.05) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06) !important;
  }

  .session-attach-item:active {
    transform: scale(0.96) !important;
  }
}


/* v38 attach menu root fix */
@media (max-width: 950px) {
  .session-attach-menu {
    position: fixed !important;
    left: 12px !important;
    right: auto !important;
    bottom: calc(72px + env(safe-area-inset-bottom)) !important;
    z-index: 5000 !important;
    visibility: visible !important;
  }
  .session-attach-menu.hidden {
    display: none !important;
  }
}


/* v41 composer floor-hugging pass inspired by SimpleX/Session screenshots */
@media (max-width: 950px) {
  :root {
    --edge-composer-height: 54px;
  }

  .chat,
  #chat,
  .dm-chat {
    padding-bottom: calc(var(--edge-composer-height) + env(safe-area-inset-bottom) + 2px) !important;
    scroll-padding-bottom: calc(var(--edge-composer-height) + env(safe-area-inset-bottom) + 2px) !important;
  }

  .session-composer {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    margin: 0 !important;
    padding: 0 0 env(safe-area-inset-bottom) 0 !important;
    background: rgba(14, 16, 20, 0.985) !important;
    border-top: 1px solid rgba(255,255,255,0.05) !important;
    box-shadow: 0 -14px 30px rgba(0,0,0,0.18) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.05) !important;
    backdrop-filter: blur(18px) saturate(1.05) !important;
    z-index: 620 !important;
    overflow: visible !important;
  }

  body.keyboard-open .session-composer,
  body.visual-keyboard-open .session-composer,
  body.text-input-focused .session-composer,
  body.is-ios-standalone .session-composer,
  body.is-ios-standalone.keyboard-open .session-composer,
  body.is-ios-standalone.visual-keyboard-open .session-composer,
  body.is-ios-standalone.text-input-focused .session-composer {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    padding: 0 0 env(safe-area-inset-bottom) 0 !important;
    background: rgba(14, 16, 20, 0.985) !important;
    border-top: 1px solid rgba(255,255,255,0.05) !important;
    box-shadow: 0 -14px 30px rgba(0,0,0,0.18) !important;
  }

  .session-composer > *,
  .session-composer-room,
  .session-composer-dm {
    margin: 0 !important;
  }

  .session-composer .reply-bar.hidden,
  .session-composer .typing-bar.hidden,
  .session-composer .typing-bar:empty {
    display: none !important;
  }

  .session-composer-row {
    grid-template-columns: 46px minmax(0, 1fr) 46px !important;
    min-height: var(--edge-composer-height) !important;
    height: var(--edge-composer-height) !important;
    margin: 0 !important;
    padding: 4px 8px 0 8px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    align-items: center !important;
  }

  .session-compose-btn,
  #sendBtn.session-compose-btn,
  #sendDmBtn.session-compose-btn {
    width: 40px !important;
    min-width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,0.045) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important;
  }

  .composer-field {
    height: 40px !important;
    min-height: 40px !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,0.02) !important;
    border: 1px solid rgba(255,255,255,0.05) !important;
  }

  .composer-field #messageInput,
  .composer-field #dmInput,
  textarea#messageInput,
  textarea#dmInput {
    height: 40px !important;
    min-height: 40px !important;
    padding: 8px 10px !important;
    font-size: 17px !important;
    line-height: 22px !important;
  }

  .session-attach-menu {
    bottom: calc(60px + env(safe-area-inset-bottom)) !important;
    left: 10px !important;
  }
}
/* Premium feature scaffolding. These classes are inert until feature flags add data. */
.reply-snippet-rich {
  cursor: pointer;
}

.reply-count-chip {
  align-self: flex-start;
  border: 1px solid rgba(120, 130, 150, .28);
  background: rgba(120, 130, 150, .08);
  color: var(--text-soft);
  border-radius: 8px;
  padding: 4px 8px;
  font: inherit;
  font-size: 12px;
  cursor: pointer;
}

.message.from-me .reply-count-chip,
.dm-message.from-me .reply-count-chip {
  align-self: flex-end;
}

.spoiler-text-hidden {
  display: inline-block;
  border-radius: 8px;
  padding: 2px 6px;
  color: transparent !important;
  text-shadow: 0 0 10px var(--bubble-text-color, currentColor);
  background: rgba(120, 130, 150, .22);
  cursor: pointer;
}

.msg-media-card.is-spoiler-blurred .msg-image,
.msg-media-card.is-spoiler-blurred .msg-video-thumb {
  filter: blur(18px) saturate(.8);
  transform: scale(1.02);
}

.spoiler-media-cover {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: grid;
  place-items: center;
  padding: 12px;
  color: #fff;
  background: rgba(0, 0, 0, .38);
  font-weight: 700;
  text-align: center;
}

.message.is-media-album,
.dm-message.is-media-album {
  margin-top: 2px;
}

.message.is-media-album.album-middle .message-bubble,
.message.is-media-album.album-last .message-bubble,
.dm-message.is-media-album.album-middle .dm-bubble,
.dm-message.is-media-album.album-last .dm-bubble {
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
}

.premium-flag-badge,
.ephemeral-indicator {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  border-radius: 8px;
  padding: 3px 8px;
  background: rgba(120, 130, 150, .12);
  color: var(--text-soft);
  font-size: 12px;
  line-height: 1.2;
}

/* Live room themes and profile vibe surfaces. */
body.room-theme-live {
  --accent: var(--room-accent, #39e58d);
  --accent-strong: var(--room-accent, #39e58d);
  --accent-soft: var(--room-accent-soft, rgba(57, 229, 141, .14));
  --accent-border: var(--room-accent-border, rgba(57, 229, 141, .38));
}

body.room-theme-live .app {
  position: relative;
  isolation: isolate;
}

body.room-theme-live .app::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background-image:
    linear-gradient(rgba(5, 6, 8, var(--room-ambient-strength, .14)), rgba(5, 6, 8, var(--room-ambient-strength, .14))),
    var(--room-ambient-image, none);
  background-size: cover;
  background-position: center;
  opacity: .9;
}

body.room-theme-live .top-bar {
  position: relative;
  border-bottom: 1px solid color-mix(in srgb, var(--room-accent, #39e58d) 22%, transparent);
}

body.room-theme-live .top-bar::before {
  content: "";
  position: absolute;
  inset: -8px -14px -10px;
  z-index: -1;
  background-image:
    linear-gradient(90deg, color-mix(in srgb, var(--room-ambient-tint, #050608) 70%, transparent), transparent 68%),
    var(--room-banner-image, none);
  background-size: cover;
  background-position: center;
  opacity: .36;
}

body.room-theme-glow .top-bar,
body.room-theme-glow .session-composer {
  box-shadow: 0 0 22px color-mix(in srgb, var(--room-accent, #39e58d) 20%, transparent) !important;
}

body.room-theme-glow #sendBtn,
body.room-theme-glow #sendDmBtn,
body.room-theme-glow .room-header-menu-btn {
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--room-accent, #39e58d) 24%, transparent), 0 0 18px color-mix(in srgb, var(--room-accent, #39e58d) 28%, transparent) !important;
}

.room-theme-banner {
  margin: 4px 0 10px;
  min-height: 74px;
  display: flex;
  align-items: end;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--room-accent, #39e58d) 32%, var(--border));
  border-radius: 8px;
  background-image:
    linear-gradient(180deg, transparent, rgba(0,0,0,.52)),
    var(--room-theme-banner-url, none);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.room-theme-banner.hidden {
  display: none;
}

.room-theme-banner-copy {
  min-width: 0;
  color: #fff;
  text-shadow: 0 1px 8px rgba(0,0,0,.58);
}

.room-theme-banner-title {
  font-weight: 900;
  font-size: 16px;
  line-height: 1.1;
}

.room-theme-banner-meta {
  margin-top: 3px;
  font-size: 12px;
  color: rgba(255,255,255,.78);
}

.room-theme-editor-panel {
  border-color: color-mix(in srgb, var(--room-accent, #39e58d) 28%, var(--border)) !important;
}

.room-theme-editor-panel .settings-upload-row {
  justify-content: flex-start;
  margin-top: 10px;
}

body.room-bubble-rounded .message-bubble:not(.media-only),
body.room-bubble-rounded .dm-bubble:not(.media-only) {
  border-radius: 22px !important;
}

body.room-bubble-compact .message-bubble:not(.media-only),
body.room-bubble-compact .dm-bubble:not(.media-only) {
  border-radius: 8px !important;
  padding: 6px 9px !important;
}

body.room-bubble-crisp .message-bubble:not(.media-only),
body.room-bubble-crisp .dm-bubble:not(.media-only) {
  border-radius: 6px !important;
}

body.room-reply-panel .reply-snippet {
  border-left: 0 !important;
  border: 1px solid color-mix(in srgb, var(--room-accent, #39e58d) 34%, transparent) !important;
  background: color-mix(in srgb, var(--room-accent, #39e58d) 12%, rgba(255,255,255,.08)) !important;
}

body.room-reply-minimal .reply-snippet {
  padding: 4px 0 4px 8px !important;
  border-radius: 0 !important;
  background: transparent !important;
}

body.room-reply-bar .reply-snippet {
  border-left-color: var(--room-accent, #39e58d) !important;
}

.profile-vibe {
  display: grid;
  gap: 8px;
  margin: 10px 0;
}

.profile-vibe.hidden {
  display: none;
}

.profile-vibe-inline {
  margin: 8px 0 0;
}

.profile-vibe-mood,
.profile-vibe-status,
.profile-vibe-intro,
.profile-vibe-empty {
  border: 1px solid color-mix(in srgb, var(--accent-border) 72%, var(--border));
  border-radius: 8px;
  padding: 8px 10px;
  background: color-mix(in srgb, var(--accent-soft) 72%, var(--panel));
  color: var(--text);
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.profile-vibe-mood {
  font-weight: 800;
  color: var(--accent-strong);
}

.profile-vibe-status,
.profile-vibe-intro,
.profile-vibe-empty {
  color: var(--text-soft);
  font-size: 13px;
}

.profile-song-card {
  display: grid;
  gap: 8px;
  border: 1px solid color-mix(in srgb, var(--accent-border) 72%, var(--border));
  border-radius: 8px;
  padding: 10px;
  background: color-mix(in srgb, var(--panel-raised) 86%, var(--accent-soft));
}

.profile-song-copy {
  min-width: 0;
}

.profile-song-label {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--text-faint);
}

.profile-song-title {
  margin-top: 2px;
  color: var(--text);
  font-weight: 800;
  overflow-wrap: anywhere;
}

.profile-song-audio {
  width: 100%;
  max-width: 100%;
}

@media (max-width: 950px) {
  .room-theme-banner {
    margin-left: 0;
    margin-right: 0;
    min-height: 62px;
  }

  body.room-theme-live .top-bar::before {
    inset: -8px -14px -7px;
  }
}


/* v38 room mood premium layering + transitions */
body.room-theme-live {
  overflow-x: clip;
}

body.room-theme-live::before,
body.room-theme-live::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
}

body.room-theme-live::before {
  z-index: -3;
  background-image: var(--room-ambient-image, none);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: scale(1.03);
  opacity: .86;
  transition: opacity 260ms ease, transform 420ms ease, filter 300ms ease;
  filter: saturate(1.06) contrast(1.03);
}

body.room-theme-live::after {
  z-index: -2;
  background:
    radial-gradient(140% 70% at 50% -12%, color-mix(in srgb, var(--room-accent, #39e58d) 14%, transparent), transparent 60%),
    linear-gradient(180deg,
      color-mix(in srgb, var(--room-ambient-tint, #050608) calc(var(--room-ambient-strength, .14) * 180%), transparent) 0%,
      color-mix(in srgb, var(--room-ambient-tint, #050608) calc(var(--room-ambient-strength, .14) * 240%), #020304) 100%);
  transition: background 260ms ease;
}

body.room-theme-live .app {
  position: relative;
  isolation: isolate;
}

body.room-theme-live .app::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.24) 36%, rgba(0,0,0,.34) 100%);
}

body.room-theme-live .top-bar::before {
  inset: -10px -16px -12px;
  opacity: .54;
  transition: opacity 220ms ease, filter 260ms ease;
  filter: saturate(1.08) contrast(1.06);
}

body.room-theme-live .top-bar,
body.room-theme-live .chat,
body.room-theme-live .session-composer,
body.room-theme-live .dm-chat,
body.room-theme-live .dm-top {
  transition: border-color 200ms ease, box-shadow 220ms ease, background-color 200ms ease;
}

body.room-theme-live.room-bubble-session .message-bubble:not(.media-only),
body.room-theme-live.room-bubble-session .dm-bubble:not(.media-only),
body.room-theme-live.room-bubble-rounded .message-bubble:not(.media-only),
body.room-theme-live.room-bubble-rounded .dm-bubble:not(.media-only),
body.room-theme-live.room-bubble-compact .message-bubble:not(.media-only),
body.room-theme-live.room-bubble-compact .dm-bubble:not(.media-only),
body.room-theme-live.room-bubble-crisp .message-bubble:not(.media-only),
body.room-theme-live.room-bubble-crisp .dm-bubble:not(.media-only),
body.room-theme-live .reply-snippet {
  transition: border-radius 180ms ease, padding 180ms ease, border-color 180ms ease, background 180ms ease;
}

body.room-theme-live.room-reply-panel .reply-snippet,
body.room-theme-live.room-reply-bar .reply-snippet {
  backdrop-filter: blur(10px);
}

.session-composer-row.voice-preview-active #sendBtn.session-compose-send,
.session-composer-row.voice-preview-active #sendDmBtn.session-compose-send {
  display: inline-flex !important;
  opacity: 1 !important;
}
