:root {
  color-scheme: dark;
  --font-ui: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-brand: "Satoshi", "Inter", ui-sans-serif, system-ui, sans-serif;
  --font-content: "Geist", "Inter", ui-sans-serif, system-ui, sans-serif;
  --font-mono: "JetBrains Mono", "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  --font-friendly: "Instrument Sans", "Inter", ui-sans-serif, system-ui, sans-serif;
  --sidebar-width: 270px;
  --rail-width: 300px;
  --profile-width: 300px;
  --bg: #141414;
  --panel: #181818;
  --panel-soft: #1e1e1e;
  --panel-muted: #2a2a2a;
  --border: rgba(179, 179, 177, 0.18);
  --border-strong: #2e2e2e;
  --text: #dadad7;
  --text-soft: #b3b3b1;
  --text-muted: #4c4c4c;
  --white: #ffffff;
  --green: #31e981;
  --red: #ff5b6b;
  --cyan: #00b9d9;
  --purple: #b450ff;
  --yellow: #e7d44d;
  --calendar-accent: #31e981;
  --calendar-accent-rgb: 49, 233, 129;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

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

html,
body {
  margin: 0;
  min-height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-ui);
}

h1,
h2,
h3,
.brand,
.auth-brand,
.section-head h1,
.section-head h2,
.dashboard-hero-copy h3,
.dashboard-header h2,
.integrations-copy h1,
.integrations-overview h1,
.integrations-overview h2,
.calendar-header h2,
.auth-welcome-lockup h1,
.profile-copy h1,
.discord-header h1,
.learning-progress-copy h2,
.chat-channel-title h2,
.messaging-directory-header h2,
.ai-native-history__header h2,
.ai-native-panel__header h2 {
  font-family: var(--font-brand);
}

p,
textarea,
.chat-bubble-body,
.chat-bubble-body p,
.ai-native-message__body,
.ai-native-message__body p,
.request-card,
.promoted-task-card,
.task-card,
.calendar-event,
.calendar-day,
.dashboard-summary-copy,
.notification-list,
.chat-file-card,
.messaging-row-main small,
.messaging-channel-row small,
.messaging-object-row small {
  font-family: var(--font-content);
}

code,
kbd,
samp,
pre,
#chatCodeInput,
.composer-command-menu,
.composer-command-menu kbd,
.composer-mention-menu code,
.chat-message-flags,
.discord-user-id,
#discordUserId,
.ai-native-status {
  font-family: var(--font-mono);
}

.auth-copy,
.auth-start-copy,
.messaging-empty-state,
.composer-menu-empty,
.notification-empty,
.ai-native-empty,
.placeholder-panel,
.activity-empty-state,
.learning-course-card {
  font-family: var(--font-friendly);
}

html {
  scrollbar-gutter: stable;
}

body {
  min-height: 100vh;
  overflow-x: hidden;
}

body.auth-checking .app-shell {
  visibility: hidden;
}

body.has-mobile-menu-open {
  overflow: hidden;
}

button,
input,
iframe {
  font: inherit;
}

button {
  border: 0;
  background: none;
  color: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

button:disabled {
  cursor: default;
}

.app-shell {
  display: grid;
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
  min-height: 100vh;
  max-width: 1600px;
  margin: 0 auto;
  position: relative;
}

.mobile-menu-button,
.sidebar-overlay {
  display: none;
}

.mobile-menu-button {
  position: fixed;
  top: 16px;
  left: 16px;
  z-index: 35;
  width: 48px;
  height: 48px;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  background: rgba(16, 16, 16, 0.92);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(16px);
  cursor: pointer;
}

.mobile-menu-button span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 4px auto;
  border-radius: 999px;
  background: var(--white);
  transition: transform 180ms ease, opacity 180ms ease;
}

.mobile-menu-button.is-active span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

.mobile-menu-button.is-active span:nth-child(2) {
  opacity: 0;
}

.mobile-menu-button.is-active span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

.sidebar-overlay {
  position: fixed;
  inset: 0;
  z-index: 29;
  background: rgba(0, 0, 0, 0.52);
  backdrop-filter: blur(4px);
}

.sidebar {
  width: var(--sidebar-width);
  max-width: var(--sidebar-width);
  min-width: var(--sidebar-width);
  flex: 0 0 var(--sidebar-width);
  border-right: 1px solid var(--border-strong);
  padding: 8px 10px 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  height: 100vh;
  position: sticky;
  top: 0;
  overflow: visible;
}

.brand-mark {
  width: 42px;
  height: 50px;
  display: grid;
  place-items: center;
}

.brand-mark img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: brightness(0) saturate(100%) invert(91%) sepia(6%) saturate(109%) hue-rotate(27deg) brightness(103%) contrast(92%);
}

.sidebar-search {
  height: 34px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: #161616;
}

.sidebar-search svg {
  width: 16px;
  height: 16px;
  stroke: var(--text-muted);
  fill: none;
  stroke-width: 2;
}

.sidebar-search input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
}

.sidebar-search input::placeholder {
  color: #8b8b8a;
}

.sidebar-nav,
.sidebar-footer {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sidebar-nav {
  position: relative;
}

.sidebar-footer {
  margin-top: auto;
}

.sign-out-button {
  width: 100%;
  min-height: 42px;
  margin-top: 12px;
  padding: 10px 12px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: #181818;
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, color 160ms ease;
}

.sign-out-button:hover {
  border-color: rgba(255, 91, 107, 0.46);
  background: rgba(255, 91, 107, 0.12);
  color: var(--white);
}

.settings-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
}

.task-empty-state,
.chat-list-empty,
.chat-empty-state {
  padding: 16px;
  border: 1px dashed var(--border-strong);
  border-radius: 12px;
  color: var(--text-soft);
  background: rgba(255, 255, 255, 0.03);
  font-size: 13px;
  line-height: 1.45;
}

.chat-empty-state {
  margin: auto;
  max-width: 360px;
  text-align: center;
}

.auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: #141414;
}

.auth-card {
  width: min(100%, 420px);
  padding: 30px;
  border: 1px solid var(--border-strong);
  border-radius: 16px;
  background: #181818;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.32);
}

.auth-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 22px;
  color: var(--white);
  font-size: 22px;
  font-weight: 700;
}

.auth-brand img {
  width: 34px;
  height: 34px;
}

.auth-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  margin-bottom: 20px;
  padding: 4px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: #111111;
}

.auth-tab {
  min-height: 38px;
  border-radius: 9px;
  color: var(--text-soft);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.auth-tab.is-active {
  background: #252525;
  color: var(--white);
}

.auth-form {
  display: grid;
  gap: 14px;
}

.auth-field {
  display: grid;
  gap: 8px;
  color: var(--text-soft);
  font-size: 13px;
  font-weight: 700;
}

.auth-field input {
  width: 100%;
  min-height: 46px;
  padding: 11px 13px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: #111111;
  color: var(--white);
  outline: none;
}

.auth-field input:focus {
  border-color: rgba(49, 233, 129, 0.62);
}

.auth-submit {
  min-height: 46px;
  margin-top: 2px;
  border-radius: 12px;
  background: var(--green);
  color: #0c1a10;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
}

.auth-submit:disabled {
  opacity: 0.72;
}

.auth-message {
  margin: 0;
  padding: 11px 12px;
  border-radius: 12px;
  font-size: 13px;
  line-height: 1.45;
}

.auth-message--error {
  border: 1px solid rgba(255, 91, 107, 0.32);
  background: rgba(255, 91, 107, 0.11);
  color: #ffb8c0;
}

.auth-message--success {
  border: 1px solid rgba(49, 233, 129, 0.32);
  background: rgba(49, 233, 129, 0.1);
  color: #9af6bc;
}

.sidebar-footer-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.nav-item {
  min-height: 34px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 10px;
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease;
  color: #8b8b8a;
}

.nav-item:hover,
.nav-item.is-active {
  background: #1e1e1e;
  color: var(--text);
}

.nav-item:not(.is-active):hover {
  background: #202020;
  color: var(--text);
}

.nav-icon {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  display: inline-grid;
  place-items: center;
  background-image: none;
  opacity: 1;
  color: currentColor;
  font-size: 18px;
}

.nav-item:not(.is-active):hover .nav-icon {
  color: currentColor;
}

.nav-item.is-active .nav-icon {
  color: currentColor;
}

.nav-item--new .nav-icon,
.nav-item--new:hover .nav-icon,
.nav-item--new.is-active .nav-icon {
  color: currentColor;
}

.nav-label {
  font-size: 14px;
}

.nav-item--new,
.nav-item--new:hover,
.nav-item--new.is-active {
  background: #f4f4f3;
  color: #111111;
  min-height: 40px;
  border-radius: 10px;
  border-color: rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.nav-item--disabled {
  opacity: 0.45;
  pointer-events: none;
}

.nav-item--footer {
  justify-content: center;
  padding: 0 8px;
}

.nav-item--footer-main {
  flex: 1 1 auto;
  justify-content: flex-start;
}

.nav-item--footer .nav-label {
  font-size: 13px;
}

.nav-item--icon-only {
  width: 40px;
  min-width: 40px;
  padding: 0;
  justify-content: center;
}

.nav-item--icon-only .nav-icon {
  margin: 0;
}

.sidebar-notification-button {
  margin-left: auto;
}

.nav-item--icon-only .nav-label {
  display: none;
}

.new-menu {
  position: absolute;
  top: 2px;
  left: calc(100% + 10px);
  width: 196px;
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  background: #121212;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.34);
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 15;
}

.new-menu[hidden] {
  display: none;
}

.new-menu-item {
  min-height: 34px;
  padding: 0 10px;
  border-radius: 10px;
  text-align: left;
  color: var(--text-soft);
  cursor: pointer;
}

.new-menu-item:hover {
  background: #2a2a2a;
  color: var(--white);
}

.workspace-card {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 4px 0;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.workspace-card:hover,
.workspace-card[aria-expanded="true"] {
  background: #1e1e1e;
}

.profile-image {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: cover;
}

.workspace-badge {
  width: 32px;
  height: 32px;
  border-radius: 12px;
  background: var(--panel-soft);
  display: grid;
  place-items: center;
  color: var(--text-soft);
  font-weight: 700;
}

.workspace-badge--large {
  width: 72px;
  height: 72px;
  border-radius: 20px;
}

.workspace-card strong,
.settings-card strong {
  display: block;
  font-size: 16px;
  color: var(--text-soft);
}

.workspace-card span,
.settings-card span {
  color: var(--text-muted);
  font-size: 12px;
}

.sidebar-account-menu {
  padding: 4px 4px 0;
}

.sidebar-account-menu .sign-out-button {
  margin-top: 0;
}

.main-stage {
  padding: 16px 16px 20px;
  overflow: auto;
  min-width: 0;
  min-height: 100vh;
}

.view-panel {
  display: none;
  min-width: 0;
  min-height: calc(100vh - 36px);
}

.view-panel.is-active {
  display: block;
}
/* OpenThread production polish overrides */
:root {
  --sidebar-width: 300px;
  --bg: #141414;
  --panel: #181818;
  --panel-soft: #1e1e1e;
  --panel-muted: #252525;
  --border: #2e2e2e;
  --border-strong: #515151;
  --text: #dadad7;
  --text-soft: #b3b3b1;
  --text-muted: #8b8b8a;
  --white: #ffffff;
  --black: #111111;
  --app-button: #181b21;
}

:root[data-theme="light"] {
  color-scheme: light;
  --bg: #f5f5f2;
  --panel: #ffffff;
  --panel-soft: #f0f0ec;
  --panel-muted: #e8e7e2;
  --border: #d8d6cf;
  --border-strong: #bdbab1;
  --text: #1e1e1c;
  --text-soft: #5f5d57;
  --text-muted: #7b7870;
  --white: #111111;
  --black: #ffffff;
  --app-button: #eceef3;
}

html,
body {
  background: var(--bg);
  color: var(--text);
}

.app-shell {
  max-width: none;
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
}

.sidebar {
  width: var(--sidebar-width);
  min-width: var(--sidebar-width);
  max-width: var(--sidebar-width);
  padding: 10px 12px 12px;
  background: var(--bg);
  border-right-color: var(--border);
}

.sidebar-search,
.nav-item,
.connect-apps-card,
.workspace-card,
.new-menu,
.request-panel,
.promoted-task-panel,
.status-panel,
.dashboard-calendar-card,
.dashboard-task-board,
.dashboard-up-next-card,
.ai-native-history,
.ai-native-panel,
.discord-settings-panel,
.discord-card,
.settings-page,
.settings-card,
.placeholder-panel {
  background: var(--panel);
  border-color: var(--border);
  color: var(--text);
}

.nav-item {
  min-height: 36px;
  font-size: 14px;
}

.nav-label,
.workspace-card strong,
.workspace-card span,
.connect-apps-card {
  color: inherit;
}

.main-stage {
  min-width: 0;
  padding: 20px 32px 16px 72px;
  background: var(--bg);
}

body[data-active-view="dashboard"] .main-stage {
  padding: 20px 34px 16px 78px;
}

body[data-active-view="ai"] .main-stage,
body[data-active-view="chat"] .main-stage {
  padding: 0;
}

.view-panel--board {
  max-width: none;
}

body[data-active-view="tasks"] .view-panel--board {
  width: min(1320px, 100%);
}

.dashboard-overview {
  width: min(100%, 1720px);
  min-height: calc(100vh - 36px);
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  grid-template-rows: 520px minmax(0, 1fr);
  gap: 20px 32px;
  align-items: stretch;
}

.dashboard-figma-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 700px;
  gap: 16px;
  grid-column: 1 / 5;
  grid-row: 1;
  align-items: start;
}

.dashboard-hero-copy {
  padding-top: 42px;
}

.dashboard-hero-copy h3 {
  margin: 0 0 64px;
  color: var(--white);
  font-size: 52px;
  line-height: 1.04;
  font-weight: 700;
}

.dashboard-hero-copy span {
  max-width: 640px;
  color: var(--white);
  font-size: 28px;
  line-height: 1.3;
}

.dashboard-new-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 250px;
  gap: 14px;
}

.dashboard-new-card {
  min-height: 0;
  border-radius: 3px;
  background: var(--panel);
  border-color: var(--border);
}

.dashboard-new-card--reminder {
  grid-column: 1;
}

.dashboard-new-icon {
  width: 58px;
  height: 58px;
  font-size: 58px;
}

.dashboard-new-card strong {
  color: var(--white);
  font-size: 24px;
}

.dashboard-main-grid--figma {
  display: contents;
}

.dashboard-primary-stack {
  grid-column: 1 / 5;
  grid-row: 2;
  min-width: 0;
}

.dashboard-side-stack {
  grid-column: 5 / 6;
  grid-row: 1 / 3;
  display: grid;
  grid-template-rows: 515px minmax(0, 1fr);
  gap: 20px;
  min-width: 0;
}

.dashboard-task-board {
  height: 100%;
  overflow: hidden;
}

.dashboard-task-board__head,
.dashboard-task-panel-head,
.section-head {
  background: var(--panel);
  border-color: var(--border);
}

.dashboard-task-board__head h3,
.dashboard-task-panel-head h4,
.section-head h1,
.section-head h2 {
  color: var(--text);
}

.dashboard-task-board__requests {
  min-height: 160px;
  background: var(--panel);
  border-color: var(--border);
}

.dashboard-request-card,
.request-card,
.promoted-task-card {
  background: var(--panel-soft);
  border-color: var(--border);
}

.request-tag {
  background: color-mix(in srgb, var(--label-color, #63e2fe) 24%, transparent);
  color: var(--label-color, #63e2fe);
}

.dashboard-task-panel,
.dashboard-task-panel__body,
.task-list {
  background: var(--panel);
}

.dashboard-task-row,
.task-row {
  min-height: 54px;
  background: var(--panel);
  border-color: var(--border);
}

.dashboard-task-row span:last-of-type,
.task-title {
  color: var(--text);
  font-size: 20px;
}

.dashboard-task-priority,
.task-priority {
  color: var(--text-soft);
  font-size: 13px;
}

.dashboard-calendar-card,
.dashboard-up-next-card {
  width: 100%;
  padding: 24px;
  background: var(--panel);
  border-color: var(--border);
}

.dashboard-calendar-card .widget-head h3,
.dashboard-up-next-card h3 {
  color: var(--white);
  font-size: 22px;
}

.dashboard-calendar-actions .widget-link-button {
  min-height: 36px;
  padding: 0 18px;
  background: var(--app-button);
  color: var(--white);
  font-size: 12px;
}

.dashboard-calendar-weekdays,
.dashboard-calendar-grid {
  gap: 12px;
}

.dashboard-calendar-weekdays span,
.dashboard-calendar-day span {
  color: var(--text);
  font-size: 16px;
}

.dashboard-calendar-grid {
  margin-top: 18px;
}

.dashboard-calendar-day {
  min-height: 42px;
}

.dashboard-calendar-day.is-today {
  border: 3px solid var(--white);
  background: transparent;
}

.dashboard-upcoming-item {
  min-height: 88px;
  padding: 16px;
  background: color-mix(in srgb, var(--panel-soft) 78%, #0b1220);
  border-color: var(--border-strong);
}

.dashboard-upcoming-item strong {
  color: var(--white);
}

.ai-native-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 0;
  background: var(--bg);
}

.ai-native-history {
  width: auto;
  min-height: 100vh;
  padding: 22px;
  border-width: 0 1px 0 0;
  border-radius: 0;
}

.ai-native-panel {
  min-height: 100vh;
  padding: 24px 32px;
  border: 0;
  border-radius: 0;
  background: var(--bg);
}

.ai-native-thread {
  height: calc(100vh - 150px);
}

.ai-native-composer {
  width: min(900px, 100%);
  border-radius: 12px;
  background: var(--panel);
  border-color: var(--border-strong);
}

.integrations-overview {
  max-width: 1180px;
  gap: 24px;
}

.integrations-copy p,
.integration-section-head span,
.settings-section-head p,
.settings-section-head span {
  color: var(--text-soft);
}

.integrations-copy h1 {
  max-width: 780px;
  margin: 0;
  color: var(--white);
  font-size: 34px;
  line-height: 1.15;
}

.integration-section {
  display: grid;
  gap: 12px;
}

.integration-section-head h2 {
  margin: 0;
  color: var(--white);
  font-size: 20px;
}

.integration-connected-grid,
.integration-explore-grid {
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 12px;
}

.integration-icon-tile {
  min-height: 132px;
  align-content: center;
  gap: 10px;
  padding: 16px;
  background: var(--panel);
  border-color: var(--border);
}

.integration-icon-tile strong {
  color: var(--text);
  font-size: 16px;
}

.integration-icon-tile small {
  color: var(--text-soft);
  font-size: 12px;
}

.discord-integration-tile .discord-tile-copy,
.discord-integration-tile .discord-tile-status {
  display: block;
}

.discord-integration-tile {
  grid-template-columns: auto minmax(0, 1fr) auto;
  text-align: left;
}

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

.settings-page {
  min-height: calc(100vh - 40px);
  display: grid;
  grid-template-columns: 260px minmax(0, 920px);
  gap: 24px;
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: 6px;
}

.settings-nav {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 18px;
  border-right: 1px solid var(--border);
}

.settings-nav p,
.settings-nav h2,
.settings-section-head p,
.settings-section-head h2 {
  margin: 0;
}

.settings-nav h2,
.settings-section-head h2 {
  color: var(--white);
}

.settings-tab {
  min-height: 38px;
  padding: 0 12px;
  border: 1px solid transparent;
  border-radius: 4px;
  color: var(--text-soft);
  text-align: left;
  cursor: pointer;
}

.settings-tab.is-active {
  border-color: var(--border-strong);
  background: var(--panel-soft);
  color: var(--white);
}

.settings-tab--danger {
  margin-top: auto;
  color: var(--red);
}

.settings-content,
.settings-section {
  min-width: 0;
}

.settings-section {
  display: none;
}

.settings-section.is-active {
  display: grid;
  gap: 18px;
}

.settings-section-head {
  display: grid;
  gap: 8px;
}

.settings-profile-frame {
  width: 100%;
  min-height: 680px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}

.settings-form,
.settings-label-form {
  display: grid;
  gap: 12px;
}

.settings-label-form {
  grid-template-columns: minmax(0, 1fr) 56px auto;
  align-items: center;
}

.settings-label-form input[type="text"],
.settings-field input,
.settings-field select {
  background: var(--panel-soft);
  border-color: var(--border);
  color: var(--text);
}

.settings-label-list {
  display: grid;
  gap: 8px;
}

.settings-label-row,
.settings-danger-card,
.settings-toggle-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--panel);
}

.settings-label-row span {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: var(--label-color);
}

.settings-label-row strong {
  flex: 1;
}

.settings-label-row button {
  color: var(--red);
  cursor: pointer;
}

.theme-toggle {
  display: inline-flex;
  padding: 3px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--panel-soft);
}

.theme-toggle button {
  min-width: 72px;
  min-height: 32px;
  border-radius: 999px;
  cursor: pointer;
}

.theme-toggle button.is-active {
  background: var(--white);
  color: var(--black);
}

.settings-danger-card {
  border-color: rgba(255, 91, 107, 0.42);
}

.settings-danger-status {
  min-height: 20px;
  color: var(--text-soft);
}

@media (max-width: 1200px) {
  .dashboard-overview,
  .dashboard-figma-top,
  .dashboard-main-grid--figma,
  .ai-native-shell,
  .settings-page {
    display: flex;
    flex-direction: column;
  }

  .dashboard-side-stack {
    display: grid;
    grid-template-rows: auto;
  }

  .dashboard-new-grid,
  .integration-connected-grid,
  .integration-explore-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  :root {
    --sidebar-width: 300px;
  }

  .main-stage,
  body[data-active-view="dashboard"] .main-stage {
    padding: 72px 14px 16px;
  }
}

/* Final desktop lock: keep the web app close to the supplied desktop SVGs. */
@media (min-width: 901px) {
  body[data-active-view="dashboard"] .main-stage,
  body[data-active-view="tasks"] .main-stage,
  body[data-active-view="integrations"] .main-stage {
    padding: 22px 28px 24px 84px;
  }

  body[data-active-view="ai"] .main-stage,
  body[data-active-view="chat"] .main-stage {
    padding: 0;
  }

  .view-panel--board {
    max-width: none;
  }

  .dashboard-overview {
    width: min(100%, 1580px);
    gap: 26px;
  }

  .dashboard-figma-top {
    grid-template-columns: minmax(560px, 1fr) 520px;
    gap: 34px;
    min-height: 350px;
  }

  .dashboard-hero-copy {
    padding-top: 18px;
  }

  .dashboard-hero-copy h3 {
    margin-bottom: 82px;
    font-size: clamp(42px, 4.2vw, 70px);
  }

  .dashboard-hero-copy span {
    max-width: 900px;
    font-size: clamp(22px, 2.1vw, 36px);
    line-height: 1.22;
  }

  .dashboard-new-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .dashboard-new-card {
    min-height: 176px;
    border-radius: 3px;
  }

  .dashboard-new-icon {
    width: 64px;
    height: 64px;
  }

  .dashboard-new-card strong {
    font-size: 20px;
  }

  .dashboard-main-grid--figma {
    grid-template-columns: minmax(720px, 1fr) 286px;
    gap: 18px;
  }

  .dashboard-task-board__head,
  .section-head {
    min-height: 66px;
    padding: 18px 34px;
  }

  .dashboard-task-board__head h3,
  .section-head h1,
  .section-head h2,
  .dashboard-task-panel-head h4 {
    font-size: 30px;
  }

  .dashboard-task-board__requests {
    grid-template-columns: minmax(0, 1fr);
    padding: 24px;
  }

  .dashboard-request-card,
  .request-card {
    min-height: 164px;
    padding: 26px 30px 0;
  }

  .dashboard-request-card h4,
  .request-card h3 {
    font-size: 24px;
    font-weight: 400;
  }

  .dashboard-task-panel-head {
    min-height: 70px;
    padding: 14px 38px;
  }

  .dashboard-task-row,
  .task-row {
    grid-template-columns: 120px 44px minmax(0, 1fr) auto;
    min-height: 74px;
    padding: 0 30px;
  }

  .dashboard-task-row span:last-of-type,
  .task-title {
    font-size: 28px;
  }

  .dashboard-task-priority,
  .task-priority {
    font-size: 18px;
  }

  .task-bullet {
    width: 22px;
    height: 22px;
  }

  .request-panel,
  .status-panel {
    max-width: 1360px;
    margin-left: 0;
  }

  .request-panel {
    margin-top: 20px;
  }

  .status-panel {
    margin-top: 12px;
  }

  .request-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .integrations-overview {
    max-width: 1120px;
    margin-left: 0;
    gap: 24px;
  }

  .integrations-overview h1,
  .integrations-overview h2 {
    font-size: 38px;
  }

  .integration-connected-grid {
    grid-template-columns: repeat(2, 292px);
    gap: 12px;
  }

  .integration-explore-grid {
    grid-template-columns: repeat(3, 292px);
    gap: 12px;
  }

  .integration-icon-tile {
    min-height: 164px;
  }

  .integration-glyph {
    width: 72px;
    height: 72px;
  }

  .integration-coming-grid {
    grid-template-columns: repeat(4, 218px);
    gap: 14px 10px;
  }

  .integration-coming-grid article {
    min-height: 122px;
  }

  .integration-coming-grid span {
    width: 42px;
    height: 42px;
  }

  .integration-coming-grid strong {
    font-size: 18px;
  }
}

.ai-native-shell {
  min-height: 100vh;
  display: block;
  position: relative;
  background: #141414;
}

.ai-native-panel {
  min-height: 100vh;
  padding: 38px 50px 58px;
  border: 0;
  background: #141414;
}

.ai-native-panel__header {
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
}

.ai-native-panel__header::before,
.ai-native-panel__header::after {
  content: none;
}

.ai-native-menu-button,
.ai-native-plus-button {
  width: 58px;
  height: 58px;
  display: inline-grid;
  place-items: center;
  border: 1px solid #2a2a2a;
  border-radius: 8px;
  background: #1e1e1e;
  color: #ffffff;
  cursor: pointer;
}

.ai-native-menu-button span,
.ai-native-menu-button span::before,
.ai-native-menu-button span::after {
  width: 22px;
  height: 2px;
  display: block;
  border-radius: 999px;
  background: #b3b3b1;
  content: "";
}

.ai-native-menu-button span {
  position: relative;
}

.ai-native-menu-button span::before,
.ai-native-menu-button span::after {
  position: absolute;
  left: 0;
}

.ai-native-menu-button span::before {
  top: -7px;
}

.ai-native-menu-button span::after {
  top: 7px;
}

.ai-native-plus-button {
  border: 0;
  background: transparent;
  font-size: 38px;
  line-height: 1;
}

.ai-native-panel__header > div,
.ai-native-status {
  display: none;
}

.ai-native-history {
  position: absolute;
  z-index: 8;
  left: 54px;
  top: 112px;
  bottom: 28px;
  width: min(404px, calc(100vw - var(--sidebar-width) - 108px));
  padding: 34px 30px;
  overflow: hidden;
  border: 1px solid #6c6c6c;
  border-radius: 8px;
  background: #202020;
  opacity: 0;
  pointer-events: none;
  transform: translateX(-18px);
  transition: opacity 160ms ease, transform 160ms ease;
}

.ai-native-shell.is-history-open .ai-native-history {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

.ai-native-history__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.ai-native-history__header p {
  margin: 30px 0 0;
  color: #b3b3b1;
  font-size: 18px;
}

.ai-native-history__header h2 {
  margin: 22px 0 0;
  color: #ffffff;
  font-size: 26px;
  font-weight: 400;
}

.ai-native-action {
  min-height: 34px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  color: #ffffff;
  font-size: 0;
}

.ai-native-action::before {
  content: "New Chat";
  font-size: 26px;
  line-height: 1;
}

.ai-native-history__meta {
  display: none;
}

.ai-native-history__list {
  margin-top: 12px;
  gap: 0;
}

.ai-native-history-item,
.ai-native-history-item.is-active {
  padding: 0;
  background: transparent;
}

.ai-native-history-item__select {
  min-height: 34px;
}

.ai-native-history-item__select strong {
  color: #ffffff;
  font-size: 24px;
  font-weight: 400;
}

.ai-native-history-item__select span {
  display: none;
}

.ai-native-history-item__delete {
  width: auto;
  height: 32px;
  min-width: 74px;
  padding: 0 10px;
  border: 1px solid #6c6c6c;
  border-radius: 5px;
  background: #181818;
  color: #ffffff;
  font-size: 14px;
  opacity: 0;
  pointer-events: none;
}

.ai-native-history-item.has-delete .ai-native-history-item__delete {
  opacity: 1;
  pointer-events: auto;
}

.ai-native-thread {
  height: calc(100vh - 210px);
  padding: 0 34px 54px;
}

.ai-native-message {
  max-width: 644px;
}

.ai-native-message__body {
  padding: 22px 44px;
  border-radius: 60px;
  background: #363636;
  color: #ffffff;
  font-size: 22px;
}

.ai-native-composer {
  width: min(582px, calc(100vw - var(--sidebar-width) - 120px));
  min-height: 50px;
  margin: 0 70px 0 auto;
  padding: 5px 6px 5px 28px;
}

.request-actions button:disabled,
.task-action:disabled {
  opacity: 1;
  cursor: default;
}

/* The supplied screens are desktop designs; keep desktop structure even in a narrow browser. */
.app-shell {
  min-width: 1200px;
  display: grid;
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
}

.mobile-menu-button,
.sidebar-overlay {
  display: none !important;
}

.sidebar {
  position: sticky !important;
  top: 0;
  z-index: 2;
  transform: none !important;
  width: var(--sidebar-width);
  min-width: var(--sidebar-width);
  max-width: var(--sidebar-width);
}

body[data-active-view="dashboard"] .main-stage,
body[data-active-view="tasks"] .main-stage,
body[data-active-view="integrations"] .main-stage {
  padding: 22px 28px 24px 84px;
}

body[data-active-view="ai"] .main-stage,
body[data-active-view="chat"] .main-stage {
  padding: 0;
}

.view-panel--board {
  max-width: none;
}

.dashboard-overview {
  width: min(100%, 1580px);
  gap: 26px;
}

.dashboard-figma-top {
  display: grid;
  grid-template-columns: minmax(560px, 1fr) 520px;
  gap: 34px;
  min-height: 350px;
}

.dashboard-hero-copy {
  padding-top: 18px;
}

.dashboard-hero-copy h3 {
  margin-bottom: 82px;
  font-size: clamp(42px, 4.2vw, 70px);
}

.dashboard-hero-copy span {
  max-width: 900px;
  font-size: clamp(22px, 2.1vw, 36px);
  line-height: 1.22;
}

.dashboard-new-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.dashboard-new-card {
  min-height: 176px;
  border-radius: 3px;
}

.dashboard-new-icon {
  width: 64px;
  height: 64px;
}

.dashboard-new-card strong {
  font-size: 20px;
}

.dashboard-main-grid--figma {
  grid-template-columns: minmax(720px, 1fr) 286px;
  gap: 18px;
}

.dashboard-task-board__head,
.section-head {
  min-height: 66px;
  padding: 18px 34px;
}

.dashboard-task-board__head h3,
.section-head h1,
.section-head h2,
.dashboard-task-panel-head h4 {
  font-size: 30px;
}

.dashboard-task-board__requests {
  grid-template-columns: minmax(0, 1fr);
  padding: 24px;
}

.dashboard-request-card,
.request-card {
  min-height: 164px;
  padding: 26px 30px 0;
}

.dashboard-request-card h4,
.request-card h3 {
  font-size: 24px;
  font-weight: 400;
}

.dashboard-task-panel-head {
  min-height: 70px;
  padding: 14px 38px;
}

.dashboard-task-row,
.task-row {
  grid-template-columns: 120px 44px minmax(0, 1fr) auto;
  min-height: 74px;
  padding: 0 30px;
}

.dashboard-task-row span:last-of-type,
.task-title {
  font-size: 28px;
}

.dashboard-task-priority,
.task-priority {
  font-size: 18px;
}

.task-bullet {
  width: 22px;
  height: 22px;
}

.request-panel,
.status-panel {
  max-width: 1360px;
  margin-left: 0;
}

.request-panel {
  margin-top: 20px;
}

.status-panel {
  margin-top: 12px;
}

.request-grid {
  grid-template-columns: minmax(0, 1fr);
}

.integrations-overview {
  max-width: 1120px;
  margin-left: 0;
  gap: 24px;
}

.integrations-overview h1,
.integrations-overview h2 {
  font-size: 38px;
}

.integration-connected-grid {
  grid-template-columns: repeat(2, 292px);
  gap: 12px;
}

.integration-explore-grid {
  grid-template-columns: repeat(3, 292px);
  gap: 12px;
}

.integration-icon-tile {
  min-height: 164px;
}

.integration-glyph {
  width: 72px;
  height: 72px;
}

.integration-coming-grid {
  grid-template-columns: repeat(4, 218px);
  gap: 14px 10px;
}

.integration-coming-grid article {
  min-height: 122px;
}

.integration-coming-grid span {
  width: 42px;
  height: 42px;
}

.integration-coming-grid strong {
  font-size: 18px;
}

/* Desktop fidelity pass for the supplied Figma SVG exports. */
@media (min-width: 901px) {
  .view-panel--board {
    max-width: none;
  }

  .dashboard-overview {
    width: min(100%, 1580px);
    display: flex;
    flex-direction: column;
    gap: 26px;
  }

  .dashboard-figma-top {
    grid-template-columns: minmax(560px, 1fr) 520px;
    gap: 34px;
    min-height: 350px;
    align-items: start;
  }

  .dashboard-hero-copy {
    padding-top: 18px;
  }

  .dashboard-hero-copy h3 {
    margin-bottom: 82px;
    font-size: clamp(42px, 4.2vw, 70px);
    letter-spacing: 0;
  }

  .dashboard-hero-copy span {
    max-width: 900px;
    font-size: clamp(22px, 2.1vw, 36px);
    line-height: 1.22;
  }

  .dashboard-new-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .dashboard-new-card {
    min-height: 176px;
    border-radius: 3px;
  }

  .dashboard-new-icon {
    width: 64px;
    height: 64px;
  }

  .dashboard-new-card strong {
    font-size: 20px;
  }

  .dashboard-main-grid--figma {
    grid-template-columns: minmax(720px, 1fr) 286px;
    gap: 18px;
  }

  .dashboard-task-board__head,
  .section-head {
    min-height: 66px;
    padding: 18px 34px;
  }

  .dashboard-task-board__head h3,
  .section-head h1,
  .section-head h2,
  .dashboard-task-panel-head h4 {
    font-size: 30px;
  }

  .dashboard-task-board__requests {
    grid-template-columns: minmax(0, 1fr);
    padding: 24px;
  }

  .dashboard-request-card,
  .request-card {
    min-height: 164px;
    padding: 26px 30px 0;
  }

  .dashboard-request-card h4,
  .request-card h3 {
    font-size: 24px;
    font-weight: 400;
  }

  .dashboard-task-panel-head {
    min-height: 70px;
    padding: 14px 38px;
  }

  .dashboard-task-row,
  .task-row {
    grid-template-columns: 120px 44px minmax(0, 1fr) auto;
    min-height: 74px;
    padding: 0 30px;
  }

  .dashboard-task-row span:last-of-type,
  .task-title {
    font-size: 28px;
  }

  .dashboard-task-priority,
  .task-priority {
    font-size: 18px;
  }

  .task-bullet {
    width: 22px;
    height: 22px;
  }

  .dashboard-calendar-card,
  .dashboard-up-next-card {
    border-radius: 3px;
  }

  .dashboard-calendar-card {
    min-height: 300px;
  }

  .dashboard-up-next-card {
    min-height: 304px;
  }

  .request-panel,
  .status-panel {
    max-width: 1360px;
    margin-left: 64px;
  }

  .request-panel {
    margin-top: 28px;
  }

  .status-panel {
    margin-top: 12px;
  }

  .request-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .integrations-overview {
    max-width: 1120px;
    margin-left: 4px;
    gap: 24px;
  }

  .integrations-overview h1,
  .integrations-overview h2 {
    font-size: 38px;
  }

  .integration-connected-grid {
    grid-template-columns: repeat(2, 292px);
    gap: 12px;
  }

  .integration-explore-grid {
    grid-template-columns: repeat(3, 292px);
    gap: 12px;
  }

  .integration-icon-tile {
    min-height: 164px;
  }

  .integration-glyph {
    width: 72px;
    height: 72px;
  }

  .integration-coming-grid {
    grid-template-columns: repeat(4, 218px);
    gap: 14px 10px;
  }

  .integration-coming-grid article {
    min-height: 122px;
  }

  .integration-coming-grid span {
    width: 42px;
    height: 42px;
  }

  .integration-coming-grid strong {
    font-size: 18px;
  }
}

.toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  position: relative;
}

.toolbar-plus,
.page-action {
  min-width: 34px;
  height: 34px;
  padding: 0 14px;
  border-radius: 10px;
  border: 1px solid var(--border-strong);
  background: var(--panel-soft);
  color: var(--white);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  white-space: nowrap;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 160ms ease;
}

.page-action:hover {
  border-color: rgba(255, 255, 255, 0.18);
  transform: translateY(-1px);
}

.page-action--danger {
  color: #ffd9de;
  border-color: rgba(255, 91, 107, 0.28);
}

.page-action--primary {
  background: #f4f4f3;
  color: #111111;
}

.page-action[aria-expanded="true"] {
  background: #f4f4f3;
  color: #111111;
}

.calendar-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: calc(100vh - 52px);
}

.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.calendar-header p {
  margin: 0 0 6px;
  color: var(--text-muted);
  font-size: 14px;
}

.calendar-header h2 {
  margin: 0;
  color: var(--white);
  font-size: clamp(26px, 2vw, 36px);
}

.calendar-header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.calendar-theme-picker {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 38px;
  padding: 0 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  background: #181818;
}

.calendar-theme-swatch {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 2px solid transparent;
  background: var(--swatch-color, var(--calendar-accent));
  cursor: pointer;
}

.calendar-theme-swatch[data-calendar-theme="#31e981"] {
  --swatch-color: #31e981;
}

.calendar-theme-swatch[data-calendar-theme="#63e2fe"] {
  --swatch-color: #63e2fe;
}

.calendar-theme-swatch[data-calendar-theme="#b450ff"] {
  --swatch-color: #b450ff;
}

.calendar-theme-swatch[data-calendar-theme="#ff7cf0"] {
  --swatch-color: #ff7cf0;
}

.calendar-theme-swatch[data-calendar-theme="#e7d44d"] {
  --swatch-color: #e7d44d;
}

.calendar-theme-swatch.is-active {
  border-color: var(--white);
  box-shadow: 0 0 0 3px rgba(var(--calendar-accent-rgb), 0.18);
}

.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
}

.calendar-weekdays span {
  padding: 0 8px;
  color: var(--text-soft);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
  grid-auto-rows: minmax(112px, 1fr);
  flex: 1;
}

.calendar-day {
  min-height: 112px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: #181818;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  text-align: left;
  cursor: pointer;
  min-width: 0;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.calendar-day:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.12);
  background: #1d1d1d;
}

.calendar-day.is-outside {
  opacity: 0.42;
}

.calendar-day.is-today {
  border-color: rgba(var(--calendar-accent-rgb), 0.48);
  box-shadow: inset 0 0 0 1px rgba(var(--calendar-accent-rgb), 0.18);
}

.calendar-day__number {
  color: var(--white);
  font-size: 16px;
  font-weight: 700;
}

.calendar-day__items {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.calendar-pill {
  display: block;
  padding: 6px 8px;
  border-radius: 10px;
  color: var(--white);
  font-size: 11px;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-pill--task {
  background: rgba(0, 185, 217, 0.18);
}

.calendar-pill--event {
  background: rgba(var(--calendar-accent-rgb), 0.2);
  border: 1px solid rgba(var(--calendar-accent-rgb), 0.24);
}

.notification-dot {
  position: absolute;
  top: 7px;
  right: 7px;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #ff4d5b;
  box-shadow: 0 0 0 2px #181818;
}

.notification-list {
  display: grid;
  gap: 18px;
}

.notification-group {
  display: grid;
  gap: 10px;
}

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

.notification-group__header h3,
.notification-group__header p {
  margin: 0;
}

.notification-group__header h3 {
  color: var(--white);
  font-size: 18px;
}

.notification-group__header p {
  color: var(--text-soft);
  font-size: 13px;
}

.notification-group__count {
  min-width: 32px;
  height: 32px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  font-size: 12px;
  font-weight: 700;
}

.notification-card {
  width: 100%;
  padding: 16px;
  border-radius: 18px;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.08), transparent 34%),
    #1a1a1a;
  border: 1px solid #2a2a2a;
  text-align: left;
  cursor: pointer;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.notification-card:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.16);
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.12), transparent 34%),
    #1f1f1f;
}

.notification-card.is-unread {
  border-color: rgba(255, 77, 91, 0.35);
  box-shadow: inset 0 0 0 1px rgba(255, 77, 91, 0.1);
}

.notification-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.notification-card__tag {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-soft);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.notification-card__chevron {
  color: var(--text-muted);
  font-size: 18px;
}

.notification-card strong {
  display: block;
  margin-bottom: 6px;
  color: var(--white);
}

.notification-card p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.5;
}

.notification-card__meta {
  margin-top: 12px;
  color: var(--text-muted);
  font-size: 12px;
}

.notification-empty {
  padding: 28px 24px;
  border-radius: 20px;
  border: 1px dashed rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.02);
}

.notification-empty h3,
.notification-empty p {
  margin: 0;
}

.notification-empty h3 {
  margin-bottom: 8px;
  color: var(--white);
}

.notification-empty p {
  color: var(--text-soft);
  line-height: 1.5;
}

.toolbar-plus {
  width: 34px;
  padding: 0;
  font-size: 20px;
}

.tasks-add-menu {
  position: absolute;
  top: 42px;
  right: 0;
  width: 196px;
  padding: 8px;
  border: 1px solid #323232;
  border-radius: 14px;
  background: #1a1a1a;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.34);
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 10;
}

.request-panel,
.promoted-task-panel,
.status-panel,
.summary-card,
.placeholder-panel,
.embed-shell {
  background: var(--panel);
  border: 1px solid rgba(46, 46, 46, 0.69);
  border-radius: 19px;
}

.request-panel {
  padding: 18px 18px 20px;
  background:
    radial-gradient(circle at top left, rgba(58, 58, 58, 0.28), transparent 38%),
    var(--panel);
}

.promoted-task-panel {
  margin-top: 14px;
  padding: 18px 18px 20px;
  background:
    radial-gradient(circle at top right, rgba(231, 212, 77, 0.16), transparent 34%),
    var(--panel);
}

.section-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}

.section-head h1,
.section-head h2 {
  margin: 0;
  color: var(--white);
  font-size: clamp(22px, 1.7vw, 32px);
  font-weight: 600;
}

.count-badge {
  min-width: 32px;
  height: 32px;
  padding: 0 10px;
  border-radius: 12px;
  background: var(--panel-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  font-size: 16px;
  font-weight: 600;
}

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

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

.promoted-task-card {
  min-height: 188px;
  padding: 22px;
  border-radius: 18px;
  border: 1px solid rgba(231, 212, 77, 0.2);
  background:
    linear-gradient(180deg, rgba(231, 212, 77, 0.08), rgba(255, 255, 255, 0.02)),
    var(--panel-soft);
  display: flex;
  flex-direction: column;
  cursor: pointer;
}

.promoted-task-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--text-soft);
  font-size: 13px;
}

.promoted-task-card h3 {
  margin: 20px 0;
  color: var(--white);
  font-size: clamp(24px, 2vw, 38px);
  line-height: 1.08;
  font-weight: 600;
}

.promoted-task-card__actions {
  margin-top: auto;
  display: flex;
  justify-content: flex-end;
}

.request-card {
  min-height: 210px;
  padding: 20px 22px 18px;
  border-radius: 20px;
  background: var(--panel-soft);
  display: flex;
  flex-direction: column;
  cursor: pointer;
}

.request-card h3 {
  margin: 0 0 22px;
  font-size: clamp(18px, 1.2vw, 26px);
  font-weight: 400;
  color: var(--text-soft);
}

.request-tag {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 10px;
  font-size: 14px;
}

.request-tag--cyan {
  background: rgba(0, 185, 217, 0.14);
  color: var(--cyan);
}

.request-tag--purple {
  background: rgba(180, 80, 255, 0.14);
  color: var(--purple);
}

.request-meta,
.request-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-top: auto;
  border-top: 1px solid var(--border-strong);
}

.request-meta div,
.request-actions button {
  padding-top: 14px;
}

.request-meta div:last-child,
.request-actions button:last-child {
  text-align: right;
}

.request-actions {
  margin-top: 12px;
}

.request-actions button {
  border-top: 1px solid var(--border-strong);
  cursor: pointer;
  font-size: 14px;
}

.request-actions button:first-child {
  color: var(--green);
  border-right: 1px solid var(--border-strong);
  text-align: center;
}

.request-actions button:last-child {
  color: var(--red);
  text-align: center;
}

.request-meta span,
.task-priority {
  font-size: 13px;
  color: var(--text-soft);
}

.status-panel {
  margin-top: 14px;
  overflow: hidden;
}

.status-panel--progress {
  background:
    linear-gradient(180deg, rgba(32, 32, 32, 0.68), rgba(24, 24, 24, 1) 18%),
    var(--panel);
}

.status-panel .section-head {
  padding: 16px 18px 0;
}

.task-list {
  display: flex;
  flex-direction: column;
}

.task-row {
  display: grid;
  grid-template-columns: 110px 26px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  border-top: 1px solid var(--border-strong);
  cursor: pointer;
  transition: background 180ms ease;
}

.task-row:hover,
.task-row:focus-visible,
.dashboard-task-row:hover,
.dashboard-task-row:focus-visible,
.request-card:hover,
.request-card:focus-visible,
.promoted-task-card:hover,
.promoted-task-card:focus-visible,
.dashboard-request-card:hover,
.dashboard-request-card:focus-visible {
  background: rgba(255, 255, 255, 0.035);
  outline: none;
}

.task-bullet {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  justify-self: center;
  border: 2px solid currentColor;
}

.task-bullet--todo {
  color: var(--red);
}

.task-bullet--progress {
  color: var(--yellow);
  border-radius: 4px;
}

.task-bullet--done {
  color: var(--green);
  background: currentColor;
}

.task-title {
  font-size: clamp(16px, 1.1vw, 22px);
  color: var(--text);
}

.task-action {
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--border-strong);
  color: var(--text-soft);
  cursor: pointer;
  font-size: 13px;
}

.task-action:hover {
  background: var(--panel-muted);
}

.task-action:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.task-action:disabled:hover {
  background: transparent;
}

.task-promote.is-active {
  border-color: rgba(231, 212, 77, 0.34);
  color: #f1df61;
  background: rgba(231, 212, 77, 0.09);
}

.task-action--mini {
  min-height: 26px;
  padding: 0 8px;
  font-size: 10px;
}

.panel-header-copy {
  margin-bottom: 14px;
}

.dashboard-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
  position: relative;
}

.dashboard-header p {
  margin: 0 0 8px;
  color: var(--text-muted);
  font-size: 14px;
}

.dashboard-header h2 {
  margin: 0;
  color: var(--white);
  font-size: clamp(30px, 2.2vw, 52px);
  line-height: 1.05;
}

.dashboard-header-actions {
  display: flex;
  gap: 10px;
  position: relative;
}

.dashboard-add-menu {
  position: absolute;
  top: 44px;
  right: 112px;
  width: 210px;
  padding: 8px;
  border: 1px solid #323232;
  border-radius: 14px;
  background: #1a1a1a;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.34);
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 12;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}

.dashboard-overview {
  display: grid;
  grid-template-columns: minmax(280px, 400px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.dashboard-summary-panel,
.dashboard-tasks-embed {
  background: #1d1d1d;
  border: 1px solid #262626;
  border-radius: 24px;
}

.dashboard-summary-panel {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 22px;
}

.dashboard-summary-copy p,
.ai-summary-card p {
  margin: 0 0 6px;
  color: var(--text-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.dashboard-summary-copy h3,
.ai-summary-card h2 {
  margin: 0 0 10px;
  color: var(--white);
  font-size: clamp(26px, 2vw, 36px);
}

.dashboard-summary-copy span,
.ai-summary-card span {
  color: var(--text-soft);
  line-height: 1.6;
}

.dashboard-summary-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.dashboard-summary-metrics article {
  padding: 14px;
  border-radius: 18px;
  background: #161616;
  border: 1px solid #2a2a2a;
}

.dashboard-summary-metrics strong {
  display: block;
  margin-bottom: 6px;
  color: var(--white);
  font-size: 28px;
}

.dashboard-summary-metrics span {
  color: var(--text-muted);
  font-size: 12px;
}

.dashboard-summary-actions,
.ai-summary-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.dashboard-tasks-embed {
  padding: 18px;
}

.dashboard-embedded-board {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 16px;
}

.widget-card {
  position: relative;
  min-width: 0;
  padding: 16px;
  border-radius: 24px;
  background: #1d1d1d;
  border: 1px solid #262626;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.widget-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.widget-head p {
  margin: 0 0 6px;
  color: var(--text-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.widget-link-button {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid #333333;
  background: #202020;
  color: var(--text-soft);
  cursor: pointer;
}

.widget-card[data-size="tall"] {
  min-height: 460px;
}

.widget-card[data-size="medium"] {
  min-height: 250px;
}

.widget-card[data-size="short"] {
  min-height: 150px;
}

.widget-col-2 {
  grid-column: span 2;
}

.widget-col-3 {
  grid-column: span 3;
}

.widget-col-4 {
  grid-column: span 4;
}

.widget-col-5 {
  grid-column: span 5;
}

.widget-col-6 {
  grid-column: span 6;
}

.widget-card h3,
.widget-card h4 {
  margin: 0;
  color: var(--white);
}

.widget-card p {
  margin: 0;
}

.widget-edit-bar {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  gap: 6px;
}

.widget-edit-button {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid #353535;
  background: #232323;
  color: var(--text-soft);
  cursor: pointer;
}

.widget-section-label {
  margin-bottom: 10px;
  color: var(--text-muted);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dashboard-messages-widget {
  min-height: 430px;
  height: 100%;
  flex: 1;
  overflow: hidden;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 18%),
    #111111;
  border: 1px solid rgba(255, 255, 255, 0.05);
  padding: 18px;
}

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

.dashboard-message-panel {
  min-width: 0;
  padding: 14px;
  border-radius: 18px;
  background: #171717;
  border: 1px solid #262626;
}

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

.dashboard-message-card {
  width: 100%;
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 14px;
  background: #1f1f1f;
  color: var(--white);
  text-align: left;
  cursor: pointer;
}

.dashboard-message-copy {
  min-width: 0;
}

.dashboard-message-copy strong,
.dashboard-message-copy span {
  display: block;
}

.dashboard-message-copy span {
  margin-top: 3px;
  color: var(--text-muted);
  font-size: 12px;
}

.dashboard-message-groups,
.dashboard-message-thread {
  border-radius: 18px;
  background: #141414;
  padding: 12px;
}

.dashboard-message-group-list,
.dashboard-dm-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dashboard-message-chip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 28px;
  padding: 0 8px;
  border-radius: 999px;
  background: #1d1d1d;
  color: var(--white);
  font-size: 11px;
}

.dashboard-message-chip::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #fc554f;
  flex: 0 0 10px;
}

.dashboard-message-chip--group::before {
  width: 8px;
  height: 8px;
  border-radius: 2px;
  background: #7d7d7d;
}

.dashboard-thread-top,
.dashboard-thread-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.dashboard-thread-top {
  margin-bottom: 12px;
}

.dashboard-user-pill,
.dashboard-input-pill,
.dashboard-message-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: #202020;
  color: var(--white);
  font-size: 11px;
}

.dashboard-user-pill::before {
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: #fc554f;
}

.dashboard-thread-body {
  min-height: 300px;
}

.dashboard-learning-widget {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

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

.dashboard-learning-course {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  padding: 8px 0;
  border-bottom: 1px solid #282828;
}

.dashboard-learning-course:last-child {
  border-bottom: 0;
}

.dashboard-learning-course .course-icon {
  width: 28px;
  height: 28px;
}

.dashboard-learning-course .course-icon svg {
  width: 24px;
  height: 24px;
}

.dashboard-learning-course h4 {
  font-size: 12px;
}

.dashboard-learning-course p {
  color: var(--text-muted);
  font-size: 8px;
  line-height: 1.2;
}

.dashboard-open-pill {
  min-width: 54px;
  height: 20px;
  padding: 0 10px;
  border-radius: 999px;
  color: var(--white);
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
}

.dashboard-leaderboard-widget {
  display: flex;
  flex-direction: column;
  gap: 12px;
  height: 100%;
}

.dashboard-request-stack,
.dashboard-task-stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dashboard-request-stack--embedded,
.dashboard-task-widget--embedded {
  height: 100%;
}

.dashboard-request-card {
  min-height: 120px;
  padding: 14px;
  border-radius: 18px;
  background: #202020;
  cursor: pointer;
}

.dashboard-request-card h4 {
  margin-bottom: 12px;
  font-size: 18px;
  font-weight: 400;
}

.dashboard-request-meta,
.dashboard-request-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  color: var(--text-soft);
  font-size: 11px;
}

.dashboard-request-actions {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid #303030;
}

.dashboard-request-actions button {
  min-height: 32px;
  border-radius: 999px;
  background: #1b1b1b;
  cursor: pointer;
  text-align: center;
}

.dashboard-request-actions button:first-child {
  color: var(--green);
}

.dashboard-request-actions button:last-child {
  color: var(--red);
}

.dashboard-task-widget {
  display: flex;
  flex-direction: column;
  gap: 10px;
  height: 100%;
}

.dashboard-task-panel {
  border-radius: 16px;
  border: 1px solid #2b2b2b;
  overflow: hidden;
}

.dashboard-task-panel-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: #1f1f1f;
}

.dashboard-task-panel-head h4 {
  font-size: 13px;
}

.dashboard-mini-count {
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 6px;
  background: #2a2a2a;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
}

.dashboard-task-row {
  display: grid;
  grid-template-columns: 48px 16px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 8px 12px;
  border-top: 1px solid #282828;
  font-size: 10px;
  cursor: pointer;
}

.dashboard-task-priority {
  color: var(--text-soft);
}

.dashboard-ai-widget {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 100%;
  flex: 1;
  overflow: hidden;
  border-radius: 18px;
  background:
    radial-gradient(circle at top right, rgba(0, 185, 217, 0.1), transparent 34%),
    #111111;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.dashboard-ai-widget h3 {
  font-size: 18px;
}

.dashboard-ai-preview {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
  flex: 1;
  min-height: 220px;
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.dashboard-ai-message {
  max-width: 360px;
  padding: 16px 18px;
  border-radius: 24px;
  background: #2f2f2f;
}

.dashboard-ai-message strong {
  display: block;
  margin-bottom: 8px;
}

.dashboard-ai-message p {
  color: var(--text-soft);
  line-height: 1.45;
}

.dashboard-ai-prompt {
  min-height: 54px;
  width: 100%;
  padding: 0 18px;
  border-radius: 999px;
  background: #181818;
  border: 1px solid #4c4c4c;
  color: #8c8c8c;
  text-align: left;
  cursor: pointer;
}

.dashboard-overview {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.dashboard-hero-panel,
.dashboard-calendar-card,
.dashboard-tasks-embed,
.dashboard-messages-widget,
.dashboard-ai-widget {
  border-radius: 20px;
}

.dashboard-hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 18px;
  padding: 22px;
  background:
    linear-gradient(135deg, rgba(49, 233, 129, 0.11), transparent 34%),
    #1d1d1d;
  border: 1px solid #262626;
}

.dashboard-hero-copy p,
.dashboard-calendar-card p {
  margin: 0 0 6px;
  color: var(--text-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.dashboard-hero-copy h3 {
  margin: 0 0 10px;
  color: var(--white);
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.08;
}

.dashboard-hero-copy span {
  display: block;
  max-width: 820px;
  color: var(--text-soft);
  line-height: 1.55;
}

.dashboard-hero-actions,
.dashboard-calendar-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.dashboard-metric-strip {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.dashboard-metric-card {
  width: 100%;
  min-width: 0;
  min-height: 92px;
  padding: 16px;
  border-radius: 18px;
  background: #1b1b1b;
  border: 1px solid #262626;
  text-align: left;
  cursor: pointer;
}

.dashboard-metric-card:hover,
.dashboard-upcoming-item:hover,
.dashboard-calendar-day:hover {
  border-color: rgba(255, 255, 255, 0.16);
  background: #202020;
}

.dashboard-metric-card span {
  display: block;
  margin-bottom: 8px;
  color: var(--text-muted);
  font-size: 12px;
}

.dashboard-metric-card strong {
  color: var(--white);
  font-size: 34px;
  line-height: 1;
}

.dashboard-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 16px;
  align-items: start;
}

.dashboard-primary-stack,
.dashboard-side-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.dashboard-calendar-card {
  padding: 18px;
  background: #1d1d1d;
  border: 1px solid #262626;
}

.dashboard-calendar-weekdays,
.dashboard-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.dashboard-calendar-weekdays {
  margin-top: 14px;
}

.dashboard-calendar-weekdays span {
  color: var(--text-muted);
  font-size: 11px;
  text-align: center;
}

.dashboard-calendar-grid {
  margin-top: 8px;
}

.dashboard-calendar-day {
  aspect-ratio: 1;
  min-width: 0;
  padding: 8px;
  border-radius: 12px;
  border: 1px solid #292929;
  background: #181818;
  color: var(--text);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  cursor: pointer;
}

.dashboard-calendar-day.is-outside {
  opacity: 0.38;
}

.dashboard-calendar-day.is-today {
  border-color: rgba(var(--calendar-accent-rgb), 0.58);
  box-shadow: inset 0 0 0 1px rgba(var(--calendar-accent-rgb), 0.16);
}

.dashboard-calendar-day span {
  font-size: 12px;
  font-weight: 700;
}

.dashboard-calendar-day strong {
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: rgba(0, 185, 217, 0.2);
  color: var(--white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
}

.dashboard-upcoming-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.dashboard-upcoming-item {
  min-width: 0;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid #292929;
  background: #181818;
  text-align: left;
  cursor: pointer;
}

.dashboard-upcoming-item span,
.dashboard-upcoming-item small {
  display: block;
  color: var(--text-muted);
  font-size: 11px;
}

.dashboard-upcoming-item strong {
  display: block;
  margin: 4px 0;
  color: var(--white);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dashboard-empty-note {
  grid-column: 1 / -1;
  margin: 0;
  padding: 14px;
  border-radius: 14px;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  color: var(--text-soft);
}

.panel-header-copy p,
.embed-head p,
.placeholder-panel p {
  margin: 0 0 8px;
  color: var(--text-muted);
  font-size: 14px;
}

.panel-header-copy h2,
.embed-head h2,
.placeholder-panel h2 {
  margin: 0;
  color: var(--white);
  font-size: clamp(24px, 1.5vw, 34px);
}

.summary-grid,
.placeholder-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.summary-card,
.placeholder-grid article {
  padding: 18px;
}

.summary-card span,
.placeholder-grid strong {
  display: block;
  color: var(--text-muted);
  margin-bottom: 10px;
}

.summary-card strong {
  display: block;
  color: var(--white);
  font-size: 19px;
  margin-bottom: 12px;
}

.summary-card p,
.placeholder-grid span {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.5;
}

.embed-shell,
.placeholder-panel {
  padding: 18px;
}

.ai-native-shell {
  min-height: calc(100vh - 48px);
  display: grid;
  grid-template-columns: var(--rail-width) minmax(0, 1fr);
  gap: 14px;
}

.ai-native-history,
.ai-native-panel {
  min-width: 0;
  border-radius: 24px;
  background: #1a1a1a;
  border: 1px solid #262626;
}

.ai-native-history {
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.ai-native-history__header,
.ai-native-panel__header,
.ai-native-history-item {
  display: flex;
  align-items: center;
}

.ai-native-history__header,
.ai-native-panel__header {
  justify-content: space-between;
  gap: 12px;
}

.ai-native-history__header p,
.ai-native-panel__header p {
  margin: 0 0 6px;
  color: var(--text-muted);
  font-size: 13px;
}

.ai-native-history__header h2,
.ai-native-panel__header h2 {
  margin: 0;
  color: var(--white);
  font-size: clamp(24px, 1.5vw, 32px);
}

.ai-native-history__meta,
.ai-native-status,
.ai-native-history-item span,
.ai-native-message__meta,
.ai-native-empty p {
  color: var(--text-soft);
}

.ai-native-action,
.ai-native-send {
  height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  background: #f4f4f3;
  color: #111111;
  cursor: pointer;
  transition: transform 160ms ease, opacity 160ms ease;
}

.ai-native-action:hover,
.ai-native-send:hover:not(:disabled) {
  transform: translateY(-1px);
}

.ai-native-send:disabled {
  opacity: 0.45;
  cursor: default;
}

.ai-native-history__list {
  min-height: 0;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ai-native-history-item {
  gap: 8px;
  padding: 8px;
  border-radius: 18px;
  background: transparent;
}

.ai-native-history-item.is-active {
  background: #232323;
}

.ai-native-history-item__select,
.ai-native-history-item__delete {
  cursor: pointer;
}

.ai-native-history-item__select {
  flex: 1;
  min-width: 0;
  text-align: left;
}

.ai-native-history-item__select strong,
.ai-native-message__meta {
  display: block;
}

.ai-native-history-item__select strong {
  color: var(--white);
  margin-bottom: 4px;
  font-size: 14px;
}

.ai-native-history-item__select span {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 12px;
}

.ai-native-history-item__delete {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  color: var(--text-soft);
}

.ai-native-history-item__delete:hover {
  background: #2b2b2b;
}

.ai-native-panel {
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.ai-native-thread {
  min-height: 0;
  height: calc(100vh - 220px);
  overflow: auto;
  padding-right: 6px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.ai-native-empty {
  margin: auto 0;
  padding: 32px;
  border-radius: 24px;
  background: #171717;
  border: 1px solid #252525;
}

.ai-native-empty h3 {
  margin: 0 0 10px;
  color: var(--white);
  font-size: 28px;
}

.ai-native-empty p {
  margin: 0;
  line-height: 1.6;
}

.ai-native-message {
  max-width: 760px;
}

.ai-native-message--user {
  align-self: flex-end;
}

.ai-native-message--assistant {
  align-self: flex-start;
}

.ai-native-message__logo {
  display: none;
}

.ai-native-message__meta {
  margin-bottom: 8px;
  font-size: 12px;
}

.ai-native-message__body {
  padding: 14px 18px;
  border-radius: 22px;
  background: #242424;
  color: var(--text);
  line-height: 1.55;
  border: 1px solid rgba(255, 255, 255, 0.04);
}

.ai-native-message--assistant .ai-native-message__body {
  background: #171717;
}

.ai-native-message__body p {
  margin: 0 0 12px;
}

.ai-native-message__body p:last-child {
  margin-bottom: 0;
}

.ai-native-message__body.is-streaming::after {
  content: none !important;
}

.ai-native-composer {
  display: flex;
  align-items: flex-end;
  gap: 12px;
  padding: 12px;
  border-radius: 28px;
  background: #171717;
  border: 1px solid #282828;
}

.ai-native-composer__input {
  flex: 1;
}

.ai-native-composer textarea {
  width: 100%;
  min-height: 24px;
  max-height: 220px;
  border: 0;
  outline: 0;
  resize: none;
  background: transparent;
  color: var(--text);
  line-height: 1.55;
}

.ai-native-composer textarea::placeholder {
  color: #8b8b8a;
}

.chat-page {
  display: grid;
  grid-template-columns: 210px minmax(0, 1fr);
  min-height: 100vh;
  margin: 0;
  background: #141414;
  position: relative;
}

.chat-page:has(.chat-members-sidebar:not([hidden])) {
  grid-template-columns: 210px minmax(0, 1fr) 260px;
}

body[data-active-view="chat"] .main-stage {
  padding: 0;
}

body[data-active-view="chat"] .view-panel {
  min-height: 100vh;
}

.chat-rail,
.chat-thread-panel {
  min-width: 0;
}

.chat-rail {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 23px 12px 18px 16px;
  background: #515151;
}

.chat-rail-section {
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.chat-rail-head {
  display: flex;
  align-items: center;
  gap: 9px;
  height: 24px;
  color: var(--white);
}

.chat-rail-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  color: var(--white);
  font-size: 17px;
  font-weight: 600;
  line-height: 1;
  background: center / contain no-repeat url("./assets/kovo-group-513.svg");
}

.chat-rail-icon:not(.chat-rail-icon--dm) {
  color: transparent;
}

.chat-rail-icon--dm {
  border: 0;
  background-image: url("./assets/kovo-group-515.svg");
  position: relative;
}

.chat-rail-icon--dm::after {
  content: none;
}

.chat-rail-head h3 {
  margin: 0;
  color: var(--white);
  font-size: 15px;
  font-weight: 500;
}

.chat-rail-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.chat-list-item {
  width: 100%;
  min-height: 24px;
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 7px;
  align-items: center;
  padding: 0 8px 0 20px;
  border-radius: 5px;
  color: var(--white);
  text-align: left;
  cursor: pointer;
}

.chat-list-item.is-active {
  background: rgba(217, 217, 217, 0.91);
}

.chat-list-marker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  font-size: 20px;
  font-weight: 500;
  line-height: 1;
}

.chat-list-marker--dm {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #d9d9d9;
  color: #515151;
  font-size: 10px;
  font-weight: 800;
}

.chat-list-copy {
  min-width: 0;
}

.chat-list-copy strong {
  display: block;
  overflow: hidden;
  color: var(--white);
  font-size: 13px;
  font-weight: 500;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-thread-panel {
  display: flex;
  flex-direction: column;
  background: #141414;
  padding: 14px 17px 14px 20px;
}

.chat-thread-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  min-height: 86px;
}

.chat-channel-title {
  display: flex;
  align-items: center;
  gap: 4px;
  color: var(--white);
}

.chat-channel-title-icon {
  width: 18px;
  height: 18px;
  display: inline-block;
  background: center / contain no-repeat url("./assets/kovo-group-513.svg");
}

.chat-channel-title h2 {
  margin: 0;
  color: var(--white);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.2;
}

.chat-thread-actions {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
}

.chat-members-button {
  min-height: 24px;
  padding: 0 7px;
  border: 1px solid #e9e9e9;
  border-radius: 6px;
  color: var(--white);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 500;
}

.chat-more-button {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
}

.chat-options-popover {
  position: absolute;
  top: 32px;
  right: 0;
  z-index: 40;
  width: 178px;
  padding: 8px;
  border: 1px solid #383838;
  border-radius: 10px;
  background: #1f1f1f;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
  display: grid;
  gap: 4px;
}

.chat-options-popover button {
  min-height: 30px;
  padding: 0 10px;
  border-radius: 7px;
  color: var(--white);
  cursor: pointer;
  text-align: left;
  font-size: 12px;
}

.chat-options-popover button:hover {
  background: #303030;
}

.chat-thread-scroll {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 14px;
  overflow: auto;
  padding: 0 0 20px;
}

.chat-bubble {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 7px;
  align-items: start;
  max-width: 420px;
  border-radius: 9px;
  padding: 2px 4px 2px 0;
}

.chat-bubble.is-pinned {
  background: rgba(244, 244, 243, 0.06);
}

.chat-bubble.is-unread .chat-bubble-body {
  border-left: 3px solid #f4f4f3;
  padding-left: 8px;
}

.chat-bubble-avatar {
  width: 33px;
  height: 33px;
  display: inline-grid;
  place-items: center;
  border-radius: 7px;
  background: #d9d9d9;
  color: #515151;
  font-size: 12px;
  font-weight: 800;
}

.chat-bubble-body {
  min-width: 0;
}

.chat-bubble-meta {
  display: flex;
  align-items: baseline;
  gap: 54px;
  min-width: 0;
}

.chat-bubble-body strong {
  overflow: hidden;
  color: var(--white);
  font-size: 13px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-bubble-body time {
  flex: 0 0 auto;
  color: #bfbfbf;
  font-size: 8px;
}

.chat-bubble-body p {
  margin: 1px 0 0;
  overflow: hidden;
  color: var(--white);
  font-size: 13px;
  line-height: 1.25;
  text-overflow: ellipsis;
}

.chat-message-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 6px;
}

.chat-message-flags span {
  min-height: 17px;
  padding: 2px 6px;
  border-radius: 999px;
  background: #2b2b2b;
  color: #d7d7d7;
  font-size: 9px;
}

.chat-file-preview,
.chat-file-card {
  margin: 5px 0 0;
  width: min(260px, 100%);
  overflow: hidden;
  border-radius: 10px;
  background: #232323;
  border: 1px solid #3a3a3a;
}

.chat-file-preview img {
  display: block;
  width: 100%;
  max-height: 160px;
  object-fit: cover;
}

.chat-file-preview figcaption,
.chat-file-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px;
}

.chat-file-preview figcaption {
  justify-content: space-between;
}

.chat-file-preview strong,
.chat-file-card strong {
  display: block;
  color: var(--white);
  font-size: 12px;
}

.chat-file-preview span,
.chat-file-card small {
  color: #bfbfbf;
  font-size: 10px;
}

.chat-file-card__icon {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #d9d9d9;
}

.chat-composer {
  position: relative;
  display: grid;
  grid-template-rows: 30px 40px 34px;
  min-height: 104px;
  overflow: hidden;
  border-radius: 6px;
  background: #ffffff;
}

.chat-emoji-panel {
  position: absolute;
  left: 8px;
  bottom: 39px;
  z-index: 120;
  width: 214px;
  padding: 8px;
  border-radius: 12px;
  background: #1f1f1f;
  border: 1px solid #3b3b3b;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.34);
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 5px;
}

.chat-emoji-panel button {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 18px;
}

.chat-emoji-panel button:hover {
  background: #303030;
}

.chat-composer-toolbar {
  display: flex;
  align-items: center;
  gap: 21px;
  padding: 0 15px;
  background: #f4f4f4;
}

.chat-composer-toolbar button {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #cacaca;
  cursor: pointer;
  font-size: 17px;
}

.chat-composer-toolbar button.is-active {
  color: #141414;
}

.chat-format-underline {
  text-decoration: underline;
}

.chat-format-strike {
  text-decoration: line-through;
}

.chat-composer-entry {
  display: flex;
  align-items: center;
  padding: 0 14px;
}

.chat-composer input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: #141414;
  font-size: 13px;
  font-weight: 300;
}

.chat-composer input.is-bold {
  font-weight: 700;
}

.chat-composer input.is-italic {
  font-style: italic;
}

.chat-composer input.is-underlined {
  text-decoration: underline;
}

.chat-composer input.is-struck {
  text-decoration: line-through;
}

.chat-composer input::placeholder {
  color: #a6a6a7;
}

.chat-composer-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 8px;
}

.chat-composer-add,
.chat-composer-mention,
.chat-composer-emoji,
.chat-composer-send {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #242424;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
}

.chat-composer-add {
  border-radius: 999px;
  background: #e6e6e6;
  font-size: 24px;
  font-weight: 300;
}

.chat-composer-mention,
.chat-composer-emoji {
  border: 1px solid #242424;
  border-radius: 999px;
  font-size: 13px;
}

.chat-composer-send {
  position: absolute;
  right: 8px;
  bottom: 6px;
  width: 28px;
  height: 28px;
  z-index: 2;
  border-radius: 999px;
  background: #141414;
  color: #ffffff;
  transition: transform 160ms ease, background 160ms ease;
}

.chat-composer-send:hover {
  background: #303030;
  transform: translateY(-1px);
}

.chat-composer-send span {
  width: 0;
  height: 0;
  display: block;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 10px solid currentColor;
  transform: translateX(1px);
}

.chat-message-menu,
.chat-conversation-menu {
  position: fixed;
  z-index: 140;
  width: 154px;
  padding: 6px;
  border-radius: 10px;
  border: 1px solid #3a3a3a;
  background: #1f1f1f;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.42);
}

.chat-message-menu button,
.chat-conversation-menu button {
  width: 100%;
  min-height: 30px;
  padding: 0 9px;
  border-radius: 7px;
  color: var(--white);
  cursor: pointer;
  font-size: 12px;
  text-align: left;
}

.chat-message-menu button:hover,
.chat-conversation-menu button:hover {
  background: #303030;
}

.chat-members-sidebar {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px 14px;
  background: #202020;
  border-left: 1px solid #333333;
}

.chat-settings-modal {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: 20px;
}

.chat-settings-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.58);
}

.chat-settings-card {
  position: relative;
  z-index: 1;
  width: min(420px, 100%);
  max-height: min(560px, calc(100vh - 40px));
  overflow: auto;
  border-radius: 16px;
  background: #202020;
  border: 1px solid #3a3a3a;
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.45);
  color: var(--white);
}

.chat-settings-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 16px 12px;
  border-bottom: 1px solid #343434;
}

.chat-settings-head p,
.chat-settings-head h3,
.chat-settings-body p,
.chat-settings-body h4 {
  margin: 0;
}

.chat-settings-head p {
  color: #9a9a9a;
  font-size: 11px;
  text-transform: uppercase;
}

.chat-settings-head h3 {
  margin-top: 4px;
  font-size: 20px;
}

#chatSettingsClose {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #303030;
  color: var(--white);
  cursor: pointer;
  font-size: 20px;
}

.chat-settings-body {
  display: grid;
  gap: 12px;
  padding: 16px;
}

.chat-setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 54px;
  padding: 12px;
  border-radius: 12px;
  background: #171717;
  border: 1px solid #303030;
}

.chat-setting-row strong {
  display: block;
  margin-bottom: 4px;
  color: var(--white);
  font-size: 13px;
}

.chat-setting-row span,
.chat-settings-body p {
  color: #bfbfbf;
  font-size: 12px;
  line-height: 1.45;
}

.chat-setting-row input[type="checkbox"] {
  width: 42px;
  height: 24px;
  accent-color: #f4f4f3;
}

.chat-setting-list {
  display: grid;
  gap: 8px;
}

.chat-setting-pill {
  min-height: 34px;
  padding: 0 10px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #171717;
  border: 1px solid #303030;
  color: #d7d7d7;
  font-size: 12px;
}

.chat-members-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.chat-members-head p,
.chat-members-head h3,
.chat-invite-panel p {
  margin: 0;
}

.chat-members-head p {
  color: #858585;
  font-size: 11px;
  text-transform: uppercase;
}

.chat-members-head h3 {
  color: var(--white);
  font-size: 18px;
}

#chatMembersClose {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #303030;
  color: var(--white);
  cursor: pointer;
  font-size: 18px;
}

.chat-members-list {
  display: grid;
  gap: 8px;
}

.chat-member-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  min-height: 42px;
  padding: 6px;
  border-radius: 10px;
  background: #161616;
}

.chat-member-row span {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #d9d9d9;
  color: #202020;
  font-size: 12px;
  font-weight: 800;
}

.chat-member-row strong {
  overflow: hidden;
  color: var(--white);
  font-size: 13px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-members-actions {
  margin-top: auto;
  display: grid;
  gap: 10px;
}

#chatAddPeopleButton,
.chat-invite-panel button {
  min-height: 34px;
  border-radius: 8px;
  background: #f4f4f3;
  color: #141414;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
}

.chat-invite-panel {
  display: grid;
  gap: 9px;
  padding: 10px;
  border-radius: 12px;
  background: #161616;
  border: 1px solid #303030;
}

.chat-invite-panel label {
  display: grid;
  gap: 5px;
  color: #bfbfbf;
  font-size: 11px;
}

.chat-invite-panel input {
  width: 100%;
  height: 32px;
  border: 1px solid #3a3a3a;
  border-radius: 8px;
  outline: 0;
  padding: 0 9px;
  background: #101010;
  color: var(--white);
}

.chat-invite-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.chat-invite-panel p {
  min-height: 16px;
  color: #bfbfbf;
  font-size: 11px;
}

.ai-hub-shell {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.ai-summary-card {
  padding: 20px 22px;
  border-radius: 24px;
  background: #1d1d1d;
  border: 1px solid #262626;
}

.native-page {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.page-split-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.page-split-header p {
  margin: 0 0 8px;
  color: var(--text-muted);
  font-size: 14px;
}

.page-split-header h2 {
  margin: 0;
  color: var(--white);
  font-size: clamp(24px, 1.5vw, 34px);
}

.messages-layout,
.ai-layout {
  display: grid;
  grid-template-columns: var(--rail-width) minmax(0, 1fr);
  gap: 18px;
}

.messages-sidebar-card,
.messages-thread-card,
.ai-recents-card,
.ai-thread-card {
  background: var(--panel);
  border: 1px solid rgba(46, 46, 46, 0.69);
  border-radius: 20px;
  padding: 18px;
}

.messages-search,
.thread-composer-native,
.ai-composer-native {
  min-height: 42px;
  padding: 10px 14px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: var(--panel-soft);
  color: var(--text-muted);
}

.messages-list,
.ai-recents-list,
.thread-bubbles,
.ai-thread-messages {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
}

.messages-item,
.ai-recent-item {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: #1c1c1c;
  text-align: left;
  cursor: pointer;
}

.messages-item.is-active,
.ai-recent-item.is-active {
  border-color: #3a3a3a;
  background: #222222;
}

.messages-item strong,
.ai-recent-item {
  color: var(--white);
  font-size: 14px;
}

.messages-item span {
  display: block;
  margin-top: 4px;
  color: var(--text-muted);
  font-size: 12px;
}

.thread-header-native p {
  margin: 0 0 6px;
  color: var(--text-muted);
  font-size: 13px;
}

.thread-header-native h3,
.ai-recents-card h3 {
  margin: 0;
  color: var(--white);
  font-size: 20px;
}

.thread-bubble,
.ai-message {
  max-width: 72%;
  padding: 12px 14px;
  border-radius: 16px;
  background: #202020;
}

.thread-bubble--outgoing,
.ai-message--user {
  align-self: flex-end;
  background: #2a2a2a;
}

.thread-bubble strong,
.ai-message strong {
  display: block;
  margin-bottom: 6px;
  color: var(--white);
  font-size: 13px;
}

.thread-bubble p,
.ai-message p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.45;
}

.settings-page {
  max-width: 760px;
}

.settings-card--profile {
  width: 100%;
  margin-bottom: 18px;
}

.settings-profile-trigger {
  padding: 0;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  cursor: pointer;
  overflow: hidden;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.settings-profile-trigger:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.24);
  background: #252525;
}

.settings-profile-trigger span {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: inherit;
}

.settings-profile-hint {
  display: block;
  margin-top: 8px;
  color: var(--text-soft);
  font-size: 13px;
}

.settings-account-actions {
  display: flex;
  justify-content: flex-start;
  margin: -6px 0 18px;
}

.settings-sign-out-button {
  display: inline-flex;
  width: auto;
  min-width: 132px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 0;
}

.settings-form {
  display: grid;
  gap: 14px;
}

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

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

.settings-field input,
.settings-field select {
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: var(--panel-soft);
  color: var(--white);
}

.settings-field select {
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--text-soft) 50%),
    linear-gradient(135deg, var(--text-soft) 50%, transparent 50%);
  background-position: calc(100% - 18px) 19px, calc(100% - 12px) 19px;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

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

.embed-link {
  color: var(--text-soft);
  text-decoration: none;
}

.embed-link:hover {
  color: var(--white);
}

.callout {
  margin-bottom: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: #202020;
  color: var(--text-soft);
  font-size: 14px;
}

.app-frame {
  width: 100%;
  height: calc(100vh - 170px);
  min-height: 600px;
  border: 1px solid var(--border-strong);
  border-radius: 16px;
  background: #101010;
}

.learning-shell {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.learning-top {
  display: flex;
}

.learning-progress-card,
.learning-course-card,
.leaderboard-card,
.lesson-modal-card {
  background: #181818;
  border: 1px solid #2c2c2c;
}

.learning-progress-card {
  display: flex;
  align-items: center;
  gap: 20px;
  min-height: 120px;
  width: min(100%, 520px);
  padding: 20px 24px;
  border-radius: 24px;
}

.learning-ring {
  width: 82px;
  height: 82px;
  border-radius: 999px;
  background: conic-gradient(#3f3f3f 0deg, #292929 360deg);
  display: grid;
  place-items: center;
}

.learning-ring-inner {
  width: 62px;
  height: 62px;
  border-radius: 999px;
  background: var(--panel);
  display: grid;
  place-items: center;
}

.learning-ring-inner strong {
  color: var(--white);
  font-size: 22px;
}

.learning-progress-copy p {
  margin: 0 0 4px;
  color: #6d737f;
  font-size: 14px;
  font-weight: 700;
}

.learning-progress-copy h2 {
  margin: 0;
  color: var(--white);
  font-size: 28px;
  line-height: 1.15;
}

.learning-content-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

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

.learning-columns-head h3,
.leaderboard-card h3 {
  margin: 0 0 10px;
  color: var(--white);
  font-size: 18px;
  font-weight: 700;
}

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

.learning-course-card {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  min-height: 104px;
  padding: 20px 20px;
  border-radius: 18px;
}

.course-icon {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  color: var(--course-color, #63e2fe);
}

.course-icon svg {
  width: 42px;
  height: 42px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.course-copy h4 {
  margin: 0;
  color: var(--white);
  font-size: 18px;
  line-height: 1.1;
}

.course-copy p {
  margin: 6px 0 0;
  color: #6d737f;
  font-size: 11px;
  line-height: 1.35;
  max-width: 280px;
}

.course-open {
  min-width: 86px;
  height: 34px;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--course-color, #63e2fe);
  color: var(--white);
  font-weight: 700;
  cursor: pointer;
}

.leaderboard-card {
  padding: 20px;
  border-radius: 20px;
}

.leaderboard-podium {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
  margin: 18px 0 18px;
}

.podium-player {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: var(--white);
  font-size: 11px;
  text-align: center;
  flex: 1;
}

.podium-player--first {
  font-size: 14px;
}

.podium-player strong {
  font-size: inherit;
  line-height: 1.15;
}

.podium-player span:last-child {
  color: #bfc3cb;
  font-size: 11px;
}

.podium-orb {
  display: block;
  border-radius: 999px;
}

.podium-orb--orange {
  width: 34px;
  height: 34px;
  background: linear-gradient(180deg, #ff8d4d, #ff5030);
}

.podium-orb--blue {
  width: 50px;
  height: 50px;
  background: linear-gradient(180deg, #42e9d6, #5a51ff);
}

.podium-orb--green {
  width: 34px;
  height: 34px;
  background: linear-gradient(180deg, #8dff65, #38d889);
}

.leaderboard-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.leaderboard-list div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--white);
  font-size: 13px;
  padding: 10px 0;
}

.leaderboard-divider,
.leaderboard-list div + div {
  border-top: 1px solid #303030;
}

.leaderboard-rank {
  color: #bfc3cb;
}

.leaderboard-score {
  color: var(--white);
  font-weight: 700;
  white-space: nowrap;
}

.lesson-modal[hidden] {
  display: none;
}

.lesson-modal {
  position: fixed;
  inset: 0;
  z-index: 20;
}

.lesson-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.44);
  backdrop-filter: blur(6px);
}

.lesson-modal-card {
  position: relative;
  width: min(1240px, calc(100vw - 56px));
  margin: 58px auto;
  border-radius: 24px;
  background: #2a2a2a;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.45);
}

.lesson-modal-main {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 16px 28px;
  padding: 22px 38px 34px;
}

.lesson-modal-copy h2 {
  margin: 0 0 10px;
  color: var(--white);
  font-size: 22px;
}

.event-modal[hidden] {
  display: none;
}

.event-modal {
  position: fixed;
  inset: 0;
  z-index: 24;
}

.task-modal[hidden] {
  display: none;
}

.task-modal {
  position: fixed;
  inset: 0;
  z-index: 25;
}

.event-modal-card {
  position: relative;
  width: min(560px, calc(100vw - 32px));
  margin: 74px auto;
  padding: 20px;
  border-radius: 24px;
  background: #1a1a1a;
  border: 1px solid #2c2c2c;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.45);
}

.task-modal-card {
  position: relative;
  width: min(560px, calc(100vw - 32px));
  margin: 74px auto;
  padding: 20px;
  border-radius: 24px;
  background: #1a1a1a;
  border: 1px solid #2c2c2c;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.45);
}

.event-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.event-modal-head p {
  margin: 0 0 6px;
  color: var(--text-muted);
  font-size: 14px;
}

.event-modal-head h2 {
  margin: 0;
  color: var(--white);
  font-size: 28px;
}

.event-close {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: #232323;
  color: var(--white);
  font-size: 24px;
  line-height: 1;
}

.event-form {
  display: grid;
  gap: 14px;
}

.task-modal-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.task-delete-button {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 8px;
  border: 1px solid rgba(255, 91, 107, 0.38);
  color: var(--red);
  cursor: pointer;
}

.task-delete-button:hover {
  background: rgba(255, 91, 107, 0.1);
}

.lesson-xp-summary {
  margin: 0 0 12px;
  color: #bfc3cb;
  font-size: 13px;
}

.lesson-copy-block {
  margin-top: 18px;
}

.lesson-copy-block h4 {
  margin: 0 0 6px;
  color: var(--white);
  font-size: 15px;
  font-weight: 500;
}

.lesson-copy-block p {
  margin: 0;
  color: var(--white);
  opacity: 0.92;
  font-size: 14px;
  line-height: 1.45;
}

.lesson-copy-block--last {
  margin-top: 54px;
}

.lesson-questions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px 28px;
}

.lesson-question {
  padding-top: 10px;
}

.lesson-question h5 {
  margin: 0 0 8px;
  color: var(--white);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
}

.lesson-options {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.lesson-option {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 34px;
  padding: 0 10px;
  border: 1px solid transparent;
  border-radius: 10px;
  background: #242424;
  color: var(--white);
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

.lesson-option span:first-child {
  width: 8px;
  height: 8px;
  background: #d9d9d9;
}

.lesson-option:hover {
  border-color: #4a4a4a;
  transform: translateY(-1px);
}

.lesson-option.is-selected {
  border-color: #5b5b5b;
}

.lesson-option.is-correct {
  border-color: rgba(49, 233, 129, 0.7);
  background: rgba(49, 233, 129, 0.12);
}

.lesson-option.is-wrong {
  border-color: rgba(255, 91, 107, 0.7);
  background: rgba(255, 91, 107, 0.12);
}

.lesson-option-label {
  flex: 0 0 auto;
  color: #d9d9d9;
  text-transform: lowercase;
}

.lesson-option-text {
  min-width: 0;
  line-height: 1.35;
}

.lesson-close {
  position: absolute;
  right: 14px;
  bottom: 14px;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: #343434;
  cursor: pointer;
}

.settings-card {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-top: 16px;
  padding: 14px;
  width: fit-content;
  background: var(--panel-soft);
  border-radius: 24px;
}

.discord-page {
  min-height: calc(100vh - 36px);
  padding: 4px 0 24px;
}

.discord-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
  padding: 18px;
  border: 1px solid var(--border-strong);
  border-radius: 20px;
  background: #181818;
}

.discord-integration-tile {
  width: min(620px, 100%);
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 18px;
  margin-bottom: 16px;
  border: 1px solid var(--border-strong);
  border-radius: 18px;
  background: #191919;
  cursor: pointer;
  text-align: left;
  transition: border-color 180ms ease, background 180ms ease, transform 160ms ease;
}

.discord-integration-tile:hover {
  border-color: rgba(255, 255, 255, 0.18);
  background: #202020;
  transform: translateY(-1px);
}

.discord-tile-icon {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: #5865f2;
  color: #ffffff;
  font-weight: 800;
}

.discord-tile-copy {
  min-width: 0;
  display: grid;
  gap: 5px;
}

.discord-tile-copy strong {
  color: var(--white);
  font-size: 18px;
}

.discord-tile-copy small {
  color: var(--text-soft);
  line-height: 1.45;
}

.discord-tile-status {
  min-width: 108px;
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  border: 1px solid rgba(49, 233, 129, 0.26);
  border-radius: 999px;
  color: #c9f7dc;
  background: rgba(49, 233, 129, 0.08);
  font-size: 13px;
  font-weight: 600;
}

.discord-settings-panel {
  padding: 16px;
  border: 1px solid var(--border-strong);
  border-radius: 20px;
  background: #151515;
}

.discord-settings-panel__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border-strong);
}

.discord-settings-panel__top p {
  margin: 0 0 8px;
  color: var(--text-muted);
  font-size: 13px;
}

.discord-settings-panel__top h2 {
  margin: 0 0 8px;
  color: var(--white);
  font-size: 24px;
}

.discord-settings-panel__top span {
  color: var(--text-soft);
  line-height: 1.5;
}

.discord-header p,
.discord-card p {
  margin: 0 0 8px;
  color: var(--text-muted);
  font-size: 13px;
}

.discord-header h1 {
  margin: 0 0 8px;
  color: var(--white);
  font-size: clamp(28px, 2.4vw, 42px);
  letter-spacing: 0;
}

.discord-header span,
.discord-card > span,
.discord-card div > span,
.discord-link-summary {
  color: var(--text-soft);
  line-height: 1.5;
}

.discord-header-actions,
.discord-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.discord-status {
  min-height: 42px;
  margin-bottom: 16px;
  padding: 12px 14px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  color: var(--text-soft);
  background: #171717;
}

.discord-status:empty {
  display: none;
}

.discord-status[data-tone="success"] {
  color: #c9f7dc;
  border-color: rgba(49, 233, 129, 0.3);
}

.discord-status[data-tone="error"] {
  color: #ffd9de;
  border-color: rgba(255, 91, 107, 0.32);
}

.discord-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.7fr);
  gap: 16px;
}

.discord-card {
  min-width: 0;
  padding: 18px;
  border: 1px solid var(--border-strong);
  border-radius: 20px;
  background: #181818;
}

.discord-card--status,
.discord-card--form,
.discord-card--help {
  grid-column: 1 / -1;
}

.discord-card h2 {
  margin: 0 0 8px;
  color: var(--white);
  font-size: 21px;
}

.discord-account {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 14px;
}

.discord-avatar {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: var(--white);
  background: var(--panel-muted);
  font-weight: 700;
}

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

.discord-account strong {
  display: block;
  margin-bottom: 4px;
  color: var(--white);
}

.discord-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 16px 0;
}

.discord-form-grid select {
  width: 100%;
  height: 42px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: #141414;
  color: var(--text);
  padding: 0 12px;
}

.discord-link-summary {
  margin-bottom: 14px;
  padding: 12px 14px;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  border-radius: 12px;
}

.discord-toggle-list,
.discord-activity-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.discord-toggle {
  min-height: 46px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: #151515;
  color: var(--text-soft);
}

.discord-toggle input {
  width: 18px;
  height: 18px;
  accent-color: var(--green);
}

.discord-activity-item,
.discord-empty-state {
  padding: 12px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: #151515;
}

.discord-activity-item span {
  display: inline-flex;
  margin-bottom: 8px;
  color: var(--green);
  font-size: 12px;
  text-transform: uppercase;
}

.discord-activity-item strong,
.discord-activity-item small {
  display: block;
}

.discord-activity-item strong {
  color: var(--white);
  margin-bottom: 6px;
}

.discord-activity-item small,
.discord-empty-state {
  color: var(--text-soft);
}

.nav-item.is-hidden {
  display: none;
}

@media (max-width: 1200px) {
  .dashboard-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .widget-col-6,
  .widget-col-5,
  .widget-col-4,
  .widget-col-3,
  .widget-col-2 {
    grid-column: span 6;
  }

  .dashboard-learning-columns,
  .learning-content-grid,
  .lesson-modal-main,
  .dashboard-message-columns,
  .ai-native-shell,
  .dashboard-overview,
  .dashboard-embedded-board,
  .dashboard-main-grid,
  .discord-layout,
  .discord-form-grid {
    grid-template-columns: 1fr;
  }

  .lesson-questions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .request-grid,
  .promoted-task-grid,
  .summary-grid,
  .placeholder-grid {
    grid-template-columns: 1fr;
  }

  .task-row {
    grid-template-columns: 1fr auto auto;
    grid-template-areas:
      "priority promote action"
      "title title title";
    gap: 12px 18px;
  }

  .task-row > :nth-child(1) {
    grid-area: priority;
  }

  .task-row > :nth-child(2) {
    display: none;
  }

  .task-row > :nth-child(3) {
    grid-area: title;
  }

  .task-row > :nth-child(4) {
    grid-area: promote;
  }

  .task-row > :nth-child(5) {
    grid-area: action;
  }
}

@media (max-width: 900px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .mobile-menu-button,
  .sidebar-overlay {
    display: block;
  }

  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 30;
    width: min(var(--sidebar-width), calc(100vw - 24px));
    max-width: min(var(--sidebar-width), calc(100vw - 24px));
    min-width: 0;
    height: 100vh;
    border-right: 1px solid var(--border-strong);
    border-bottom: 0;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 12%),
      #141414;
    transform: translateX(-100%);
    transition: transform 220ms ease;
    box-shadow: 28px 0 60px rgba(0, 0, 0, 0.36);
  }

  .sidebar.is-open {
    transform: translateX(0);
  }

  .sidebar-nav {
    display: flex;
    grid-template-columns: none;
  }

  .sidebar-footer {
    margin-top: 0;
  }

  .workspace-card {
    padding-left: 0;
  }

  .main-stage {
    padding: 84px 14px 18px;
  }

  .mobile-menu-button,
  .sidebar-overlay {
    backdrop-filter: none;
  }

  .lesson-modal-backdrop {
    backdrop-filter: none;
  }

  .dashboard-header,
  .page-split-header,
  .dashboard-header-actions,
  .calendar-header,
  .dashboard-hero-panel,
  .discord-header,
  .discord-card-head,
  .discord-settings-panel__top {
    flex-direction: column;
    align-items: stretch;
  }

  .dashboard-hero-panel {
    display: flex;
  }

  .calendar-header-actions,
  .dashboard-hero-actions,
  .dashboard-calendar-actions,
  .discord-header-actions {
    justify-content: flex-start;
  }

  .dashboard-add-menu {
    right: 0;
    top: 88px;
  }

  .dashboard-messages-widget,
  .messages-layout,
  .ai-layout,
  .dashboard-learning-columns,
  .chat-page,
  .ai-native-shell {
    grid-template-columns: 1fr;
  }

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

  .dashboard-metric-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .learning-columns-head,
  .learning-columns,
  .lesson-questions {
    grid-template-columns: 1fr;
  }

  .chat-page {
    min-height: auto;
  }

  .chat-rail,
  .chat-thread-panel,
  .chat-profile-panel {
    border-radius: 20px;
  }

  .chat-thread-panel {
    min-height: 480px;
  }

  .ai-native-thread {
    height: min(60vh, 560px);
  }

  .widget-card {
    padding: 14px;
    border-radius: 20px;
  }

  .task-row {
    grid-template-columns: 1fr;
    grid-template-areas:
      "priority"
      "title"
      "promote"
      "action";
  }
}

@media (max-width: 600px) {
  .dashboard-header h2 {
    font-size: clamp(24px, 8vw, 34px);
  }

  .dashboard-ai-widget {
    padding: 12px;
  }

  .dashboard-messages-widget {
    min-height: 360px;
  }

  .dashboard-grid {
    gap: 14px;
  }

  .dashboard-metric-strip,
  .dashboard-upcoming-list,
  .dashboard-embedded-board,
  .dashboard-message-columns {
    grid-template-columns: 1fr;
  }

  .calendar-header-actions,
  .dashboard-hero-actions,
  .dashboard-calendar-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }

  .dashboard-calendar-card .widget-head {
    flex-direction: column;
    align-items: stretch;
  }

  .calendar-header-actions .page-action,
  .dashboard-hero-actions .page-action,
  .dashboard-calendar-actions .widget-link-button,
  .discord-header-actions .page-action,
  .discord-card-head .page-action {
    width: 100%;
  }

  .discord-integration-tile {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .discord-tile-icon {
    width: 48px;
    height: 48px;
  }

  .discord-tile-status {
    grid-column: 1 / -1;
    justify-content: flex-start;
    width: fit-content;
  }

  .calendar-weekdays,
  .calendar-grid {
    gap: 4px;
  }

  .calendar-weekdays span {
    padding: 0;
    text-align: center;
    font-size: 10px;
  }

  .calendar-grid {
    grid-auto-rows: minmax(76px, auto);
  }

  .calendar-day {
    min-height: 76px;
    padding: 7px;
    border-radius: 12px;
    gap: 6px;
  }

  .calendar-day__number {
    font-size: 13px;
  }

  .calendar-pill {
    padding: 4px 5px;
    border-radius: 7px;
    font-size: 9px;
  }

  .dashboard-calendar-weekdays,
  .dashboard-calendar-grid {
    gap: 5px;
  }

  .dashboard-calendar-day {
    padding: 5px;
    border-radius: 9px;
  }

  .dashboard-calendar-day span {
    font-size: 10px;
  }

  .dashboard-summary-panel,
  .dashboard-tasks-embed,
  .ai-native-history,
  .ai-native-panel {
    padding: 16px;
    border-radius: 20px;
  }

  .chat-rail,
  .chat-thread-panel,
  .chat-profile-panel {
    padding: 14px;
  }

  .chat-profile-avatar {
    width: 132px;
    height: 132px;
    font-size: 44px;
  }

  .chat-bubble,
  .chat-bubble--right {
    grid-template-columns: 32px minmax(0, 1fr);
  }

  .chat-bubble-meta {
    gap: 16px;
  }

  .chat-composer {
    grid-template-columns: none;
    grid-template-rows: 30px 40px 34px;
    padding: 0;
  }

  .ai-native-composer {
    flex-direction: column;
    align-items: stretch;
  }

  .ai-native-send {
    width: 100%;
  }

  .dashboard-learning-course,
  .learning-course-card {
    grid-template-columns: 1fr;
    justify-items: start;
  }

  .course-open,
  .dashboard-open-pill {
    margin-top: 4px;
  }
}

/* Figma redesign pass: DT frames 325:* */
:root {
  --sidebar-width: 164px;
  --rail-width: 210px;
  --profile-width: 260px;
  --bg: #141414;
  --panel: #181818;
  --panel-soft: #1e1e1e;
  --panel-muted: #2a2a2a;
  --border: rgba(179, 179, 177, 0.18);
  --border-strong: #2e2e2e;
  --text: #dadad7;
  --text-soft: #b3b3b1;
  --text-muted: #4c4c4c;
  --green: #31e981;
  --red: #ff5b6b;
  --cyan: #00b9d9;
  --purple: #b450ff;
  --yellow: #e7d44d;
}

body {
  background: #141414;
}

.app-shell {
  max-width: none;
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
  background: #141414;
}

.sidebar {
  padding: 6px 7px 10px;
  gap: 8px;
  border-right: 2px solid #2a2a2a;
  background: #141414;
}

.brand-mark {
  width: 34px;
  height: 37px;
  margin: 4px 0 2px 8px;
}

.sidebar-search {
  width: calc(var(--sidebar-width) - 16px);
  height: 30px;
  gap: 8px;
  padding: 0 10px;
  border-radius: 3px;
  border-color: #515151;
  background: rgba(20, 20, 20, 0.18);
}

.sidebar-search svg {
  width: 13px;
  height: 13px;
}

.sidebar-search input {
  font-size: 11px;
}

.sidebar-nav,
.sidebar-footer {
  gap: 2px;
}

.nav-item {
  min-height: 31px;
  gap: 9px;
  padding: 0 10px;
  border-radius: 3px;
  color: #b3b3b1;
}

.nav-item:focus-visible,
.connect-apps-card:focus-visible,
.dashboard-new-card:focus-visible,
.integration-icon-tile:focus-visible {
  outline: none;
  border-color: #b3b3b1;
}

.nav-label {
  font-size: 12px;
  line-height: 1;
}

.nav-icon {
  width: 14px;
  height: 14px;
  flex-basis: 14px;
  display: inline-grid;
  place-items: center;
  color: currentColor;
  font-size: 14px;
  background-image: none !important;
}

.nav-item:hover,
.nav-item.is-active {
  background: #1e1e1e;
  border-color: #515151;
  color: #dadad7;
}

.nav-item--new,
.nav-item--new:hover,
.nav-item--new.is-active {
  min-height: 31px;
  border-radius: 2px;
  background: #ffffff;
  color: #000000;
  border-color: #b3b3b1;
  box-shadow: none;
}

.new-menu {
  top: 36px;
  left: 170px;
  width: 210px;
  padding: 16px;
  border-radius: 8px;
  border-color: #2e2e2e;
  background: #181818;
}

.new-menu-item {
  min-height: 34px;
  border-radius: 3px;
  color: #ffffff;
  font-size: 16px;
}

.connect-apps-card {
  width: calc(var(--sidebar-width) - 16px);
  min-height: 38px;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 7px;
  padding: 0 10px;
  border: 1px solid #6c6c6c;
  border-radius: 3px;
  background: #202020;
  color: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 300;
}

.sidebar-footer-actions {
  gap: 2px;
}

.nav-item--footer-main {
  flex: 1;
}

.nav-item--icon-only {
  width: 30px;
  min-width: 30px;
  min-height: 30px;
}

.workspace-card {
  gap: 7px;
  padding: 2px 4px 0;
  border-radius: 3px;
}

.workspace-badge {
  width: 25px;
  height: 25px;
  border-radius: 4px;
  font-size: 11px;
}

.workspace-card strong {
  font-size: 12px;
  line-height: 1.05;
}

.workspace-card span {
  font-size: 10px;
}

.notification-dot {
  top: 1px;
  right: 1px;
  width: 7px;
  height: 7px;
  z-index: 2;
}

.main-stage {
  padding: 20px 18px 10px 30px;
  background: #141414;
}

.view-panel {
  min-height: calc(100vh - 30px);
}

body[data-active-view="chat"] .main-stage {
  padding: 0;
}

.request-panel,
.promoted-task-panel,
.status-panel,
.dashboard-calendar-card,
.dashboard-task-board,
.dashboard-up-next-card,
.dashboard-ai-widget,
.dashboard-messages-widget,
.ai-native-history,
.ai-native-panel,
.discord-settings-panel,
.discord-card,
.placeholder-panel,
.summary-card,
.embed-shell {
  background: #181818;
  border: 1px solid rgba(46, 46, 46, 0.69);
  border-radius: 4px;
  box-shadow: none;
}

.view-panel--board {
  max-width: 1050px;
}

.request-panel {
  padding: 0;
  overflow: hidden;
  background: #181818;
}

.section-head {
  min-height: 38px;
  margin: 0;
  padding: 8px 14px;
  gap: 10px;
  border-bottom: 1px solid #2e2e2e;
}

.section-head h1,
.section-head h2 {
  font-size: 15px;
  font-weight: 700;
}

.count-badge {
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 5px;
  font-size: 10px;
  background: #2a2a2a;
}

.request-grid,
.promoted-task-grid {
  gap: 4px;
  padding: 10px;
}

.request-card,
.promoted-task-card {
  min-height: 110px;
  padding: 12px;
  border-radius: 4px;
  background: #1e1e1e;
}

.request-card h3,
.promoted-task-card h3 {
  margin-bottom: 10px;
  color: #b3b3b1;
  font-size: 12px;
}

.request-tag {
  min-height: 18px;
  padding: 0 7px;
  border-radius: 3px;
  font-size: 9px;
}

.request-meta,
.request-actions {
  font-size: 9px;
}

.request-meta div,
.request-actions button {
  padding-top: 8px;
}

.status-panel {
  margin-top: 4px;
  overflow: hidden;
}

.status-panel .section-head {
  padding: 7px 14px;
}

.task-row {
  grid-template-columns: 64px 24px minmax(0, 1fr);
  min-height: 35px;
  gap: 12px;
  padding: 7px 14px;
  border-top: 1px solid #2e2e2e;
}

.task-row .task-action {
  display: none;
}

.task-priority {
  font-size: 9px;
}

.task-title {
  color: #dadad7;
  font-size: 13px;
}

.task-bullet {
  width: 11px;
  height: 11px;
  border-width: 1px;
}

.task-bullet--progress {
  width: 11px;
  height: 11px;
  border-radius: 999px;
  border-color: #e7d44d;
  background: conic-gradient(from 90deg, transparent 0 45%, currentColor 45% 68%, transparent 68%);
}

.dashboard-header {
  display: none;
}

.dashboard-overview {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dashboard-figma-top {
  display: grid;
  grid-template-columns: minmax(270px, 1fr) minmax(315px, 340px);
  gap: 22px;
  align-items: start;
}

.dashboard-hero-copy h3 {
  margin: 0 0 28px;
  color: #ffffff;
  font-size: 30px;
  line-height: 1.08;
  font-weight: 700;
}

.dashboard-hero-copy span {
  display: block;
  max-width: 620px;
  color: #ffffff;
  font-size: 16px;
  line-height: 1.45;
}

.dashboard-new-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.dashboard-new-card {
  min-height: 125px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  border: 1px solid #2e2e2e;
  border-radius: 2px;
  background: #181818;
  color: #ffffff;
  cursor: pointer;
}

.dashboard-new-icon {
  width: 42px;
  height: 42px;
  display: inline-grid;
  place-items: center;
  position: relative;
  font-size: 42px;
  background-image: none !important;
}

.dashboard-new-card strong {
  font-size: 13px;
  font-weight: 500;
}

.dashboard-new-card--chat .dashboard-new-icon { color: #f072a6; }
.dashboard-new-card--event .dashboard-new-icon { color: #63c7ff; }
.dashboard-new-card--reminder .dashboard-new-icon { color: #4be7b0; }
.dashboard-new-card--task .dashboard-new-icon { color: #b450ff; }
.dashboard-new-card--ai .dashboard-new-icon { color: #ff7b45; }

.dashboard-new-icon::after {
  content: none !important;
}

.dashboard-main-grid--figma {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 184px;
  gap: 16px;
  align-items: start;
}

.dashboard-primary-stack,
.dashboard-side-stack {
  gap: 12px;
}

.dashboard-request-stack,
.dashboard-task-stack {
  gap: 4px;
}

.dashboard-task-board {
  overflow: hidden;
}

.dashboard-task-board__head {
  min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 14px;
  border-bottom: 1px solid #2e2e2e;
}

.dashboard-task-board__head h3 {
  margin: 0;
  color: #dadad7;
  font-size: 15px;
  font-weight: 700;
}

.dashboard-task-board__requests {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
  padding: 10px;
  border-bottom: 1px solid #2e2e2e;
}

.dashboard-task-board__sections {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.dashboard-request-card {
  min-height: 78px;
  padding: 10px;
  border-radius: 4px;
}

.dashboard-request-card--figma {
  background: #1e1e1e;
}

.dashboard-request-card--empty p {
  margin: 10px 0 0;
  color: #b3b3b1;
  font-size: 10px;
}

.dashboard-task-panel {
  border: 0;
  border-radius: 0;
  background: #181818;
}

.dashboard-task-panel-head {
  padding: 8px 12px;
  background: #181818;
  border-bottom: 1px solid #2e2e2e;
}

.dashboard-task-panel__body {
  background: #1e1e1e;
}

.dashboard-task-row {
  grid-template-columns: 50px 16px minmax(0, 1fr) auto;
  min-height: 35px;
  padding: 7px 12px;
  border-top: 1px solid #2e2e2e;
}

.dashboard-task-row .task-action {
  display: none;
}

.dashboard-calendar-card {
  padding: 10px;
  border-radius: 4px;
}

.dashboard-up-next-card {
  padding: 10px;
  border-radius: 4px;
}

.dashboard-up-next-card h3 {
  margin: 0 0 8px;
  color: #ffffff;
  font-size: 11px;
  font-weight: 500;
}

.dashboard-calendar-card .widget-head p,
.dashboard-calendar-actions .widget-link-button:nth-child(1),
.dashboard-calendar-actions .widget-link-button:nth-child(3) {
  display: none;
}

.dashboard-calendar-card .widget-head h3 {
  margin: 0;
  font-size: 11px;
  font-weight: 500;
  color: #ffffff;
}

.dashboard-calendar-actions .widget-link-button {
  min-height: 20px;
  padding: 0 8px;
  border: 0;
  border-radius: 2px;
  background: #181b21;
  color: #ffffff;
  font-size: 6px;
}

.dashboard-calendar-weekdays,
.dashboard-calendar-grid {
  gap: 5px;
}

.dashboard-calendar-weekdays span,
.dashboard-calendar-day span {
  color: #ffffff;
  font-size: 8px;
  text-align: center;
}

.dashboard-calendar-day {
  aspect-ratio: auto;
  min-height: 19px;
  justify-content: center;
  align-items: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
}

.dashboard-calendar-day.is-today {
  background: transparent;
  color: #ffffff;
  border: 2px solid #ffffff;
  box-shadow: none;
}

.dashboard-calendar-day.is-today span {
  color: #ffffff;
}

.dashboard-upcoming-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dashboard-upcoming-item {
  min-height: 42px;
  padding: 8px;
  border-radius: 4px;
  background: #11141a;
  border-color: #515151;
}

.calendar-page {
  min-height: calc(100vh - 30px);
  gap: 10px;
}

.calendar-header {
  min-height: 38px;
  padding: 0 0 8px;
  border-bottom: 1px solid #2e2e2e;
}

.calendar-header p,
.calendar-theme-picker {
  display: none;
}

.calendar-header h2 {
  font-size: 24px;
}

.page-action {
  height: 28px;
  min-width: 28px;
  padding: 0 10px;
  border-radius: 4px;
  font-size: 12px;
}

.calendar-weekdays {
  gap: 0;
  padding: 10px 0 0;
}

.calendar-weekdays span {
  color: #ffffff;
  text-align: center;
  letter-spacing: 0;
}

.calendar-grid {
  gap: 0;
  grid-auto-rows: minmax(92px, 1fr);
  border: 1px solid #2e2e2e;
  border-radius: 4px;
  overflow: hidden;
}

.calendar-day {
  min-height: 92px;
  border: 0;
  border-right: 1px solid #2e2e2e;
  border-bottom: 1px solid #2e2e2e;
  border-radius: 0;
  background: #181818;
}

.calendar-day.is-today {
  border: 2px solid #ffffff;
  box-shadow: inset 0 0 0 1px #ffffff;
}

.calendar-day__number {
  font-size: 13px;
}

.chat-page {
  grid-template-columns: 210px minmax(0, 1fr);
  background: #141414;
}

.chat-page:has(.chat-members-sidebar:not([hidden])) {
  grid-template-columns: 210px minmax(0, 1fr) 260px;
}

.chat-rail {
  padding: 22px 12px 18px 14px;
  gap: 22px;
  background: #141414;
  border: 2px solid #2a2a2a;
  border-top: 0;
  border-bottom: 0;
}

.chat-rail-head h3 {
  font-size: 15px;
}

.chat-list-item {
  min-height: 26px;
  border-radius: 2px;
  padding: 0 10px 0 18px;
}

.chat-list-item.is-active {
  background: #1e1e1e;
  border: 1px solid #a6a6a7;
}

.chat-list-copy strong {
  font-size: 14px;
}

.chat-thread-panel {
  padding: 16px 18px 10px;
  background: #141414;
}

.chat-thread-header {
  min-height: 92px;
}

.chat-channel-title h2 {
  font-size: 18px;
  text-transform: uppercase;
}

.chat-members-button {
  min-height: 25px;
  border-radius: 6px;
  font-size: 11px;
}

.chat-thread-scroll {
  gap: 15px;
  padding-bottom: 24px;
}

.chat-bubble {
  grid-template-columns: 33px minmax(0, 1fr);
  max-width: 560px;
  gap: 7px;
}

.chat-bubble-avatar {
  width: 33px;
  height: 33px;
  border-radius: 7px;
  background: #d9d9d9;
}

.chat-bubble-body strong,
.chat-bubble-body p {
  font-size: 13px;
}

.chat-bubble-body time {
  font-size: 8px;
}

.chat-composer {
  min-height: 116px;
  border-radius: 3px;
  background: #ffffff;
}

.chat-composer-toolbar {
  background: #f4f4f4;
}

.ai-native-shell {
  min-height: calc(100vh - 30px);
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 12px;
}

.ai-native-history {
  width: auto;
  padding: 18px;
  overflow: hidden;
  border: 1px solid rgba(46, 46, 46, 0.69);
}

.ai-native-panel {
  min-height: calc(100vh - 30px);
  padding: 18px 24px;
  border: 1px solid rgba(46, 46, 46, 0.69);
  background: #181818;
}

.ai-native-panel__header {
  min-height: 52px;
  justify-content: flex-start;
}

.ai-native-panel__header::before {
  content: none;
}

.ai-native-panel__header::after {
  content: none;
}

.ai-native-thread {
  height: calc(100vh - 200px);
  padding: 0 12px 42px;
}

.ai-native-empty {
  display: grid;
}

.ai-native-message {
  max-width: 72%;
}

.ai-native-message__meta {
  display: block;
}

.ai-native-message__body {
  padding: 12px 14px;
  border-radius: 8px;
  border: 1px solid #2e2e2e;
  background: #202020;
  color: #ffffff;
  font-size: 13px;
  line-height: 1.25;
}

.ai-native-message--assistant .ai-native-message__body {
  background: #363636;
}

.ai-native-composer {
  width: 100%;
  margin: 0 auto;
  min-height: 44px;
  align-items: center;
  padding: 4px 5px 4px 18px;
  border-radius: 8px;
  border: 1px solid #2e2e2e;
  background: #141414;
}

.ai-native-composer textarea {
  min-height: 24px;
  color: #dadad7;
  font-size: 14px;
  overflow: hidden;
}

.ai-native-send {
  width: 31px;
  height: 31px;
  min-width: 31px;
  padding: 0;
  border-radius: 999px;
  background: #ffffff;
  color: transparent;
  position: relative;
}

.ai-native-send::before {
  content: "";
  position: absolute;
  inset: 8px 10px 8px 9px;
  border-left: 3px solid #141414;
  border-top: 3px solid #141414;
  transform: rotate(45deg);
}

.integrations-overview {
  display: grid;
  gap: 8px;
  max-width: 560px;
}

.integrations-overview h1,
.integrations-overview h2 {
  margin: 0;
  color: #ffffff;
  font-size: 20px;
  line-height: 1.15;
}

.integration-connected-grid,
.integration-explore-grid {
  display: grid;
  grid-template-columns: repeat(4, 133px);
  gap: 5px;
}

.integration-connected-grid {
  grid-template-columns: repeat(2, 133px);
}

.integration-icon-tile {
  min-height: 75px;
  display: grid;
  place-items: center;
  border: 1px solid #515151;
  border-radius: 2px;
  background: #202020;
  color: #ffffff;
  text-align: center;
}

.integration-icon-tile span,
.discord-tile-icon {
  line-height: 1;
}

.integration-glyph {
  width: 43px;
  height: 43px;
  display: block;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.integration-glyph--slack { background-image: url("./assets/kovo-integrations/Vector.svg"); }
.integration-glyph--discord { background-image: url("./assets/kovo-integrations/Vector-1.svg"); }
.integration-glyph--drive { background-image: url("./assets/kovo-integrations/Vector-2.svg"); }
.integration-glyph--calendar { background-image: url("./assets/kovo-integrations/Vector-3.svg"); }
.integration-glyph--gmail { background-image: url("./assets/kovo-integrations/Vector-4.svg"); }
.integration-glyph--teams { background-image: url("./assets/kovo-integrations/Vector-5.svg"); }
.integration-glyph--coming { background-image: url("./assets/kovo-integrations/Subtract.svg"); }

.discord-integration-tile {
  width: auto;
  margin: 0;
  grid-template-columns: 1fr;
  gap: 0;
  padding: 0;
}

.discord-integration-tile .discord-tile-copy,
.discord-integration-tile .discord-tile-status {
  display: none;
}

.discord-tile-icon {
  width: 43px;
  height: 43px;
  background: transparent;
  border-radius: 0;
}

.integration-coming-grid {
  display: grid;
  grid-template-columns: repeat(4, 100px);
  gap: 5px;
  margin-top: 2px;
}

.integration-coming-grid article {
  min-height: 56px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 1px;
  border: 1px solid #6c6c6c;
  border-radius: 2px;
  background: #202020;
  color: #ffffff;
}

.integration-coming-grid span {
  width: 20px;
  height: 20px;
}

.integration-coming-grid strong {
  font-size: 8px;
}

.discord-settings-panel {
  margin-top: 16px;
}

.event-modal-card,
.task-modal-card {
  width: min(680px, calc(100vw - 32px));
  margin: 70px auto;
  padding: 28px;
  border-radius: 4px;
  background: #181818;
  border: 1px solid #2e2e2e;
}

.event-modal-head p {
  color: #b3b3b1;
}

.settings-field input,
.settings-field select {
  border-radius: 2px;
  background: #141414;
}

@media (max-width: 900px) {
  :root {
    --sidebar-width: 164px;
  }

  .mobile-menu-button {
    display: block;
  }

  .app-shell {
    display: block;
  }

  .sidebar {
    position: fixed;
    z-index: 30;
    transform: translateX(-100%);
    transition: transform 180ms ease;
  }

  .sidebar.is-open {
    transform: translateX(0);
  }

  .sidebar-overlay {
    display: block;
  }

  .main-stage {
    padding: 72px 12px 16px;
  }

  body[data-active-view="chat"] .main-stage {
    padding-top: 72px;
  }

  .view-panel--board,
  .dashboard-figma-top,
  .dashboard-main-grid--figma,
  .chat-page,
  .ai-native-shell {
    max-width: none;
    display: flex;
    flex-direction: column;
  }

  .dashboard-new-grid,
  .dashboard-task-board__requests,
  .request-grid,
  .promoted-task-grid,
  .integration-connected-grid,
  .integration-explore-grid,
  .integration-coming-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-new-card {
    min-height: 112px;
  }

  .chat-rail {
    border: 1px solid #2a2a2a;
    min-height: auto;
  }

  .chat-thread-panel,
  .ai-native-panel {
    min-height: 70vh;
  }

  .calendar-grid {
    grid-auto-rows: minmax(76px, 1fr);
  }
}

@media (max-width: 560px) {
  .main-stage {
    padding-inline: 10px;
  }

  .dashboard-hero-copy h3 {
    font-size: 24px;
  }

  .dashboard-hero-copy span {
    font-size: 14px;
  }

  .task-row {
    grid-template-columns: 54px 20px minmax(0, 1fr);
    gap: 8px;
    padding-inline: 10px;
  }

  .task-title {
    font-size: 12px;
  }

  .calendar-grid {
    grid-auto-rows: minmax(64px, 1fr);
  }

  .integration-connected-grid,
  .integration-explore-grid,
  .integration-coming-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .ai-native-composer {
    width: 100%;
  }
}

.view-panel:not(.is-active) {
  display: none !important;
}

.view-panel.is-active {
  display: block;
}

/* Absolute final desktop lock: Open Thread Main is not mobile friendly by design. */
:root {
  --sidebar-width: 330px;
  --rail-width: 420px;
  --profile-width: 360px;
  --desktop-min-width: 1280px;
  --bg: #101112;
  --panel: #171819;
  --panel-soft: #202224;
  --panel-muted: #292c2f;
  --border: rgba(255, 255, 255, 0.09);
  --border-strong: rgba(255, 255, 255, 0.16);
  --text: #ececea;
  --text-soft: #b9bbb6;
  --text-muted: #858983;
  --white: #ffffff;
  --black: #0f1011;
  --green: #37e487;
  --red: #ff6877;
  --cyan: #63d7ff;
  --purple: #b989ff;
  --yellow: #f2d85c;
  --app-button: #262a2f;
}

html,
body,
.app-shell {
  min-width: var(--desktop-min-width) !important;
}

html,
body {
  overflow-x: auto !important;
  background: var(--bg) !important;
}

.app-shell {
  display: grid !important;
  grid-template-columns: var(--sidebar-width) minmax(920px, 1fr) !important;
  max-width: none !important;
  background: var(--bg) !important;
}

.mobile-menu-button,
.sidebar-overlay {
  display: none !important;
}

.sidebar {
  position: sticky !important;
  top: 0 !important;
  transform: none !important;
  width: var(--sidebar-width) !important;
  min-width: var(--sidebar-width) !important;
  max-width: var(--sidebar-width) !important;
  height: 100vh !important;
  padding: 28px !important;
  gap: 18px !important;
  border-right: 1px solid var(--border) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 32%), #121314 !important;
}

.brand-mark {
  width: 68px !important;
  height: 74px !important;
  margin: 0 0 10px !important;
}

.sidebar-search {
  width: 100% !important;
  height: 52px !important;
  padding: 0 18px !important;
  border-radius: 8px !important;
  background: #181a1c !important;
}

.nav-item {
  min-height: 64px !important;
  gap: 16px !important;
  padding: 0 18px !important;
  border-radius: 8px !important;
}

.nav-item--new,
.nav-item--new:hover,
.nav-item--new.is-active {
  min-height: 72px !important;
  border-radius: 8px !important;
  background: #f4f4f1 !important;
  color: #101112 !important;
}

.nav-icon {
  width: 22px !important;
  height: 22px !important;
  flex-basis: 22px !important;
  font-size: 22px !important;
}

.nav-label,
.connect-apps-card {
  font-size: 17px !important;
}

.connect-apps-card,
.workspace-card {
  width: 100% !important;
  min-height: 64px !important;
  border-radius: 8px !important;
}

.workspace-card {
  min-height: 74px !important;
}

.main-stage,
body[data-active-view="dashboard"] .main-stage,
body[data-active-view="tasks"] .main-stage,
body[data-active-view="integrations"] .main-stage,
body[data-active-view="calendar"] .main-stage,
body[data-active-view="notifications"] .main-stage,
body[data-active-view="settings"] .main-stage {
  padding: 32px 40px !important;
  background: var(--bg) !important;
}

body[data-active-view="ai"] .main-stage,
body[data-active-view="chat"] .main-stage {
  padding: 0 !important;
}

.dashboard-header {
  display: none !important;
}

.dashboard-overview {
  width: 100% !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) !important;
  gap: 26px !important;
}

.dashboard-figma-top {
  display: grid !important;
  grid-template-columns: minmax(520px, 1fr) 620px !important;
  gap: 32px !important;
  min-height: 280px !important;
}

.dashboard-hero-copy {
  min-height: 280px !important;
  padding: 30px !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  background: linear-gradient(135deg, rgba(55, 228, 135, 0.12), transparent 42%), var(--panel) !important;
}

.dashboard-hero-copy h3 {
  font-size: 56px !important;
  line-height: 1.02 !important;
  letter-spacing: 0 !important;
}

.dashboard-hero-copy span {
  color: var(--text-soft) !important;
  font-size: 24px !important;
}

.dashboard-new-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.dashboard-new-card {
  min-height: 134px !important;
  padding: 18px !important;
  border-radius: 8px !important;
}

.dashboard-main-grid--figma {
  display: grid !important;
  grid-template-columns: minmax(680px, 1fr) 420px !important;
  gap: 26px !important;
}

.request-panel,
.promoted-task-panel,
.status-panel,
.dashboard-task-board,
.dashboard-calendar-card,
.dashboard-up-next-card,
.placeholder-panel,
.settings-page,
.settings-card,
.discord-card,
.discord-settings-panel,
.ai-native-history,
.ai-native-panel {
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  background: var(--panel) !important;
}

.dashboard-task-board__head,
.section-head,
.dashboard-task-panel-head {
  min-height: 62px !important;
  padding: 16px 22px !important;
}

.dashboard-task-board__head h3,
.section-head h1,
.section-head h2,
.dashboard-task-panel-head h4 {
  font-size: 22px !important;
}

.dashboard-task-board__requests,
.request-grid,
.promoted-task-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
  padding: 16px !important;
}

.dashboard-request-card,
.request-card,
.promoted-task-card {
  min-height: 160px !important;
  padding: 18px !important;
  border-radius: 8px !important;
  background: var(--panel-soft) !important;
}

.dashboard-task-row,
.task-row {
  grid-template-columns: 104px 28px minmax(0, 1fr) auto auto !important;
  min-height: 72px !important;
  padding: 0 20px !important;
}

.dashboard-task-row {
  grid-template-columns: 104px 28px minmax(0, 1fr) auto !important;
}

.dashboard-task-row .task-action,
.task-row .task-action {
  display: inline-flex !important;
}

.calendar-grid {
  grid-auto-rows: minmax(132px, 1fr) !important;
}

.chat-page {
  display: grid !important;
  grid-template-columns: 360px minmax(0, 1fr) !important;
}

.chat-page:has(.chat-members-sidebar:not([hidden])) {
  grid-template-columns: 360px minmax(0, 1fr) var(--profile-width) !important;
}

.chat-rail {
  padding: 28px 22px !important;
}

.chat-thread-panel {
  padding: 28px 30px 22px !important;
}

.chat-bubble {
  max-width: 720px !important;
}

.ai-native-shell {
  display: grid !important;
  grid-template-columns: var(--rail-width) minmax(0, 1fr) !important;
}

.ai-native-history {
  position: static !important;
  width: auto !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: none !important;
}

.ai-native-menu-button {
  display: none !important;
}

.integrations-overview h1,
.integrations-overview h2 {
  font-size: 42px !important;
}

.integration-connected-grid,
.integration-explore-grid {
  grid-template-columns: repeat(5, minmax(180px, 1fr)) !important;
}

.integration-icon-tile {
  min-height: 164px !important;
  border-radius: 8px !important;
}

.settings-page {
  display: grid !important;
  grid-template-columns: 340px minmax(680px, 1fr) !important;
}

/* Figma page implementation pass: compact dark desktop shell and interaction states. */
:root {
  --sidebar-width: 150px;
  --desktop-min-width: 1024px;
  --bg: #141414;
  --panel: #181818;
  --panel-soft: #1e1e1e;
  --panel-muted: #202020;
  --border: #2e2e2e;
  --border-strong: #515151;
  --text: #dadad7;
  --text-soft: #b3b3b1;
  --text-muted: #8f8f8f;
}

html,
body,
.app-shell {
  min-width: var(--desktop-min-width) !important;
  background: var(--bg) !important;
}

.app-shell {
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr) !important;
}

.sidebar {
  width: var(--sidebar-width) !important;
  min-width: var(--sidebar-width) !important;
  max-width: var(--sidebar-width) !important;
  padding: 6px 4px 10px !important;
  gap: 8px !important;
  border-right: 2px solid #2a2a2a !important;
  background: #141414 !important;
}

.brand-mark {
  width: 26px !important;
  height: 28px !important;
  margin: 0 0 4px !important;
}

.sidebar-search {
  height: 24px !important;
  padding: 0 8px !important;
  border-color: #3a3a3a !important;
  border-radius: 3px !important;
  background: #141414 !important;
}

.sidebar-search svg {
  width: 12px !important;
  height: 12px !important;
}

.sidebar-search input,
.sidebar-search input::placeholder {
  font-size: 11px !important;
}

.nav-item {
  min-height: 24px !important;
  padding: 0 8px !important;
  gap: 8px !important;
  border-radius: 2px !important;
  color: var(--text-soft) !important;
}

.nav-item.is-active:not(.nav-item--new) {
  border: 1px solid #454545 !important;
  background: #1e1e1e !important;
}

.nav-item--new,
.nav-item--new:hover,
.nav-item--new.is-active {
  min-height: 24px !important;
  background: #ffffff !important;
  color: #000000 !important;
}

.nav-icon {
  width: 13px !important;
  height: 13px !important;
  flex-basis: 13px !important;
  font-size: 13px !important;
}

.nav-label,
.connect-apps-card {
  font-size: 12px !important;
}

.new-menu {
  position: absolute !important;
  z-index: 20 !important;
  left: calc(100% + 10px) !important;
  top: 32px !important;
  width: 180px !important;
  padding: 8px 0 !important;
  border: 1px solid #b3b3b1 !important;
  border-radius: 3px !important;
  background: #ffffff !important;
  color: #000000 !important;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.45) !important;
}

.new-menu-item {
  min-height: 26px !important;
  padding: 0 12px !important;
  color: #000000 !important;
  font-size: 14px !important;
  text-align: left !important;
}

.new-menu-item:hover {
  background: #eeeeee !important;
}

.connect-apps-card {
  min-height: 28px !important;
  border-radius: 3px !important;
  padding: 0 8px !important;
}

.workspace-card {
  min-height: 34px !important;
  padding: 2px 6px !important;
  border-radius: 3px !important;
}

.workspace-badge {
  width: 18px !important;
  height: 18px !important;
  border-radius: 3px !important;
}

.workspace-card strong {
  font-size: 11px !important;
}

.workspace-card span {
  font-size: 9px !important;
}

.main-stage,
body[data-active-view="dashboard"] .main-stage,
body[data-active-view="tasks"] .main-stage,
body[data-active-view="integrations"] .main-stage,
body[data-active-view="calendar"] .main-stage,
body[data-active-view="notifications"] .main-stage,
body[data-active-view="settings"] .main-stage {
  padding: 20px 18px 10px 40px !important;
}

.view-panel--board {
  max-width: none !important;
}

.dashboard-figma-top {
  grid-template-columns: minmax(300px, 1fr) 340px !important;
  gap: 16px !important;
  min-height: 125px !important;
}

.dashboard-hero-copy {
  min-height: 125px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.dashboard-hero-copy h3 {
  margin: 0 0 26px !important;
  font-size: 28px !important;
  line-height: 1.1 !important;
}

.dashboard-hero-copy span {
  max-width: 620px !important;
  color: #ffffff !important;
  font-size: 16px !important;
}

.dashboard-new-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 6px !important;
}

.dashboard-new-card {
  min-height: 125px !important;
  border: 1px solid #2e2e2e !important;
  border-radius: 2px !important;
  background: #181818 !important;
}

.dashboard-main-grid--figma {
  grid-template-columns: minmax(0, 1fr) 184px !important;
  gap: 16px !important;
}

.dashboard-task-board__head,
.section-head,
.dashboard-task-panel-head {
  min-height: 34px !important;
  padding: 7px 14px !important;
}

.dashboard-task-board__head h3,
.section-head h1,
.section-head h2,
.dashboard-task-panel-head h4 {
  font-size: 14px !important;
}

.dashboard-task-board__requests,
.request-grid,
.promoted-task-grid {
  gap: 4px !important;
  padding: 10px !important;
}

.dashboard-request-card,
.request-card,
.promoted-task-card {
  min-height: 78px !important;
  padding: 10px !important;
  border-radius: 3px !important;
  background: #1e1e1e !important;
}

.dashboard-task-row,
.task-row {
  grid-template-columns: 64px 24px minmax(0, 1fr) auto !important;
  min-height: 35px !important;
  padding: 7px 12px !important;
}

.dashboard-task-row .task-action,
.task-row .task-action {
  display: none !important;
}

.calendar-page {
  max-width: 930px !important;
  margin: 0 auto !important;
}

.calendar-header h2 {
  font-size: 24px !important;
}

.calendar-grid {
  grid-auto-rows: minmax(86px, 1fr) !important;
  border-color: #242424 !important;
}

.calendar-day {
  min-height: 86px !important;
  background: #181818 !important;
  border-color: #242424 !important;
}

.chat-page {
  grid-template-columns: 210px minmax(0, 1fr) !important;
}

.chat-page:has(.chat-members-sidebar:not([hidden])) {
  grid-template-columns: 210px minmax(0, 1fr) 260px !important;
}

.chat-rail {
  padding: 22px 12px 18px 14px !important;
}

.chat-thread-panel {
  padding: 16px 18px 10px !important;
}

.ai-native-shell {
  grid-template-columns: 220px minmax(0, 1fr) !important;
  min-height: 100vh !important;
}

.ai-native-shell:not(.is-history-open) {
  grid-template-columns: 0 minmax(0, 1fr) !important;
}

.ai-native-history {
  position: relative !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: none !important;
  overflow: hidden !important;
}

.ai-native-shell:not(.is-history-open) .ai-native-history {
  width: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}

.ai-native-menu-button {
  display: inline-grid !important;
}

.ai-native-panel {
  min-height: 100vh !important;
  border: 0 !important;
  background: #141414 !important;
}

.ai-native-message--user {
  margin-left: auto !important;
}

.ai-native-message__meta {
  display: none !important;
}

.ai-native-message__body {
  border: 0 !important;
  border-radius: 999px !important;
  background: #363636 !important;
}

.ai-native-composer {
  width: min(520px, 70vw) !important;
  border: 1px solid #ffffff !important;
  border-radius: 999px !important;
  background: #181818 !important;
}

.ai-native-send {
  font-size: 0 !important;
}

.ai-native-history-item {
  position: relative !important;
}

.ai-native-history-item__delete {
  display: none !important;
  position: absolute !important;
  right: 6px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  min-height: 24px !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  color: #141414 !important;
}

.ai-native-history-item.has-delete .ai-native-history-item__delete {
  display: inline-flex !important;
}

.integrations-overview {
  max-width: 700px !important;
}

.integrations-overview h1 {
  display: none !important;
}

.integrations-overview h2 {
  font-size: 20px !important;
}

.integration-connected-grid,
.integration-explore-grid {
  grid-template-columns: repeat(4, 133px) !important;
  gap: 7px !important;
}

.integration-connected-grid {
  grid-template-columns: repeat(2, 133px) !important;
}

.integration-icon-tile {
  min-height: 75px !important;
  border-radius: 2px !important;
}

.integration-detail-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 205px;
  gap: 12px;
  margin-top: 18px;
}

.integration-detail-main h2 {
  margin: 0 0 12px;
  color: #ffffff;
  font-size: 40px;
}

.integration-detail-main,
.integration-detail-side {
  min-width: 0;
}

.integration-detail-card,
.integration-detail-logo {
  border: 1px solid #a6a6a7;
  border-radius: 2px;
  background: #171717;
}

.integration-detail-card {
  padding: 14px;
}

.integration-detail-card p {
  margin: 0 0 10px;
  color: #939393;
  font-size: 12px;
}

.integration-detail-card h3 {
  margin: 0 0 16px;
  color: #ffffff;
}

.integration-detail-profile {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 58px;
}

.integration-avatar-placeholder {
  width: 46px;
  height: 46px;
  border-radius: 3px;
  background: #d9d9d9;
}

.integration-detail-card--logs {
  min-height: 260px;
  margin-top: 12px;
}

.integration-detail-logo {
  display: grid;
  place-items: center;
  min-height: 205px;
}

.integration-detail-logo .integration-glyph {
  width: 90px;
  height: 90px;
}

.integration-detail-card--description {
  min-height: 268px;
  margin-top: 12px;
}

.integration-detail-card--description span {
  color: #ffffff;
  font-size: 11px;
}

.integration-detail-actions {
  display: grid;
  grid-template-columns: 1fr 118px;
  gap: 8px;
  margin-top: 20px;
}

.event-modal-card,
.task-modal-card {
  width: 288px !important;
  margin: 124px auto !important;
  padding: 12px !important;
  border: 1px solid #6c6c6c !important;
  border-radius: 2px !important;
  background: #202020 !important;
}

.event-modal-head {
  min-height: 22px !important;
  margin: -4px 0 4px !important;
  display: flex !important;
  justify-content: flex-end !important;
}

.event-modal-head > div {
  display: none !important;
}

.event-close {
  width: 22px !important;
  height: 22px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid #515151 !important;
  border-radius: 999px !important;
  color: #ffffff !important;
  font-size: 14px !important;
  cursor: pointer !important;
}

.event-form {
  display: grid !important;
  gap: 10px !important;
}

.event-form .settings-field span {
  display: none !important;
}

.event-form .settings-field input,
.event-form .settings-field select {
  min-height: 24px !important;
  padding: 0 !important;
  border: 0 !important;
  border-bottom: 1px solid #797979 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #ffffff !important;
  font-size: 12px !important;
}

.task-modal-actions {
  display: flex !important;
  justify-content: flex-end !important;
  gap: 10px !important;
}

.task-modal-actions .page-action,
.event-form > .page-action {
  min-height: 24px !important;
  padding: 0 12px !important;
  border-radius: 8px !important;
  background: #ffffff !important;
  color: #000000 !important;
  font-size: 11px !important;
}

.task-delete-button {
  min-height: 24px !important;
  color: #ffffff !important;
  font-size: 11px !important;
}

.settings-page {
  grid-template-columns: 220px minmax(0, 1fr) !important;
  max-width: 760px !important;
  margin: 60px auto 0 !important;
}

@media (max-width: 900px) {
  html,
  body,
  .app-shell {
    min-width: 0 !important;
  }

  :root {
    --sidebar-width: 120px;
  }

  .app-shell {
    grid-template-columns: var(--sidebar-width) minmax(0, 1fr) !important;
  }

  .sidebar {
    position: sticky !important;
    width: var(--sidebar-width) !important;
    min-width: var(--sidebar-width) !important;
    max-width: var(--sidebar-width) !important;
    padding: 6px 3px 8px !important;
  }

  .nav-label,
  .connect-apps-card,
  .new-menu-item {
    font-size: 11px !important;
  }

  .main-stage,
  body[data-active-view="dashboard"] .main-stage,
  body[data-active-view="tasks"] .main-stage,
  body[data-active-view="integrations"] .main-stage,
  body[data-active-view="calendar"] .main-stage,
  body[data-active-view="notifications"] .main-stage,
  body[data-active-view="settings"] .main-stage {
    padding: 14px 10px !important;
  }

  .dashboard-figma-top,
  .dashboard-main-grid--figma,
  .integration-detail-panel,
  .settings-page {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .dashboard-new-grid,
  .dashboard-task-board__requests,
  .request-grid,
  .promoted-task-grid,
  .integration-connected-grid,
  .integration-explore-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .dashboard-new-card {
    min-height: 96px !important;
  }

  .dashboard-hero-copy h3 {
    font-size: 24px !important;
  }

  .dashboard-hero-copy span {
    font-size: 13px !important;
  }

  .dashboard-task-row,
  .task-row {
    grid-template-columns: 52px 18px minmax(0, 1fr) !important;
    gap: 6px !important;
  }

  .calendar-grid {
    grid-auto-rows: minmax(58px, 1fr) !important;
  }

  .chat-page,
  .ai-native-shell {
    display: flex !important;
    flex-direction: column !important;
  }

  .ai-native-shell:not(.is-history-open) .ai-native-history {
    display: none !important;
  }
}

/* Modern monochrome refresh: black/white foundation with sparing #A04CEE accents. */
:root {
  color-scheme: dark !important;
  --accent: #A04CEE;
  --accent-soft: rgba(160, 76, 238, 0.14);
  --accent-border: rgba(160, 76, 238, 0.42);
  --sidebar-width: 240px;
  --rail-width: 340px;
  --profile-width: 320px;
  --desktop-min-width: 1120px;
  --bg: #050505;
  --panel: #0d0d0f;
  --panel-soft: #151517;
  --panel-muted: #202024;
  --border: rgba(255, 255, 255, 0.1);
  --border-strong: rgba(255, 255, 255, 0.18);
  --text: #f6f6f7;
  --text-soft: #b8b8c0;
  --text-muted: #777781;
  --white: #ffffff;
  --black: #050505;
  --green: var(--accent);
  --cyan: var(--accent);
  --purple: var(--accent);
  --calendar-accent: var(--accent);
  --calendar-accent-rgb: 160, 76, 238;
}

html,
body,
.app-shell {
  min-width: var(--desktop-min-width) !important;
  background: var(--bg) !important;
  color: var(--text) !important;
}

.app-shell {
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr) !important;
  max-width: none !important;
}

.sidebar {
  width: var(--sidebar-width) !important;
  min-width: var(--sidebar-width) !important;
  max-width: var(--sidebar-width) !important;
  padding: 18px 14px !important;
  gap: 14px !important;
  border-right: 1px solid var(--border) !important;
  background: #080809 !important;
}

.brand-mark {
  width: 42px !important;
  height: 46px !important;
  margin: 0 0 2px !important;
}

.brand-mark img {
  filter: brightness(0) invert(1) !important;
}

.sidebar-search,
.new-menu,
.workspace-card,
.connect-apps-card,
.request-panel,
.promoted-task-panel,
.status-panel,
.dashboard-task-board,
.dashboard-calendar-card,
.dashboard-up-next-card,
.placeholder-panel,
.settings-page,
.settings-card,
.discord-card,
.discord-settings-panel,
.integration-detail-card,
.integration-detail-logo,
.chat-rail,
.chat-thread-panel,
.chat-members-sidebar,
.ai-native-history,
.ai-native-panel {
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  background: var(--panel) !important;
  box-shadow: none !important;
}

.sidebar-search {
  height: 40px !important;
  padding: 0 12px !important;
  background: #0f0f11 !important;
}

.nav-item,
.connect-apps-card,
.workspace-card {
  min-height: 42px !important;
  padding: 0 12px !important;
  gap: 10px !important;
  border-radius: 8px !important;
  color: var(--text-soft) !important;
  transition: background 160ms ease, color 160ms ease, border-color 160ms ease, transform 160ms ease !important;
}

.nav-item:hover,
.connect-apps-card:hover,
.workspace-card:hover {
  background: var(--panel-soft) !important;
  color: var(--white) !important;
}

.nav-item.is-active:not(.nav-item--new),
.settings-tab.is-active,
[data-theme-choice].is-active {
  border: 1px solid var(--accent-border) !important;
  background: var(--accent-soft) !important;
  color: var(--white) !important;
}

.nav-item--new,
.nav-item--new:hover,
.nav-item--new.is-active,
.page-action,
.task-action,
.course-open,
.request-actions button,
.lesson-option.is-selected,
.ai-native-action,
.ai-native-send,
.chat-members-button,
.chat-composer-send,
.dashboard-new-card:hover {
  border-color: transparent !important;
  background: var(--white) !important;
  color: var(--black) !important;
}

.nav-item--new {
  min-height: 46px !important;
}

.nav-icon {
  width: 18px !important;
  height: 18px !important;
  flex-basis: 18px !important;
  font-size: 18px !important;
}

.nav-label,
.connect-apps-card {
  font-size: 14px !important;
}

.workspace-card {
  min-height: 58px !important;
}

.workspace-badge,
.profile-image,
.chat-bubble-avatar,
.discord-avatar {
  border-radius: 8px !important;
  background: var(--accent) !important;
  color: var(--white) !important;
}

.main-stage,
body[data-active-view="dashboard"] .main-stage,
body[data-active-view="tasks"] .main-stage,
body[data-active-view="integrations"] .main-stage,
body[data-active-view="calendar"] .main-stage,
body[data-active-view="notifications"] .main-stage,
body[data-active-view="settings"] .main-stage {
  padding: 28px !important;
  background: var(--bg) !important;
}

body[data-active-view="ai"] .main-stage,
body[data-active-view="chat"] .main-stage {
  padding: 0 !important;
}

.dashboard-figma-top {
  grid-template-columns: minmax(360px, 1fr) minmax(360px, 520px) !important;
  gap: 20px !important;
  min-height: 180px !important;
}

.dashboard-hero-copy,
.dashboard-new-card,
.dashboard-request-card,
.request-card,
.promoted-task-card,
.dashboard-task-row,
.task-row,
.calendar-day,
.dashboard-calendar-day,
.discord-status,
.discord-integration-tile,
.integration-icon-tile,
.chat-list-item,
.chat-setting-row,
.ai-native-history-item,
.ai-native-empty {
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  background: var(--panel-soft) !important;
}

.dashboard-hero-copy {
  min-height: 180px !important;
  padding: 22px !important;
}

.dashboard-hero-copy h3,
.section-head h1,
.section-head h2,
.calendar-header h2,
.integrations-overview h2,
.discord-header h1 {
  color: var(--white) !important;
  letter-spacing: 0 !important;
}

.dashboard-hero-copy h3 {
  font-size: clamp(34px, 4vw, 54px) !important;
}

.dashboard-new-card {
  min-height: 132px !important;
}

.dashboard-new-card--chat .dashboard-new-icon,
.dashboard-new-card--event .dashboard-new-icon,
.dashboard-new-card--reminder .dashboard-new-icon,
.calendar-day.is-today .calendar-day__number,
.discord-activity-item span,
.ai-native-status {
  color: var(--accent) !important;
}

.dashboard-task-board__head,
.section-head,
.dashboard-task-panel-head {
  min-height: 54px !important;
  padding: 14px 18px !important;
}

.dashboard-main-grid--figma,
.discord-layout,
.integration-detail-panel,
.settings-page {
  gap: 20px !important;
}

.calendar-theme-swatch[data-calendar-theme="#b450ff"],
.calendar-theme-swatch[data-calendar-theme="#31e981"],
.calendar-theme-swatch[data-calendar-theme="#63e2fe"],
.calendar-theme-swatch[data-calendar-theme="#ff7cf0"],
.calendar-theme-swatch[data-calendar-theme="#e7d44d"] {
  background: var(--accent) !important;
}

.calendar-day.is-today,
.dashboard-calendar-day.is-today {
  border-color: var(--accent-border) !important;
  box-shadow: inset 0 0 0 1px var(--accent-border) !important;
}

.chat-page {
  min-height: 100vh !important;
  display: grid !important;
  grid-template-columns: 300px minmax(0, 1fr) !important;
  background: var(--bg) !important;
}

.chat-page:has(.chat-members-sidebar:not([hidden])) {
  grid-template-columns: 300px minmax(0, 1fr) var(--profile-width) !important;
}

.chat-rail,
.chat-thread-panel,
.chat-members-sidebar {
  min-height: 100vh !important;
  border-radius: 0 !important;
}

.chat-thread-panel {
  padding: 22px !important;
}

.chat-list-item.is-active,
.chat-bubble.is-pinned,
.chat-message-flags span {
  border-color: var(--accent-border) !important;
  background: var(--accent-soft) !important;
}

.chat-composer {
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  background: var(--white) !important;
}

.chat-composer-toolbar {
  background: #f2f2f3 !important;
}

.chat-composer-send {
  background: var(--black) !important;
  color: var(--white) !important;
}

.ai-native-shell {
  min-height: 100vh !important;
  display: grid !important;
  grid-template-columns: 340px minmax(0, 1fr) !important;
  gap: 0 !important;
  background: var(--bg) !important;
}

.ai-native-shell:not(.is-history-open) {
  grid-template-columns: 340px minmax(0, 1fr) !important;
}

.ai-native-history {
  position: static !important;
  width: auto !important;
  min-height: 100vh !important;
  padding: 24px !important;
  border-width: 0 1px 0 0 !important;
  border-radius: 0 !important;
  opacity: 1 !important;
  overflow: auto !important;
  pointer-events: auto !important;
  transform: none !important;
}

.ai-native-shell:not(.is-history-open) .ai-native-history {
  display: flex !important;
  width: auto !important;
  padding: 24px !important;
  border-width: 0 1px 0 0 !important;
}

.ai-native-history__header {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
  gap: 18px !important;
}

.ai-native-history__header p {
  margin: 0 0 8px !important;
  color: var(--text-muted) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
}

.ai-native-history__header h2 {
  margin: 0 !important;
  color: var(--white) !important;
  font-size: 32px !important;
  line-height: 1.05 !important;
  font-weight: 750 !important;
}

.ai-native-action {
  min-height: 40px !important;
  max-width: 104px !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  font-size: 14px !important;
  font-weight: 750 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.ai-native-action::before {
  content: none !important;
}

.ai-native-history__meta {
  display: block !important;
  color: var(--text-muted) !important;
  font-size: 13px !important;
}

.ai-native-history__list {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  margin-top: 4px !important;
  overflow: auto !important;
}

.ai-native-history-item {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 8px !important;
  align-items: center !important;
  padding: 10px !important;
}

.ai-native-history-item.is-active {
  border-color: var(--accent-border) !important;
  background: var(--accent-soft) !important;
}

.ai-native-history-item__select {
  min-height: 44px !important;
  min-width: 0 !important;
  text-align: left !important;
}

.ai-native-history-item__select strong {
  display: block !important;
  margin: 0 0 4px !important;
  overflow: hidden !important;
  color: var(--white) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.ai-native-history-item__select span {
  display: block !important;
  overflow: hidden !important;
  color: var(--text-muted) !important;
  font-size: 12px !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.ai-native-history-item__delete,
.ai-native-history-item.has-delete .ai-native-history-item__delete {
  position: static !important;
  display: inline-flex !important;
  width: 30px !important;
  min-width: 30px !important;
  height: 30px !important;
  min-height: 30px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  border: 1px solid transparent !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: var(--text-muted) !important;
  font-size: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: none !important;
}

.ai-native-history-item__delete::before {
  content: "×" !important;
  font-size: 18px !important;
  line-height: 1 !important;
}

.ai-native-history-item:hover .ai-native-history-item__delete,
.ai-native-history-item.has-delete .ai-native-history-item__delete {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.ai-native-history-item__delete:hover {
  border-color: var(--border) !important;
  background: var(--panel-muted) !important;
  color: var(--white) !important;
}

.ai-native-panel {
  min-height: 100vh !important;
  padding: 24px 28px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: var(--bg) !important;
}

.ai-native-panel__header {
  min-height: 56px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 12px !important;
}

.ai-native-panel__header > div,
.ai-native-status {
  display: block !important;
}

.ai-native-menu-button {
  display: none !important;
}

.ai-native-plus-button {
  width: 40px !important;
  height: 40px !important;
  display: inline-grid !important;
  place-items: center !important;
  border: 1px solid var(--border) !important;
  border-radius: 999px !important;
  background: var(--panel-soft) !important;
  color: var(--white) !important;
  font-size: 24px !important;
  line-height: 1 !important;
}

.ai-native-plus-button:hover {
  border-color: var(--accent-border) !important;
  color: var(--accent) !important;
}

.ai-native-panel__header p {
  margin: 0 0 2px !important;
  color: var(--text-muted) !important;
  font-size: 12px !important;
}

.ai-native-panel__header h2 {
  margin: 0 !important;
  color: var(--white) !important;
  font-size: 20px !important;
}

.ai-native-thread {
  height: calc(100vh - 150px) !important;
  padding: 24px 4px 28px !important;
  gap: 14px !important;
  overflow: auto !important;
}

.ai-native-empty {
  width: min(640px, 100%) !important;
  margin: auto !important;
  padding: 28px !important;
}

.ai-native-message {
  max-width: min(720px, 78%) !important;
}

.ai-native-message__meta {
  display: block !important;
  color: var(--text-muted) !important;
  font-size: 12px !important;
}

.ai-native-message__body {
  padding: 14px 16px !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  background: var(--panel-soft) !important;
  color: var(--text) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

.ai-native-message--user .ai-native-message__body {
  border-color: var(--accent-border) !important;
  background: var(--accent) !important;
  color: var(--white) !important;
}

.ai-native-composer {
  width: min(860px, 100%) !important;
  min-height: 54px !important;
  margin: 0 auto !important;
  padding: 8px 8px 8px 18px !important;
  align-items: center !important;
  border: 1px solid var(--border-strong) !important;
  border-radius: 999px !important;
  background: var(--panel) !important;
}

.ai-native-composer:focus-within {
  border-color: var(--accent-border) !important;
  box-shadow: 0 0 0 4px var(--accent-soft) !important;
}

.ai-native-composer textarea {
  color: var(--text) !important;
  font-size: 15px !important;
}

.ai-native-send {
  position: relative !important;
  width: auto !important;
  min-width: 72px !important;
  height: 38px !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  background: var(--white) !important;
  color: var(--black) !important;
  font-size: 14px !important;
  font-weight: 750 !important;
}

.ai-native-send::before {
  content: none !important;
}

.ai-native-send:hover:not(:disabled),
.page-action:hover,
.task-action:hover,
.request-actions button:hover {
  background: var(--accent) !important;
  color: var(--white) !important;
  transform: translateY(-1px) !important;
}

@media (max-width: 900px) {
  html,
  body,
  .app-shell {
    min-width: 0 !important;
  }

  :root {
    --sidebar-width: 84px;
    --desktop-min-width: 0;
  }

  .app-shell {
    grid-template-columns: var(--sidebar-width) minmax(0, 1fr) !important;
  }

  .sidebar {
    position: sticky !important;
    width: var(--sidebar-width) !important;
    min-width: var(--sidebar-width) !important;
    max-width: var(--sidebar-width) !important;
    padding: 12px 8px !important;
  }

  .nav-label,
  .connect-apps-card span,
  .workspace-card > div:last-child,
  .sidebar-search {
    display: none !important;
  }

  .nav-item,
  .connect-apps-card,
  .workspace-card {
    justify-content: center !important;
    padding: 0 !important;
  }

  .main-stage,
  body[data-active-view="dashboard"] .main-stage,
  body[data-active-view="tasks"] .main-stage,
  body[data-active-view="integrations"] .main-stage,
  body[data-active-view="calendar"] .main-stage,
  body[data-active-view="notifications"] .main-stage,
  body[data-active-view="settings"] .main-stage {
    padding: 16px !important;
  }

  .dashboard-figma-top,
  .dashboard-main-grid--figma,
  .discord-layout,
  .integration-detail-panel,
  .settings-page,
  .chat-page,
  .chat-page:has(.chat-members-sidebar:not([hidden])),
  .ai-native-shell,
  .ai-native-shell:not(.is-history-open) {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .ai-native-history {
    min-height: auto !important;
    border-width: 0 0 1px 0 !important;
  }

  .ai-native-panel,
  .chat-rail,
  .chat-thread-panel,
  .chat-members-sidebar {
    min-height: auto !important;
  }

  .ai-native-message {
    max-width: 92% !important;
  }
}

/* Bottom control bar refactor */
:root {
  --sidebar-width: 0px;
  --control-ease: cubic-bezier(0.19, 1, 0.22, 1);
  --control-gradient: linear-gradient(135deg, #2c1c53 32%, #8b46d5 55%, #c546c1 63%, #e94194 72%, #f46532 86%, #fdbe3b 100%);
}

body,
body.has-mobile-menu-open {
  overflow-x: hidden;
}

.app-shell,
body[data-active-view="dashboard"] .app-shell,
body[data-active-view="tasks"] .app-shell,
body[data-active-view="integrations"] .app-shell,
body[data-active-view="calendar"] .app-shell,
body[data-active-view="notifications"] .app-shell,
body[data-active-view="settings"] .app-shell,
body[data-active-view="ai"] .app-shell,
body[data-active-view="chat"] .app-shell {
  display: block !important;
  min-width: 0 !important;
  max-width: none !important;
  width: 100%;
  margin: 0;
}

.mobile-menu-button,
.sidebar-overlay,
.sidebar,
.brand-mark,
.sidebar-search,
.sidebar-nav,
.sidebar-footer,
.sidebar-account-menu,
.workspace-card,
.connect-apps-card {
  display: none !important;
}

.main-stage,
body[data-active-view="dashboard"] .main-stage,
body[data-active-view="tasks"] .main-stage,
body[data-active-view="integrations"] .main-stage,
body[data-active-view="calendar"] .main-stage,
body[data-active-view="notifications"] .main-stage,
body[data-active-view="settings"] .main-stage {
  width: min(100%, 1540px) !important;
  margin: 0 auto !important;
  padding: 26px clamp(18px, 4vw, 58px) 148px !important;
}

body[data-active-view="ai"] .main-stage,
body[data-active-view="chat"] .main-stage {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 0 132px !important;
}

.view-panel {
  width: 100%;
}

.view-panel--board,
body[data-active-view="tasks"] .view-panel--board {
  max-width: 1320px !important;
  margin: 0 auto !important;
}

.ai-native-history {
  width: min(404px, calc(100vw - 108px));
}

.ai-native-composer {
  width: min(582px, calc(100vw - 120px));
}

.bottom-control-bar {
  position: fixed;
  left: 50%;
  bottom: max(16px, env(safe-area-inset-bottom));
  z-index: 70;
  transform: translateX(-50%);
  width: min(760px, calc(100vw - 22px));
  height: 96px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  pointer-events: auto;
  transition: transform 340ms var(--control-ease);
}

.bottom-control-rail {
  position: relative;
  height: 62px;
  width: min(620px, 100%);
  padding: 6px 22px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 92px minmax(0, 1fr);
  align-items: center;
  justify-content: center;
  gap: 4px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(245, 245, 242, 0.88)), #ffffff;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.9);
  pointer-events: auto;
  transition: width 360ms var(--control-ease) 700ms, grid-template-columns 360ms var(--control-ease) 700ms, gap 340ms var(--control-ease) 700ms, padding 340ms var(--control-ease) 700ms, box-shadow 340ms var(--control-ease) 700ms;
}

.bottom-control-rail::after {
  content: "";
  position: absolute;
  left: 7%;
  right: 7%;
  bottom: -13px;
  height: 20px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.28);
  filter: blur(16px);
  opacity: 0.72;
  pointer-events: none;
  transform: translateY(2px);
  transition: opacity 340ms var(--control-ease), transform 340ms var(--control-ease);
}

.bottom-control-bar:hover .bottom-control-rail,
.bottom-control-bar:focus-within .bottom-control-rail,
.bottom-control-bar:has(.new-menu:not([hidden])) .bottom-control-rail {
  width: 100%;
  grid-template-columns: minmax(0, 1fr) 92px minmax(0, 1fr);
  gap: 5px;
  padding-inline: 26px;
  box-shadow: 0 22px 52px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.bottom-control-bar:hover .bottom-control-rail::after,
.bottom-control-bar:focus-within .bottom-control-rail::after,
.bottom-control-bar:has(.new-menu:not([hidden])) .bottom-control-rail::after {
  opacity: 0.86;
  transform: translateY(3px) scaleX(1.03);
}

.bottom-control-rail::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -30px;
  width: 82px;
  height: 82px;
  border-radius: 50%;
  background: #ffffff;
  box-shadow: 0 9px 20px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.9);
  transform: translateX(-50%);
  pointer-events: none;
}

.bottom-control-compose {
  position: relative;
  z-index: 2;
  width: 92px;
  height: 88px;
  margin: -30px 2px 0;
  display: grid;
  place-items: center;
  justify-self: center;
}

.bottom-control-group {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 4px;
  transition: gap 340ms var(--control-ease) 700ms;
}

.bottom-control-bar:hover .bottom-control-group,
.bottom-control-bar:focus-within .bottom-control-group,
.bottom-control-bar:has(.new-menu:not([hidden])) .bottom-control-group {
  gap: 5px;
}

.bottom-control-group--left {
  justify-content: flex-end;
}

.bottom-control-group--right {
  justify-content: flex-start;
}

.bottom-control-bar .nav-item {
  position: relative;
  z-index: 1;
  width: 50px;
  min-width: 50px;
  height: 50px;
  min-height: 50px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  overflow: hidden;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #0b0b0c !important;
  cursor: pointer;
  transform: translateY(0) scale(1);
  transition: width 320ms var(--control-ease), min-width 320ms var(--control-ease), background-color 320ms var(--control-ease), box-shadow 320ms var(--control-ease), transform 320ms var(--control-ease), color 220ms ease;
}

.bottom-control-bar .nav-item:hover,
.bottom-control-bar .nav-item:focus-visible {
  width: 146px;
  min-width: 146px;
  background: transparent !important;
  box-shadow: none !important;
  transform: translateY(-1px);
  transition-delay: 700ms, 700ms, 0ms, 0ms, 700ms, 0ms;
}

.bottom-control-bar .nav-icon {
  flex: 0 0 auto;
  font-size: 25px;
  line-height: 1;
  color: #0b0b0c !important;
  transform: translateY(-2px);
  transition: transform 320ms var(--control-ease), color 240ms ease, filter 240ms ease;
}

.bottom-control-bar .nav-icon::before {
  color: currentColor;
}

.bottom-control-bar .nav-item:hover .nav-icon,
.bottom-control-bar .nav-item:focus-visible .nav-icon {
  transform: translateY(-2px);
}

.bottom-control-bar .nav-label {
  max-width: 0;
  opacity: 0;
  color: #0b0b0c !important;
  white-space: nowrap;
  overflow: hidden;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0;
  transform: translateX(-6px);
  transition: opacity 240ms ease 700ms, max-width 320ms var(--control-ease) 700ms, transform 320ms var(--control-ease) 700ms;
}

.bottom-control-bar .nav-item:hover .nav-label,
.bottom-control-bar .nav-item:focus-visible .nav-label {
  max-width: 96px;
  opacity: 1;
  transform: translateX(0);
  color: #0b0b0c !important;
}

.bottom-control-bar .nav-item.is-active {
  background: transparent !important;
  border-color: transparent !important;
  outline: 0 !important;
  color: #0b0b0c !important;
  box-shadow: none !important;
}

.bottom-control-bar .nav-item.is-active:hover,
.bottom-control-bar .nav-item.is-active:focus-visible {
  background: transparent !important;
  box-shadow: none !important;
}

.bottom-control-bar .nav-item.is-active .nav-icon {
  color: #0b0b0c !important;
  filter: drop-shadow(0 4px 8px rgba(233, 65, 148, 0.16));
}

.bottom-control-bar .nav-item.is-active .nav-icon::before {
  color: transparent;
  background: var(--control-gradient);
  -webkit-background-clip: text;
  background-clip: text;
}

.bottom-control-bar .nav-item.is-active .nav-label {
  color: #202020;
}

.bottom-control-bar .nav-item.is-active:hover .nav-label,
.bottom-control-bar .nav-item.is-active:focus-visible .nav-label {
  color: #202020;
}

.bottom-control-bar .nav-item--new,
.bottom-control-bar .nav-item--new:hover,
.bottom-control-bar .nav-item--new:focus-visible {
  width: 82px;
  min-width: 82px;
  height: 82px;
  min-height: 82px;
  padding: 0;
  background: transparent !important;
  color: #0f0f10;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
}

.bottom-control-bar .nav-item--new:hover,
.bottom-control-bar .nav-item--new:focus-visible {
  background: transparent !important;
  transform: none;
}

.bottom-control-bar .nav-item--new .nav-icon {
  font-size: 34px;
  transform: translateY(-4px) !important;
}

.bottom-control-bar .nav-item--new:hover .nav-icon,
.bottom-control-bar .nav-item--new:focus-visible .nav-icon {
  transform: translateY(-4px) !important;
}

.bottom-control-bar .nav-item--new .nav-label {
  display: none;
}

.bottom-control-bar .notification-dot {
  position: absolute;
  top: 9px;
  right: 10px;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--red);
  box-shadow: 0 0 0 3px rgba(255, 91, 107, 0.16);
}

.bottom-control-bar .new-menu {
  position: absolute !important;
  left: 50% !important;
  top: auto !important;
  bottom: calc(100% + 16px) !important;
  z-index: 80 !important;
  width: 178px !important;
  padding: 8px !important;
  display: grid !important;
  gap: 4px;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  border-radius: 16px !important;
  background: rgba(24, 24, 24, 0.96) !important;
  color: #f5f5f2 !important;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.38) !important;
  transform: translate(-50%, 0) scale(1) !important;
  animation: controlPopupIn 240ms var(--control-ease);
}

.bottom-control-bar .new-menu::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -5px;
  width: 10px;
  height: 10px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(24, 24, 24, 0.96);
  transform: translateX(-50%) rotate(45deg);
}

.bottom-control-bar .new-menu[hidden] {
  display: none !important;
}

.bottom-control-bar .new-menu-item {
  position: relative;
  z-index: 1;
  min-height: 38px !important;
  padding: 0 12px !important;
  border-radius: 10px !important;
  color: #f5f5f2 !important;
  font-size: 13px !important;
  font-weight: 700;
  text-align: left !important;
  cursor: pointer;
  transition: background-color 220ms ease, transform 240ms var(--control-ease), color 220ms ease;
}

.bottom-control-bar .new-menu-item:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  transform: translateY(-1px);
}

@keyframes controlPopupIn {
  from {
    opacity: 0;
    transform: translate(-50%, 10px) scale(0.98);
  }

  to {
    opacity: 1;
    transform: translate(-50%, 0) scale(1);
  }
}

@media (max-width: 760px) {
  .main-stage,
  body[data-active-view="dashboard"] .main-stage,
  body[data-active-view="tasks"] .main-stage,
  body[data-active-view="integrations"] .main-stage,
  body[data-active-view="calendar"] .main-stage,
  body[data-active-view="notifications"] .main-stage,
  body[data-active-view="settings"] .main-stage {
    padding: 18px 14px 140px !important;
  }

  .bottom-control-bar {
    width: min(548px, calc(100vw - 18px));
    height: 74px;
  }

  .bottom-control-rail {
    width: min(456px, 100%);
    grid-template-columns: minmax(0, 1fr) 80px minmax(0, 1fr);
    height: 56px;
    padding: 5px 18px;
  }

  .bottom-control-bar:hover .bottom-control-rail,
  .bottom-control-bar:focus-within .bottom-control-rail,
  .bottom-control-bar:has(.new-menu:not([hidden])) .bottom-control-rail {
    width: 100%;
    grid-template-columns: minmax(0, 1fr) 80px minmax(0, 1fr);
  }

  .bottom-control-bar .nav-item {
    width: 42px;
    min-width: 42px;
    height: 44px;
    min-height: 44px;
    padding: 0 9px;
  }

  .bottom-control-bar .nav-item:hover,
  .bottom-control-bar .nav-item:focus-visible {
    width: 92px;
    min-width: 92px;
  }

  .bottom-control-bar .nav-icon {
    font-size: 21px;
  }

  .bottom-control-compose {
    width: 80px;
    height: 76px;
    margin-top: -27px;
  }

  .bottom-control-rail::before {
    top: -27px;
    width: 72px;
    height: 72px;
  }

  .bottom-control-bar .nav-item--new,
  .bottom-control-bar .nav-item--new:hover,
  .bottom-control-bar .nav-item--new:focus-visible {
    width: 66px;
    min-width: 66px;
    height: 66px;
    min-height: 66px;
  }
}

/* Final priority: keep the conversation as the main screen */
body[data-active-view="chat"] .chat-page.messaging-workspace,
body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
  --message-rail: 68px;
  --activity-side: clamp(190px, 18vw, 260px);
  display: grid !important;
  grid-template-areas: "rail thread activity" !important;
  grid-template-columns: var(--message-rail) minmax(0, 1fr) var(--activity-side) !important;
  grid-template-rows: minmax(0, 1fr) !important;
}

body[data-active-view="chat"] .messaging-left-rail {
  grid-area: rail !important;
}

body[data-active-view="chat"] .messaging-chat-shell {
  grid-area: thread !important;
}

body[data-active-view="chat"] .messaging-directory {
  grid-area: activity !important;
  padding: 32px 18px 116px !important;
  border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-right: 0 !important;
}

body[data-active-view="chat"] .chat-thread-panel.messaging-chat-shell {
  width: auto !important;
  min-width: 0 !important;
  border-left: 0 !important;
  border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
  box-shadow: none !important;
}

body[data-active-view="chat"] .messaging-directory-header h2 {
  font-size: clamp(28px, 2.5vw, 36px) !important;
}

body[data-active-view="chat"] .messaging-list {
  width: 100% !important;
}

body[data-active-view="chat"] .mention-activity-row,
body[data-active-view="chat"] .messaging-object-row.mention-activity-row {
  grid-template-columns: 40px minmax(0, 1fr) !important;
}

body[data-active-view="chat"] .mention-activity-row em {
  position: absolute !important;
  right: 12px !important;
  top: 12px !important;
}

body[data-active-view="chat"] .mention-row-copy {
  padding-right: 34px !important;
}

body[data-active-view="chat"] .mention-row-actions {
  display: none !important;
}

body[data-active-view="chat"] .chat-thread-scroll {
  padding-inline: clamp(20px, 5vw, 72px) !important;
}

body[data-active-view="chat"] .chat-bubble {
  max-width: min(760px, 96%) !important;
}

body[data-active-view="chat"] .chat-composer.messaging-composer {
  margin-inline: clamp(14px, 3.2vw, 42px) !important;
  margin-bottom: 112px !important;
  overflow: visible !important;
  z-index: 80 !important;
}

body[data-active-view="chat"] .composer-command-menu,
body[data-active-view="chat"] .composer-mention-menu,
body[data-active-view="chat"] .composer-add-menu,
body[data-active-view="chat"] .chat-emoji-panel {
  z-index: 120 !important;
  bottom: calc(100% + 12px) !important;
  width: min(340px, calc(100vw - 244px)) !important;
  max-width: calc(100vw - 244px) !important;
}

@media (max-width: 900px) {
  body[data-active-view="chat"] .chat-page.messaging-workspace,
  body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
    --message-rail: 64px;
    --activity-side: 190px;
    grid-template-areas: "rail thread activity" !important;
    grid-template-columns: var(--message-rail) minmax(0, 1fr) var(--activity-side) !important;
    grid-template-rows: minmax(0, 1fr) !important;
  }

  body[data-active-view="chat"] .messaging-directory {
    padding-inline: 12px !important;
  }

  body[data-active-view="chat"] .messaging-directory-header h2 {
    font-size: 26px !important;
  }

  body[data-active-view="chat"] .messaging-directory-actions #chatCreateButton {
    display: none !important;
  }

  body[data-active-view="chat"] .messaging-chat-header [data-chat-action="live"],
  body[data-active-view="chat"] .messaging-chat-header [data-chat-panel="pins"] {
    display: none !important;
  }

  body[data-active-view="chat"] .chat-composer-command,
  body[data-active-view="chat"] .chat-composer-ai {
    display: inline-grid !important;
  }

  body[data-active-view="chat"] .messaging-composer .chat-composer-entry {
    grid-template-columns: 34px 34px minmax(0, 1fr) repeat(5, 34px) !important;
  }
}

/* Control dock: Kovo Figma 3 hover states */
.bottom-control-bar {
  --dock-rail-width: min(646px, calc(100vw - 38px));
  --dock-rail-height: 64px;
  --dock-item-size: 42px;
  --dock-hover-width: 132px;
  --dock-label-width: 78px;
  --dock-compose-size: 78px;
  --dock-gap: 6px;
  bottom: max(14px, env(safe-area-inset-bottom)) !important;
  width: var(--dock-rail-width) !important;
  height: 96px !important;
  align-items: flex-end !important;
}

.bottom-control-rail {
  width: var(--dock-rail-width) !important;
  height: var(--dock-rail-height) !important;
  padding: 11px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: var(--dock-gap) !important;
  overflow: visible !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.4) !important;
  backdrop-filter: none !important;
  box-shadow: none !important;
}

.bottom-control-bar:hover .bottom-control-rail,
.bottom-control-bar:focus-within .bottom-control-rail,
.bottom-control-bar:has(.new-menu:not([hidden])) .bottom-control-rail {
  width: var(--dock-rail-width) !important;
  padding-inline: 11px !important;
  gap: var(--dock-gap) !important;
  box-shadow: none !important;
}

.bottom-control-rail::before,
.bottom-control-rail::after {
  content: none !important;
}

.bottom-control-group {
  height: var(--dock-item-size) !important;
  display: flex !important;
  align-items: center !important;
  gap: var(--dock-gap) !important;
  min-width: 0 !important;
  transition: gap 220ms var(--control-ease) !important;
}

.bottom-control-bar:hover .bottom-control-group,
.bottom-control-bar:focus-within .bottom-control-group,
.bottom-control-bar:has(.new-menu:not([hidden])) .bottom-control-group {
  gap: var(--dock-gap) !important;
}

.bottom-control-group--left,
.bottom-control-group--right {
  flex: 0 1 auto !important;
}

.bottom-control-compose {
  width: var(--dock-compose-size) !important;
  height: var(--dock-compose-size) !important;
  margin: -19px 0 0 !important;
  flex: 0 0 var(--dock-compose-size) !important;
  display: grid !important;
  place-items: center !important;
}

.bottom-control-bar .nav-item {
  width: var(--dock-item-size) !important;
  min-width: var(--dock-item-size) !important;
  height: var(--dock-item-size) !important;
  min-height: var(--dock-item-size) !important;
  padding: 0 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  box-shadow: none !important;
  color: #000000 !important;
  transform: none !important;
  transition: width 260ms var(--control-ease), min-width 260ms var(--control-ease), gap 260ms var(--control-ease), transform 220ms var(--control-ease), background-color 180ms ease !important;
}

.bottom-control-bar .nav-item:hover,
.bottom-control-bar .nav-item:focus-visible {
  width: var(--dock-hover-width) !important;
  min-width: var(--dock-hover-width) !important;
  background: #ffffff !important;
  color: #000000 !important;
  transform: none !important;
  outline: 0 !important;
  gap: 8px !important;
}

.bottom-control-bar .nav-item.is-active,
.bottom-control-bar .nav-item.is-active:hover,
.bottom-control-bar .nav-item.is-active:focus-visible {
  background: #ffffff !important;
  box-shadow: none !important;
  color: #000000 !important;
}

.bottom-control-bar .nav-item.is-active::after {
  content: none !important;
}

.bottom-control-bar .nav-icon {
  width: 22px !important;
  height: 22px !important;
  flex: 0 0 22px !important;
  object-fit: contain !important;
  font-size: 22px !important;
  color: #000000 !important;
  filter: none !important;
  transform: none !important;
}

.bottom-control-bar i.nav-icon {
  display: inline-grid !important;
  place-items: center !important;
  line-height: 1 !important;
}

.bottom-control-bar .nav-icon::before {
  color: currentColor !important;
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
}

.bottom-control-bar .nav-label {
  max-width: 0 !important;
  opacity: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #000000 !important;
  backdrop-filter: none !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  transform: translateX(-8px) !important;
  transition: max-width 260ms var(--control-ease), opacity 180ms ease 60ms, transform 260ms var(--control-ease) !important;
}

.bottom-control-bar .nav-item:hover .nav-label,
.bottom-control-bar .nav-item:focus-visible .nav-label {
  max-width: var(--dock-label-width) !important;
  opacity: 1 !important;
  transform: translateX(0) !important;
}

.bottom-control-bar .nav-item--new,
.bottom-control-bar .nav-item--new:hover,
.bottom-control-bar .nav-item--new:focus-visible {
  width: var(--dock-compose-size) !important;
  min-width: var(--dock-compose-size) !important;
  height: var(--dock-compose-size) !important;
  min-height: var(--dock-compose-size) !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  transform: none !important;
}

.bottom-control-bar .nav-item--new .nav-icon {
  width: 34px !important;
  height: 34px !important;
  flex-basis: 34px !important;
  transform: none !important;
}

.bottom-control-bar .nav-item--new .nav-label {
  display: none !important;
}

.bottom-control-bar .notification-dot {
  top: 10px !important;
  right: 10px !important;
}

.bottom-control-bar .new-menu {
  bottom: calc(100% + 14px) !important;
}

@media (max-width: 980px) {
  .bottom-control-bar {
    --dock-rail-width: min(548px, calc(100vw - 18px));
    --dock-rail-height: 56px;
    --dock-item-size: 38px;
    --dock-hover-width: 118px;
    --dock-label-width: 72px;
    --dock-compose-size: 66px;
    --dock-gap: 4px;
    height: 74px !important;
  }

  .bottom-control-rail {
    border-radius: 31px !important;
    padding: 9px !important;
  }

  .bottom-control-bar:hover .bottom-control-rail,
  .bottom-control-bar:focus-within .bottom-control-rail,
  .bottom-control-bar:has(.new-menu:not([hidden])) .bottom-control-rail {
    padding-inline: 9px !important;
  }

  .bottom-control-compose {
    margin-top: -15px !important;
  }

  .bottom-control-bar .nav-item {
    padding-inline: 9px !important;
    border-radius: 28px !important;
  }

  .bottom-control-bar .nav-item:hover,
  .bottom-control-bar .nav-item:focus-visible {
    gap: 7px !important;
  }

  .bottom-control-bar .nav-icon {
    width: 20px !important;
    height: 20px !important;
    flex-basis: 20px !important;
    font-size: 20px !important;
  }

  .bottom-control-bar .nav-label {
    font-size: 11px !important;
  }

  .bottom-control-bar .nav-item--new .nav-icon {
    width: 29px !important;
    height: 29px !important;
    flex-basis: 29px !important;
  }
}

@media (max-width: 620px) {
  .bottom-control-bar {
    --dock-rail-width: min(430px, calc(100vw - 14px));
    --dock-rail-height: 48px;
    --dock-item-size: 34px;
    --dock-hover-width: 96px;
    --dock-label-width: 58px;
    --dock-compose-size: 58px;
    --dock-gap: 4px;
    height: 66px !important;
  }

  .bottom-control-group {
    gap: var(--dock-gap) !important;
  }

  .bottom-control-rail {
    padding: 7px !important;
  }

  .bottom-control-bar:hover .bottom-control-rail,
  .bottom-control-bar:focus-within .bottom-control-rail,
  .bottom-control-bar:has(.new-menu:not([hidden])) .bottom-control-rail {
    padding-inline: 7px !important;
  }

  .bottom-control-compose {
    margin-top: -13px !important;
  }

  .bottom-control-bar .nav-item {
    padding-inline: 8px !important;
  }

  .bottom-control-bar .nav-icon {
    width: 18px !important;
    height: 18px !important;
    flex-basis: 18px !important;
    font-size: 18px !important;
  }

  .bottom-control-bar .nav-label {
    font-size: 10px !important;
  }

  .bottom-control-bar .nav-item--new .nav-icon {
    width: 26px !important;
    height: 26px !important;
    flex-basis: 26px !important;
  }
}

/* Chat-first layout: conversation becomes the main screen, Activity moves to the side */
body[data-active-view="chat"] .chat-page.messaging-workspace,
body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
  --message-rail: 68px;
  --activity-side: clamp(190px, 18vw, 260px);
  display: grid !important;
  grid-template-areas: "rail thread activity" !important;
  grid-template-columns: var(--message-rail) minmax(0, 1fr) var(--activity-side) !important;
  grid-template-rows: minmax(0, 1fr) !important;
}

body[data-active-view="chat"] .messaging-left-rail {
  grid-area: rail !important;
}

body[data-active-view="chat"] .messaging-chat-shell {
  grid-area: thread !important;
}

body[data-active-view="chat"] .messaging-directory {
  grid-area: activity !important;
}

body[data-active-view="chat"] .chat-thread-panel.messaging-chat-shell {
  width: auto !important;
  min-width: 0;
  border-left: 0 !important;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  background:
    radial-gradient(circle at 50% -18%, rgba(255, 255, 255, 0.08), transparent 38%),
    linear-gradient(180deg, #ede9df 0%, #ded8cc 100%) !important;
  box-shadow: none !important;
}

body[data-active-view="chat"] .messaging-directory {
  height: 100vh !important;
  padding: 32px 18px 116px !important;
  border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.026), rgba(255, 255, 255, 0.012)),
    rgba(13, 14, 12, 0.74) !important;
  box-shadow: inset 1px 0 rgba(255, 255, 255, 0.025);
}

body[data-active-view="chat"] .messaging-directory::after {
  inset: 112px 12px 106px !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.025) !important;
}

body[data-active-view="chat"] .messaging-directory-header {
  min-height: 52px !important;
}

body[data-active-view="chat"] .messaging-directory-header h2 {
  font-size: clamp(28px, 2.5vw, 36px) !important;
}

body[data-active-view="chat"] .messaging-directory-actions {
  padding-bottom: 3px !important;
}

body[data-active-view="chat"] .messaging-directory-actions button {
  width: 36px !important;
  height: 36px !important;
}

body[data-active-view="chat"] .messaging-directory-search {
  width: 100% !important;
  margin: 22px 0 20px !important;
}

body[data-active-view="chat"] .messaging-list {
  width: 100% !important;
}

body[data-active-view="chat"] .mention-activity-row,
body[data-active-view="chat"] .messaging-object-row.mention-activity-row {
  min-height: 70px !important;
  grid-template-columns: 40px minmax(0, 1fr) !important;
  border-color: rgba(255, 255, 255, 0.075) !important;
  background: rgba(255, 255, 255, 0.052) !important;
}

body[data-active-view="chat"] .mention-activity-row em {
  position: absolute;
  right: 12px;
  top: 12px;
}

body[data-active-view="chat"] .mention-row-copy {
  padding-right: 34px;
}

body[data-active-view="chat"] .mention-row-actions {
  display: none;
}

body[data-active-view="chat"] .messaging-chat-header {
  padding: 22px clamp(22px, 3.2vw, 42px) 16px !important;
  grid-template-columns: minmax(0, 1fr) auto auto !important;
  grid-template-areas:
    "title ai actions" !important;
  align-items: center;
}

body[data-active-view="chat"] .messaging-chat-header .chat-channel-title {
  grid-template-columns: 46px minmax(0, 1fr) !important;
}

body[data-active-view="chat"] .messaging-chat-header .chat-channel-title-icon {
  width: 46px !important;
  height: 46px !important;
}

body[data-active-view="chat"] .messaging-chat-header .chat-channel-title h2 {
  font-size: 22px !important;
}

body[data-active-view="chat"] .chat-ai-pill {
  justify-self: end;
}

body[data-active-view="chat"] .messaging-chat-header .chat-thread-actions {
  grid-template-columns: repeat(4, 34px) !important;
}

body[data-active-view="chat"] .messaging-chat-header .chat-icon-button {
  width: 34px !important;
  height: 34px !important;
}

body[data-active-view="chat"] .messaging-connection-banner {
  max-width: 680px;
  margin: 14px clamp(22px, 3.2vw, 42px) 0 !important;
}

body[data-active-view="chat"] .chat-thread-scroll {
  padding: 24px clamp(26px, 5vw, 72px) 18px !important;
}

body[data-active-view="chat"] .chat-bubble {
  max-width: min(720px, 84%) !important;
  grid-template-columns: 38px minmax(0, 1fr) !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
}

body[data-active-view="chat"] .chat-bubble-avatar {
  width: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;
}

body[data-active-view="chat"] .chat-bubble-body {
  padding: 14px 16px !important;
  border-radius: 18px !important;
}

body[data-active-view="chat"] .chat-bubble-body p {
  font-size: 14px !important;
}

body[data-active-view="chat"] .messaging-typing-line {
  padding: 0 clamp(26px, 5vw, 72px) !important;
}

body[data-active-view="chat"] .chat-composer.messaging-composer {
  margin: 0 clamp(22px, 3.2vw, 42px) 92px !important;
}

@media (max-width: 900px) {
  body[data-active-view="chat"] .chat-page.messaging-workspace,
  body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
    --message-rail: 64px;
    --activity-side: 190px;
    grid-template-areas: "rail thread activity" !important;
    grid-template-columns: var(--message-rail) minmax(0, 1fr) var(--activity-side) !important;
    grid-template-rows: minmax(0, 1fr) !important;
  }

  body[data-active-view="chat"] .messaging-directory {
    padding-inline: 12px !important;
  }

  body[data-active-view="chat"] .messaging-directory-header h2 {
    font-size: 26px !important;
  }

  body[data-active-view="chat"] .messaging-directory-actions button {
    width: 34px !important;
    height: 34px !important;
  }

  body[data-active-view="chat"] .messaging-directory-search {
    height: 38px !important;
    margin-top: 18px !important;
  }

  body[data-active-view="chat"] .mention-activity-row,
  body[data-active-view="chat"] .messaging-object-row.mention-activity-row {
    grid-template-columns: 38px minmax(0, 1fr) !important;
  }

  body[data-active-view="chat"] .mention-activity-row em {
    position: absolute;
    right: 12px;
    top: 12px;
  }

  body[data-active-view="chat"] .mention-row-copy {
    padding-right: 34px;
  }

  body[data-active-view="chat"] .mention-row-actions {
    display: none;
  }

  body[data-active-view="chat"] .messaging-chat-header {
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-areas:
      "title actions"
      "ai actions" !important;
    padding-inline: 18px !important;
  }

  body[data-active-view="chat"] .chat-ai-pill {
    justify-self: start;
  }

  body[data-active-view="chat"] .messaging-chat-header [data-chat-action="live"],
  body[data-active-view="chat"] .messaging-chat-header [data-chat-panel="pins"] {
    display: none !important;
  }

  body[data-active-view="chat"] .messaging-chat-header .chat-thread-actions {
    grid-template-columns: repeat(3, 32px) !important;
  }

  body[data-active-view="chat"] .chat-thread-scroll {
    padding-inline: 20px !important;
  }

  body[data-active-view="chat"] .chat-bubble {
    max-width: 96% !important;
  }

  body[data-active-view="chat"] .chat-composer.messaging-composer {
    margin-inline: 14px !important;
  }

  body[data-active-view="chat"] .chat-composer-command,
  body[data-active-view="chat"] .chat-composer-ai {
    display: inline-grid !important;
  }

  body[data-active-view="chat"] .messaging-composer .chat-composer-entry {
    grid-template-columns: 34px 34px minmax(0, 1fr) repeat(5, 34px) !important;
  }
}

body[data-active-view="ai"] .ai-native-panel,
body[data-active-view="ai"] .ai-native-thread {
  padding-bottom: 190px !important;
}

body[data-active-view="ai"],
body[data-active-view="chat"] {
  overflow: hidden !important;
  height: 100vh !important;
}

body[data-active-view="ai"] .view-panel,
body[data-active-view="chat"] .view-panel {
  height: 100vh !important;
  overflow: hidden !important;
}

body[data-active-view="ai"] .ai-native-composer {
  position: fixed !important;
  left: 50% !important;
  right: auto !important;
  bottom: max(136px, calc(env(safe-area-inset-bottom) + 136px)) !important;
  z-index: 60 !important;
  width: min(620px, calc(100vw - 34px)) !important;
  margin: 0 !important;
  transform: translateX(-50%) !important;
}

body[data-active-view="chat"] .chat-thread-panel {
  position: relative !important;
  height: 100vh !important;
  max-height: 100vh !important;
  overflow: hidden !important;
  padding-bottom: 190px !important;
}

body[data-active-view="chat"] .chat-thread {
  padding-bottom: 28px !important;
}

body[data-active-view="chat"] .chat-page {
  height: 100vh !important;
  max-height: 100vh !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

body[data-active-view="chat"] .chat-rail,
body[data-active-view="chat"] .chat-members-sidebar {
  height: 100vh !important;
  max-height: 100vh !important;
  overflow: hidden auto !important;
}

body[data-active-view="chat"] .chat-thread-scroll {
  min-height: 0 !important;
  overflow: auto !important;
  padding-bottom: 96px !important;
}

body[data-active-view="chat"] .chat-composer {
  position: fixed !important;
  left: 50% !important;
  right: auto !important;
  bottom: max(136px, calc(env(safe-area-inset-bottom) + 136px)) !important;
  z-index: 60 !important;
  width: min(720px, calc(100vw - 34px)) !important;
  margin: 0 !important;
  transform: translateX(-50%) !important;
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.34) !important;
}

/* Messaging production workspace */
body[data-active-view="chat"] .main-stage {
  padding: 0 !important;
}

body[data-active-view="chat"] .chat-page.messaging-workspace {
  --message-rail: 72px;
  --message-directory: 324px;
  --message-context: 392px;
  height: 100vh !important;
  max-height: 100vh !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: var(--message-rail) var(--message-directory) minmax(560px, 1fr);
  overflow: hidden !important;
  background: #111210;
  color: #f4f2ed;
}

body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
  grid-template-columns: var(--message-rail) var(--message-directory) minmax(480px, 1fr) var(--message-context);
}

.messaging-left-rail {
  position: relative;
  z-index: 4;
  width: var(--message-rail);
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 14px 10px;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  background: #171816;
}

.messaging-left-top,
.messaging-rail-nav,
.messaging-left-bottom {
  display: grid;
  gap: 8px;
}

.messaging-left-bottom {
  margin-top: auto;
}

.messaging-brand-button,
.messaging-rail-button,
.messaging-profile-dot {
  position: relative;
  width: 48px;
  height: 48px;
  display: inline-grid;
  place-items: center;
  border-radius: 14px;
  color: #bdbbb4;
  cursor: pointer;
  transition: transform 140ms ease, background 140ms ease, color 140ms ease;
}

.messaging-brand-button img {
  width: 27px;
  height: 27px;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: 0.9;
}

.messaging-brand-button span,
.messaging-rail-button span {
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  z-index: 30;
  min-width: max-content;
  padding: 7px 9px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  background: #232520;
  color: #f4f2ed;
  font-size: 12px;
  font-weight: 700;
  opacity: 0;
  pointer-events: none;
  transform: translate(-8px, -50%) scale(0.96);
  transition: opacity 160ms ease, transform 160ms ease;
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.28);
}

.messaging-brand-button:hover,
.messaging-rail-button:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.06);
  color: #ffffff;
}

.messaging-brand-button:hover span,
.messaging-rail-button:hover span {
  opacity: 1;
  transform: translate(0, -50%) scale(1);
}

.messaging-rail-button.is-active {
  background: #e7e4dc;
  color: #161714;
}

.messaging-rail-button.is-active::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 13px;
  width: 3px;
  height: 22px;
  border-radius: 999px;
  background: #9fdc7c;
}

.messaging-profile-dot {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: #22231f;
  color: #ffffff;
  font-weight: 800;
}

.messaging-profile-dot small {
  position: absolute;
  right: 8px;
  bottom: 8px;
  width: 9px;
  height: 9px;
  border: 2px solid #22231f;
  border-radius: 999px;
  background: #55d57a;
}

.messaging-directory {
  position: relative;
  height: 100vh;
  min-width: 0;
  display: flex;
  flex-direction: column;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  background: #1d1f1b;
}

.messaging-directory-header {
  position: sticky;
  top: 0;
  z-index: 2;
  min-height: 82px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 16px 12px;
  background: rgba(29, 31, 27, 0.96);
}

.messaging-directory-header p,
.messaging-directory-header h2,
.chat-channel-title p,
.chat-channel-title h2 {
  margin: 0;
}

.messaging-directory-header p,
.chat-channel-title p {
  color: #a6a49d;
  font-size: 12px;
  font-weight: 700;
}

.messaging-directory-header h2 {
  margin-top: 3px;
  color: #ffffff;
  font-size: 22px;
  line-height: 1.15;
}

.messaging-directory-actions {
  display: flex;
  gap: 6px;
}

.messaging-directory-actions button,
.chat-icon-button {
  width: 34px;
  height: 34px;
  display: inline-grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.055);
  color: #d7d4ca;
  cursor: pointer;
  transition: transform 120ms ease, background 120ms ease, color 120ms ease;
}

.messaging-directory-actions button:hover,
.chat-icon-button:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.1);
  color: #ffffff;
}

.messaging-directory-search {
  height: 38px;
  margin: 0 14px 12px;
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  padding: 0 11px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 10px;
  background: #151713;
  color: #8f8d86;
}

.messaging-directory-search input,
.context-search input,
.context-field input,
.context-field select,
.messaging-new-popover input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: #f7f5ee;
}

.messaging-list {
  min-height: 0;
  flex: 1;
  overflow: auto;
  padding: 0 10px 18px;
}

.messaging-conversation-row,
.messaging-channel-row,
.messaging-object-row {
  position: relative;
  width: 100%;
  min-height: 68px;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: 10px;
  color: #e7e4dc;
  text-align: left;
  cursor: pointer;
  transition: background 140ms ease, transform 140ms ease;
}

.messaging-conversation-row:hover,
.messaging-channel-row:hover,
.messaging-object-row:hover {
  background: rgba(255, 255, 255, 0.055);
}

.messaging-conversation-row.is-active,
.messaging-channel-row.is-active {
  background: #303229;
}

.messaging-conversation-row.is-active::before,
.messaging-channel-row.is-active::before {
  content: "";
  position: absolute;
  left: 0;
  top: 14px;
  width: 3px;
  height: calc(100% - 28px);
  border-radius: 999px;
  background: #9fdc7c;
}

.messaging-row-avatar {
  position: relative;
  width: 40px;
  height: 40px;
  display: inline-grid;
  place-items: center;
  border-radius: 12px;
  background: #d9d4c9;
  color: #1b1c18;
  font-size: 13px;
  font-weight: 900;
}

.messaging-row-avatar i {
  position: absolute;
  right: -1px;
  bottom: -1px;
  width: 10px;
  height: 10px;
  border: 2px solid #1d1f1b;
  border-radius: 999px;
  background: #55d57a;
}

.messaging-row-main,
.messaging-object-row span,
.messaging-channel-row span {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.messaging-row-title {
  min-width: 0;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.messaging-row-title strong,
.messaging-channel-row strong,
.messaging-object-row strong {
  overflow: hidden;
  color: #ffffff;
  font-size: 14px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.messaging-conversation-row.is-unread strong {
  font-weight: 900;
}

.messaging-row-title em,
.messaging-object-row em {
  color: #9c9a92;
  font-size: 11px;
  font-style: normal;
}

.messaging-row-main small,
.messaging-channel-row small,
.messaging-object-row small {
  overflow: hidden;
  color: #aaa79e;
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.messaging-row-badges {
  display: flex;
  align-items: center;
  gap: 5px;
}

.messaging-row-badges b,
.messaging-row-badges mark,
.messaging-channel-row mark {
  min-width: 19px;
  height: 19px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: #9fdc7c;
  color: #111210;
  font-size: 10px;
  font-weight: 900;
}

.messaging-row-badges b {
  background: #d8c7ff;
}

.messaging-empty-state {
  display: grid;
  gap: 9px;
  margin: 12px 4px;
  padding: 16px;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.035);
  color: #aaa79e;
  font-size: 13px;
  line-height: 1.45;
}

.messaging-empty-state strong {
  color: #ffffff;
  font-size: 14px;
}

.messaging-empty-state button,
.context-primary-action,
.context-card button,
.context-actions button,
.suggestion-card button {
  min-height: 34px;
  padding: 0 11px;
  border-radius: 9px;
  background: #e7e4dc;
  color: #171816;
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
}

.messaging-server-switcher {
  position: relative;
  padding: 0 14px 12px;
}

.messaging-server-current {
  width: 100%;
  min-height: 44px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 9px;
  padding: 5px;
  border-radius: 11px;
  background: #151713;
  color: #ffffff;
  cursor: pointer;
  text-align: left;
}

.server-glyph {
  width: 32px;
  height: 32px;
  display: inline-grid;
  place-items: center;
  border-radius: 9px;
  background: #cfe8bb;
  color: #171816;
  font-size: 11px;
  font-weight: 900;
}

.messaging-server-menu,
.messaging-new-popover,
.composer-command-menu,
.composer-add-menu,
.chat-options-popover,
.chat-message-menu,
.chat-conversation-menu {
  animation: menuIn 180ms ease both;
}

.messaging-server-menu {
  position: absolute;
  inset: 50px 14px auto;
  z-index: 35;
  display: grid;
  gap: 4px;
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  background: #252720;
  box-shadow: 0 22px 50px rgba(0, 0, 0, 0.36);
}

.messaging-server-menu button {
  min-height: 36px;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  padding: 7px;
  border-radius: 9px;
  color: #f4f2ed;
  cursor: pointer;
  text-align: left;
}

.messaging-server-menu button:hover {
  background: rgba(255, 255, 255, 0.07);
}

.messaging-server-menu button:disabled {
  opacity: 0.48;
}

.messaging-channel-section {
  display: grid;
  gap: 3px;
  margin-bottom: 14px;
}

.messaging-channel-section-head {
  height: 28px;
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) 22px;
  align-items: center;
  gap: 4px;
  padding: 0 8px;
  color: #8f8d86;
  font-size: 11px;
  text-transform: uppercase;
}

.messaging-channel-section-head button {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  color: #8f8d86;
  cursor: pointer;
}

.messaging-channel-row {
  min-height: 46px;
  grid-template-columns: 22px minmax(0, 1fr) auto auto;
}

body[data-active-view="chat"] .chat-thread-panel.messaging-chat-shell {
  height: 100vh !important;
  max-height: 100vh !important;
  min-width: 0;
  display: flex !important;
  flex-direction: column;
  overflow: hidden !important;
  padding: 0 !important;
  background: #f6f4ef;
  color: #1b1c18;
}

.messaging-chat-header {
  position: sticky;
  top: 0;
  z-index: 3;
  min-height: 76px;
  align-items: center;
  padding: 14px 18px !important;
  border-bottom: 1px solid rgba(27, 28, 24, 0.08);
  background: rgba(246, 244, 239, 0.94);
  backdrop-filter: blur(18px);
}

.chat-channel-title {
  min-width: 0;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 11px;
  align-items: center;
}

.chat-channel-title-icon {
  width: 42px !important;
  height: 42px !important;
  border-radius: 12px;
  background: #1b1c18 !important;
}

.chat-channel-title h2 {
  color: #171816 !important;
  font-size: 18px !important;
}

.chat-ai-pill {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 11px;
  border: 1px solid rgba(27, 28, 24, 0.1);
  border-radius: 999px;
  background: #ffffff;
  color: #34362f;
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
}

.messaging-chat-header .chat-thread-actions {
  align-items: center;
  gap: 6px;
}

.messaging-chat-header .chat-icon-button {
  background: #ffffff;
  color: #55564e;
  box-shadow: 0 1px 0 rgba(27, 28, 24, 0.04);
}

.messaging-connection-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 10px 18px 0;
  padding: 8px 11px;
  border: 1px solid rgba(45, 113, 74, 0.18);
  border-radius: 10px;
  background: #edf8ee;
  color: #315c3c;
  font-size: 12px;
}

.video-call-layer {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(17, 18, 15, 0.48);
}

.video-call-layer[hidden] {
  display: none !important;
}

.video-call-card {
  width: min(960px, calc(100vw - 48px));
  max-height: calc(100vh - 48px);
  display: grid;
  grid-template-rows: auto minmax(320px, 1fr) auto auto;
  overflow: hidden;
  border: 1px solid rgba(246, 243, 235, 0.16);
  border-radius: 18px;
  background: #151611;
  color: #f6f3eb;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
}

.video-call-card.is-expanded,
.video-call-card:fullscreen {
  width: 100vw;
  max-height: none;
  height: 100vh;
  border-radius: 0;
}

.video-call-header {
  min-height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(246, 243, 235, 0.1);
}

.video-call-header p,
.video-call-header h3,
.video-call-remote-tile strong,
.video-call-remote-tile span,
.video-call-local-tile span,
.video-call-meta {
  margin: 0;
}

.video-call-header p {
  color: #9fdc7c;
  font-size: 11px;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.video-call-header h3 {
  margin-top: 3px;
  color: #ffffff;
  font-size: 18px;
  line-height: 1.2;
}

.video-call-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.video-call-icon,
.video-call-control,
.video-call-device-picker {
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(246, 243, 235, 0.12);
  background: rgba(255, 255, 255, 0.06);
  color: #f6f3eb;
  cursor: pointer;
  transition: transform 120ms ease, background 120ms ease, color 120ms ease;
}

.video-call-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
}

.video-call-icon:hover,
.video-call-control:hover,
.video-call-device-picker:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.12);
}

.video-call-stage {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 240px);
  gap: 14px;
  padding: 14px;
}

.video-call-remote-tile,
.video-call-local-tile {
  position: relative;
  min-width: 0;
  overflow: hidden;
  border: 1px solid rgba(246, 243, 235, 0.1);
  border-radius: 14px;
  background: #22231d;
}

.video-call-remote-tile {
  min-height: 360px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
}

.video-call-avatar {
  width: 96px;
  height: 96px;
  display: inline-grid;
  place-items: center;
  border-radius: 28px;
  background: #ded8cc;
  color: #1a1b17;
  font-size: 30px;
  font-weight: 900;
}

.video-call-remote-tile strong {
  margin-top: 8px;
  color: #ffffff;
  font-size: 22px;
}

.video-call-remote-tile span {
  color: rgba(246, 243, 235, 0.62);
  font-size: 13px;
  font-weight: 750;
}

.video-call-local-tile {
  align-self: end;
  aspect-ratio: 4 / 5;
  min-height: 220px;
  display: grid;
  place-items: center;
  background: #0f100d;
}

.video-call-local-tile video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.video-call-local-tile span {
  position: absolute;
  left: 10px;
  bottom: 10px;
  padding: 5px 8px;
  border-radius: 8px;
  background: rgba(15, 16, 13, 0.72);
  color: #ffffff;
  font-size: 11px;
  font-weight: 800;
}

.video-call-camera-off {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  background: #1c1d18;
  color: rgba(246, 243, 235, 0.74);
  font-size: 12px;
  font-weight: 800;
}

.video-call-camera-off[hidden] {
  display: none !important;
}

.video-call-camera-off i {
  font-size: 28px;
}

.video-call-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 0 18px 14px;
  color: rgba(246, 243, 235, 0.68);
  font-size: 12px;
  font-weight: 750;
}

.video-call-meta #videoCallTimer {
  color: #ffffff;
  font-variant-numeric: tabular-nums;
}

.video-call-controls {
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 14px 18px 18px;
  border-top: 1px solid rgba(246, 243, 235, 0.1);
}

.video-call-control {
  min-width: 86px;
  min-height: 44px;
  grid-auto-flow: column;
  gap: 7px;
  padding: 0 13px;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 850;
}

.video-call-device-picker {
  position: relative;
  min-width: 174px;
  max-width: 240px;
  min-height: 44px;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 7px;
  padding: 0 11px;
  border-radius: 12px;
}

.video-call-device-picker button {
  min-width: 0;
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: #f6f3eb;
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 850;
  text-overflow: ellipsis;
}

.video-call-device-picker button:disabled {
  cursor: default;
  opacity: 0.62;
}

.video-call-device-menu {
  position: absolute;
  left: 0;
  bottom: calc(100% + 10px);
  z-index: 4;
  width: min(320px, 82vw);
  max-height: 260px;
  overflow-y: auto;
  padding: 6px;
  border: 1px solid rgba(246, 243, 235, 0.14);
  border-radius: 12px;
  background: #20211c;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34);
}

.video-call-device-menu[hidden] {
  display: none !important;
}

.video-call-device-option {
  width: 100%;
  min-height: 52px;
  display: grid;
  gap: 3px;
  padding: 9px 10px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: #f6f3eb;
  text-align: left;
  cursor: pointer;
}

.video-call-device-option:hover,
.video-call-device-option.is-active {
  background: rgba(255, 255, 255, 0.09);
}

.video-call-device-option strong,
.video-call-device-option span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.video-call-device-option strong {
  font-size: 12px;
}

.video-call-device-option span {
  color: rgba(246, 243, 235, 0.58);
  font-size: 11px;
  font-weight: 750;
}

.video-call-control.is-active {
  background: #f2ecdc;
  color: #1a1b17;
}

.video-call-end {
  border-color: rgba(255, 104, 91, 0.42);
  background: #d84b3f;
  color: #ffffff;
}

.video-call-end:hover {
  background: #c83f34;
}

.video-call-layer.is-minimized {
  inset: auto 22px 108px auto;
  display: block;
  padding: 0;
  background: transparent;
  pointer-events: none;
}

.video-call-card.is-minimized {
  width: 290px;
  max-height: none;
  grid-template-rows: auto;
  border-radius: 14px;
  pointer-events: auto;
}

.video-call-card.is-minimized .video-call-stage,
.video-call-card.is-minimized .video-call-meta,
.video-call-card.is-minimized .video-call-controls,
.video-call-card.is-minimized .video-call-device-picker,
.video-call-card.is-minimized #videoCallFullscreenButton {
  display: none;
}

.video-call-card.is-minimized .video-call-header {
  min-height: 58px;
  padding: 12px;
}

.video-call-card.is-minimized .video-call-header h3 {
  max-width: 190px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 15px;
}

@media (max-width: 760px) {
  .video-call-layer {
    padding: 12px;
  }

  .video-call-card {
    width: calc(100vw - 24px);
    max-height: calc(100vh - 24px);
    grid-template-rows: auto minmax(300px, 1fr) auto auto;
  }

  .video-call-stage {
    grid-template-columns: 1fr;
  }

  .video-call-remote-tile {
    min-height: 330px;
  }

  .video-call-local-tile {
    position: absolute;
    right: 24px;
    bottom: 98px;
    width: min(34vw, 150px);
    min-height: 112px;
    z-index: 2;
  }

  .video-call-controls {
    flex-wrap: wrap;
  }

  .video-call-control {
    min-width: 74px;
    flex: 1 1 74px;
  }

  .video-call-device-picker {
    min-width: 100%;
    max-width: none;
    flex: 1 1 100%;
  }
}

body[data-active-view="chat"] .chat-thread-scroll {
  flex: 1;
  min-height: 0;
  display: block !important;
  overflow: auto !important;
  padding: 22px 24px 18px !important;
  background:
    linear-gradient(rgba(246, 244, 239, 0.92), rgba(246, 244, 239, 0.92)),
    radial-gradient(circle at top left, rgba(159, 220, 124, 0.12), transparent 34%),
    #f6f4ef;
}

.chat-bubble {
  position: relative;
  max-width: min(760px, 78%);
  min-height: 44px;
  grid-template-columns: 38px minmax(0, 1fr) !important;
  gap: 10px !important;
  margin: 0 0 14px;
  padding: 0 !important;
  color: #1b1c18;
}

.chat-bubble--right {
  margin-left: auto;
}

.chat-bubble-avatar {
  width: 36px !important;
  height: 36px !important;
  border-radius: 11px !important;
  background: #d8d2c6 !important;
  color: #1b1c18 !important;
}

.chat-bubble--right .chat-bubble-avatar {
  background: #1b1c18 !important;
  color: #ffffff !important;
}

.chat-bubble-body {
  position: relative;
  padding: 11px 12px;
  border: 1px solid rgba(27, 28, 24, 0.08);
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 8px 24px rgba(27, 28, 24, 0.05);
}

.chat-bubble--right .chat-bubble-body {
  background: #20221d;
  color: #ffffff;
}

.chat-bubble.is-ai-action .chat-bubble-body {
  border-color: rgba(110, 82, 184, 0.18);
  background: #fbf8ff;
}

.chat-bubble-meta {
  gap: 10px !important;
  justify-content: space-between;
}

.chat-bubble-body strong {
  color: inherit !important;
  font-size: 12px !important;
}

.chat-bubble-body time {
  color: #8d8b84 !important;
  font-size: 11px !important;
}

.chat-bubble-body p {
  overflow: visible !important;
  margin: 5px 0 0 !important;
  color: inherit !important;
  font-size: 14px !important;
  line-height: 1.48 !important;
  text-overflow: clip !important;
}

.chat-message-toolbar {
  position: absolute;
  right: 8px;
  top: -28px;
  z-index: 5;
  display: flex;
  gap: 2px;
  padding: 3px;
  border: 1px solid rgba(27, 28, 24, 0.1);
  border-radius: 9px;
  background: #ffffff;
  opacity: 0;
  pointer-events: none;
  transform: translateY(4px);
  transition: opacity 120ms ease, transform 120ms ease;
  box-shadow: 0 10px 28px rgba(27, 28, 24, 0.12);
}

.chat-bubble:hover .chat-message-toolbar {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.chat-message-toolbar button {
  width: 25px;
  height: 25px;
  display: inline-grid;
  place-items: center;
  border-radius: 7px;
  color: #4d4e47;
  cursor: pointer;
}

.chat-message-toolbar button:hover {
  background: #f0eee8;
}

.smart-chip {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  min-height: 22px;
  margin: 0 2px;
  padding: 0 7px;
  border-radius: 999px;
  background: #edf1e8;
  color: #315c3c;
  font-size: 12px;
  font-weight: 800;
  vertical-align: baseline;
  cursor: pointer;
}

.smart-chip--person {
  background: #eef2ff;
  color: #394781;
}

.smart-chip--event {
  background: #fff4db;
  color: #73531a;
}

.chat-reactions {
  display: flex;
  gap: 5px;
  margin-top: 9px;
}

.chat-reactions button {
  min-height: 24px;
  padding: 0 7px;
  border-radius: 999px;
  background: #f0eee8;
  color: #1b1c18;
  cursor: pointer;
  font-size: 12px;
}

.messaging-typing-line {
  display: flex;
  align-items: center;
  gap: 5px;
  min-height: 30px;
  padding: 0 24px;
  color: #78766f;
  font-size: 12px;
}

.messaging-typing-line i {
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: #98968e;
  animation: typingDot 900ms ease-in-out infinite;
}

.messaging-typing-line i:nth-child(3) {
  animation-delay: 120ms;
}

.messaging-typing-line i:nth-child(4) {
  animation-delay: 240ms;
}

body[data-active-view="chat"] .chat-composer.messaging-composer {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  z-index: 4 !important;
  width: auto !important;
  min-height: 70px;
  display: block !important;
  margin: 0 18px 18px !important;
  padding: 10px;
  border: 1px solid rgba(27, 28, 24, 0.12);
  border-radius: 16px;
  background: #ffffff;
  transform: none !important;
  box-shadow: 0 18px 42px rgba(27, 28, 24, 0.12) !important;
}

.messaging-composer:focus-within {
  border-color: rgba(27, 28, 24, 0.24);
  box-shadow: 0 22px 54px rgba(27, 28, 24, 0.16) !important;
}

.messaging-composer .chat-composer-entry {
  min-height: 48px;
  display: grid;
  grid-template-columns: repeat(3, 34px) minmax(0, 1fr) repeat(5, 34px);
  gap: 6px;
  align-items: end;
  padding: 0 !important;
}

.messaging-composer textarea {
  min-height: 38px;
  max-height: 168px;
  resize: none;
  border: 0;
  outline: 0;
  padding: 10px 8px;
  background: transparent;
  color: #1b1c18;
  font-size: 14px;
  line-height: 1.45;
}

.chat-composer-add,
.chat-composer-attach,
.chat-composer-voice,
.chat-composer-emoji,
.chat-composer-mention,
.chat-composer-command,
.chat-composer-ai,
.chat-composer-send {
  position: static !important;
  width: 34px !important;
  height: 34px !important;
  display: inline-grid !important;
  place-items: center;
  border: 1px solid rgba(27, 28, 24, 0.09) !important;
  border-radius: 10px !important;
  background: #f3f1eb !important;
  color: #34362f !important;
  cursor: pointer;
  font-size: 16px !important;
  transform: none !important;
}

.chat-composer-voice:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.chat-composer-send {
  background: #1b1c18 !important;
  color: #ffffff !important;
}

.chat-composer-send:hover {
  transform: translateY(-1px) !important;
}

.chat-composer-send span {
  display: none !important;
}

.composer-command-menu,
.composer-mention-menu,
.composer-add-menu,
.chat-emoji-panel {
  position: absolute;
  left: 12px;
  bottom: calc(100% + 10px);
  z-index: 60;
  width: min(430px, calc(100vw - 460px));
  max-height: 390px;
  overflow: auto;
  display: grid;
  gap: 4px;
  padding: 8px;
  border: 1px solid rgba(27, 28, 24, 0.12);
  border-radius: 14px;
  background: #ffffff;
  box-shadow: 0 24px 60px rgba(27, 28, 24, 0.18);
}

.composer-command-menu button {
  min-height: 48px;
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) auto;
  gap: 9px;
  align-items: center;
  padding: 6px 8px;
  border-radius: 10px;
  color: #1b1c18;
  cursor: pointer;
  text-align: left;
}

.composer-mention-menu {
  width: min(440px, calc(100vw - 250px));
  gap: 10px;
}

.composer-mention-menu section {
  display: grid;
  gap: 4px;
}

.composer-mention-menu section > strong {
  padding: 4px 8px;
  color: #74726b;
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
}

.composer-mention-menu button {
  min-height: 48px;
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) auto;
  gap: 9px;
  align-items: center;
  padding: 7px 8px;
  border-radius: 10px;
  color: #1b1c18;
  cursor: pointer;
  text-align: left;
}

.composer-mention-menu button:hover {
  background: #f1efe8;
}

.composer-mention-menu b,
.composer-mention-menu small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.composer-mention-menu small {
  color: #74726b;
  font-size: 12px;
}

.composer-mention-menu code {
  max-width: 124px;
  overflow: hidden;
  padding: 3px 6px;
  border-radius: 999px;
  background: #eeeae1;
  color: #5f5d55;
  font: inherit;
  font-size: 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.composer-menu-empty {
  padding: 12px;
  color: #74726b;
  font-size: 13px;
}

.composer-command-menu button:hover,
.composer-command-menu button.is-active {
  background: #f1efe8;
}

.composer-command-menu small {
  display: block;
  color: #74726b;
  font-size: 12px;
}

.composer-command-menu kbd {
  padding: 3px 6px;
  border-radius: 6px;
  background: #e8e5dd;
  color: #4f5049;
  font: inherit;
  font-size: 11px;
}

.composer-add-menu {
  width: 310px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.composer-add-menu section {
  display: grid;
  gap: 4px;
}

.composer-add-menu strong {
  padding: 4px 7px;
  color: #74726b;
  font-size: 11px;
  text-transform: uppercase;
}

.composer-add-menu button {
  min-height: 32px;
  padding: 0 8px;
  border-radius: 8px;
  color: #1b1c18;
  cursor: pointer;
  text-align: left;
  font-size: 12px;
}

.composer-add-menu button:hover {
  background: #f1efe8;
}

.composer-drop-zone {
  position: absolute;
  inset: 8px;
  z-index: 70;
  display: grid;
  place-items: center;
  border: 1px dashed #7fae66;
  border-radius: 12px;
  background: rgba(237, 248, 238, 0.94);
  color: #315c3c;
  font-weight: 800;
  pointer-events: none;
}

.composer-drop-zone[hidden] {
  display: none !important;
}

.chat-file-preview,
.chat-file-card {
  border-color: rgba(27, 28, 24, 0.1) !important;
  background: #f3f1eb !important;
}

.chat-file-card__icon {
  background: #ffffff !important;
  color: #34362f !important;
}

.messaging-context-panel {
  height: 100vh !important;
  max-height: 100vh !important;
  min-width: 0;
  display: flex !important;
  flex-direction: column;
  padding: 18px 14px !important;
  border-left: 1px solid rgba(27, 28, 24, 0.1);
  background: #fcfbf7 !important;
  color: #1b1c18;
  animation: contextPanelIn 220ms ease both;
}

.messaging-context-panel[hidden] {
  display: none !important;
}

.messaging-context-panel .chat-members-head p {
  color: #74726b;
}

.messaging-context-panel .chat-members-head h3 {
  color: #1b1c18;
}

#chatMembersClose {
  background: #f0eee8 !important;
  color: #1b1c18 !important;
}

.messaging-context-panel .chat-members-list {
  min-height: 0;
  overflow: auto;
  gap: 10px;
}

.messaging-context-panel .chat-member-row,
.context-card,
.suggestion-card {
  display: grid;
  gap: 7px;
  padding: 12px;
  border: 1px solid rgba(27, 28, 24, 0.08);
  border-radius: 12px;
  background: #ffffff;
  color: #1b1c18;
}

.messaging-context-panel .chat-member-row {
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
}

.messaging-context-panel .chat-member-row strong {
  color: #1b1c18;
}

.context-search,
.context-field {
  min-height: 40px;
  display: grid;
  gap: 6px;
  padding: 9px;
  border: 1px solid rgba(27, 28, 24, 0.09);
  border-radius: 11px;
  background: #ffffff;
}

.context-field span {
  color: #74726b;
  font-size: 11px;
  font-weight: 800;
}

.context-result {
  display: grid;
  gap: 4px;
  padding: 11px;
  border-radius: 11px;
  background: #ffffff;
  color: #1b1c18;
  text-align: left;
  cursor: pointer;
}

.context-result span,
.context-card span,
.suggestion-card p,
.suggestion-card span {
  color: #69675f;
  font-size: 12px;
  line-height: 1.45;
}

.context-actions,
.suggestion-card div {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.messaging-new-popover {
  position: absolute;
  right: 12px;
  top: 70px;
  z-index: 50;
  width: min(300px, calc(100% - 24px));
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  background: #252720;
  color: #f4f2ed;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.32);
}

.messaging-popover-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.messaging-new-popover label {
  display: grid;
  gap: 6px;
  color: #b9b6ad;
  font-size: 12px;
}

.messaging-new-popover input {
  height: 36px;
  padding: 0 9px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 9px;
  background: #171816;
}

.messaging-suggested-contacts {
  display: grid;
  gap: 5px;
}

.messaging-suggested-contacts button {
  min-height: 34px;
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 0 9px;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.055);
  color: #ffffff;
  cursor: pointer;
}

.messaging-toggle-row {
  min-height: 38px;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.chat-invite-row {
  grid-template-columns: 1fr 1fr !important;
}

.chat-invite-row button,
#chatEnterCodeButton {
  min-height: 34px;
  border-radius: 9px;
  background: #e7e4dc;
  color: #171816;
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
}

.chat-message-menu,
.chat-conversation-menu {
  width: 198px !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
  background: #252720 !important;
}

.chat-message-menu button:disabled,
.chat-conversation-menu button:disabled {
  opacity: 0.44;
  cursor: not-allowed;
}

@keyframes menuIn {
  from {
    opacity: 0;
    transform: translateY(6px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes contextPanelIn {
  from {
    opacity: 0;
    transform: translateX(18px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes typingDot {
  0%,
  80%,
  100% {
    opacity: 0.35;
    transform: translateY(0);
  }
  40% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

@media (max-width: 1100px) {
  body[data-active-view="chat"] .chat-page.messaging-workspace,
  body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
    grid-template-columns: 72px 292px minmax(480px, 1fr);
  }

  .messaging-context-panel {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 20;
    width: 382px;
    box-shadow: -20px 0 60px rgba(27, 28, 24, 0.18);
  }
}

/* Open Thread Chat polish pass: Activity / Mentions desktop shell */
body[data-active-view="chat"] {
  --ot-graphite-0: #0f100f;
  --ot-graphite-1: #151613;
  --ot-graphite-2: #1c1d19;
  --ot-graphite-3: #24251f;
  --ot-panel: #e9e5dc;
  --ot-panel-soft: #f4f1ea;
  --ot-panel-line: rgba(35, 36, 31, 0.12);
  --ot-ink: #1d1e1a;
  --ot-muted: #8d8a81;
  --ot-lilac: #ebe7f7;
  --ot-accent: #8f73ff;
}

body[data-active-view="chat"] .chat-page.messaging-workspace,
body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
  --message-rail: 68px;
  --message-chat: clamp(320px, 29vw, 352px);
  grid-template-columns: var(--message-rail) minmax(280px, 1fr) var(--message-chat) !important;
  background:
    radial-gradient(circle at 34% -16%, rgba(255, 255, 255, 0.065), transparent 38%),
    linear-gradient(135deg, #171815 0%, #111210 48%, #171713 100%);
  color: #f3f0e8;
}

body[data-active-view="chat"] .chat-page.messaging-workspace::before {
  content: "";
  position: absolute;
  inset: 0 0 0 68px;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(circle at 34% 26%, rgba(0, 0, 0, 0.52), transparent 62%);
  opacity: 0.55;
}

body[data-active-view="chat"] .chat-page.messaging-workspace > * {
  position: relative;
}

.messaging-left-rail {
  width: 68px !important;
  gap: 18px;
  padding: 18px 12px 20px !important;
  border-right-color: rgba(255, 255, 255, 0.075) !important;
  background: rgba(14, 15, 13, 0.96) !important;
  box-shadow: inset -1px 0 rgba(255, 255, 255, 0.03);
}

.messaging-left-top,
.messaging-rail-nav,
.messaging-left-bottom {
  width: 44px;
  place-items: center;
  gap: 10px !important;
}

.messaging-brand-button,
.messaging-rail-button,
.messaging-profile-dot {
  width: 40px !important;
  height: 40px !important;
  border-radius: 12px !important;
  color: rgba(240, 237, 229, 0.68) !important;
  transition: background 200ms ease, color 200ms ease, transform 200ms ease, box-shadow 200ms ease !important;
}

.messaging-brand-button {
  margin-bottom: 7px;
}

.messaging-brand-button img {
  width: 24px !important;
  height: 24px !important;
  opacity: 0.84;
}

.messaging-rail-button:hover,
.messaging-brand-button:hover,
.messaging-profile-dot:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  transform: translateY(-1px) scale(1.015) !important;
}

.messaging-rail-button.is-active {
  background: #ece8df !important;
  color: #161714 !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.24), inset 0 1px rgba(255, 255, 255, 0.7);
}

.messaging-rail-button.is-active::before {
  left: -12px !important;
  top: 17px !important;
  width: 4px !important;
  height: 4px !important;
  border-radius: 999px !important;
  background: var(--ot-accent) !important;
  box-shadow: 0 0 14px rgba(143, 115, 255, 0.7);
}

.messaging-brand-button span,
.messaging-rail-button span {
  left: calc(100% + 12px) !important;
  border-radius: 10px !important;
  background: rgba(35, 36, 31, 0.92) !important;
  backdrop-filter: blur(18px);
}

.messaging-profile-dot {
  background: rgba(255, 255, 255, 0.055) !important;
  border-color: rgba(255, 255, 255, 0.09) !important;
}

.messaging-directory {
  height: 100vh !important;
  padding: 34px clamp(24px, 4vw, 58px) 124px !important;
  border-right: 0 !important;
  background: transparent !important;
  animation: pageSettle 260ms ease-out both;
}

.messaging-directory::after {
  content: "";
  position: absolute;
  inset: 128px 32px 106px;
  z-index: -1;
  border-radius: 26px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.04), transparent 44%),
    rgba(255, 255, 255, 0.018);
  border: 1px solid rgba(255, 255, 255, 0.035);
}

.messaging-directory-header {
  min-height: 58px !important;
  padding: 0 !important;
  background: transparent !important;
  align-items: end !important;
}

.messaging-directory-header p {
  color: rgba(232, 228, 219, 0.56) !important;
  font-size: 13px !important;
  letter-spacing: 0.02em;
}

.messaging-directory-header h2 {
  margin-top: 5px !important;
  color: #f7f4eb !important;
  font-size: clamp(34px, 4.2vw, 52px) !important;
  font-weight: 760;
  letter-spacing: 0 !important;
}

.messaging-directory-actions {
  gap: 9px !important;
  padding-bottom: 8px;
}

.messaging-directory-actions button {
  width: 38px !important;
  height: 38px !important;
  border: 1px solid rgba(255, 255, 255, 0.075);
  border-radius: 13px !important;
  background: rgba(255, 255, 255, 0.055) !important;
  color: rgba(240, 237, 229, 0.78) !important;
  backdrop-filter: blur(14px);
}

.messaging-directory-actions button:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  color: #ffffff !important;
}

.messaging-directory-search {
  width: min(100%, 680px);
  height: 42px !important;
  margin: 26px 0 20px !important;
  border-color: rgba(255, 255, 255, 0.085) !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, 0.045) !important;
  color: rgba(240, 237, 229, 0.62) !important;
  backdrop-filter: blur(16px);
  transition: border-color 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.messaging-directory-search:focus-within {
  border-color: rgba(143, 115, 255, 0.48) !important;
  background: rgba(255, 255, 255, 0.065) !important;
  box-shadow: 0 0 0 4px rgba(143, 115, 255, 0.1);
}

.messaging-directory-search input {
  color: #f6f2ea !important;
  font-size: 14px;
}

.messaging-directory-search input::placeholder {
  color: rgba(232, 228, 219, 0.42);
}

.messaging-list {
  padding: 0 !important;
  width: min(100%, 740px);
}

.mention-activity-row,
.messaging-object-row.mention-activity-row {
  min-height: 72px !important;
  grid-template-columns: 44px minmax(0, 1fr) auto !important;
  gap: 14px !important;
  padding: 12px 14px !important;
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 17px !important;
  background: rgba(255, 255, 255, 0.052) !important;
  color: #f1eee5 !important;
  backdrop-filter: blur(16px);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.11);
}

.mention-activity-row:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.075) !important;
  border-color: rgba(255, 255, 255, 0.11);
}

.mention-activity-row .messaging-row-avatar {
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
  background: rgba(236, 232, 223, 0.94) !important;
  color: #171816 !important;
  box-shadow: inset 0 1px rgba(255, 255, 255, 0.72);
}

.mention-row-copy {
  display: grid;
  min-width: 0;
  gap: 5px;
}

.mention-row-copy strong {
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 760;
}

.mention-row-copy small {
  overflow: hidden;
  color: rgba(237, 234, 225, 0.64) !important;
  font-size: 13px !important;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mention-activity-row em {
  align-self: start;
  margin-top: 3px;
  color: rgba(237, 234, 225, 0.42) !important;
  font-size: 12px !important;
}

.mention-row-actions {
  position: absolute;
  right: 12px;
  bottom: 10px;
  display: flex;
  gap: 6px;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 160ms ease, transform 160ms ease;
}

.mention-activity-row:hover .mention-row-actions {
  opacity: 1;
  transform: translateY(0);
}

.mention-row-actions b {
  min-height: 24px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.72);
  font-size: 11px;
}

.activity-empty-state {
  min-height: 150px;
  align-content: center;
  border-radius: 22px !important;
  border-style: solid !important;
  background: rgba(255, 255, 255, 0.045) !important;
}

body[data-active-view="chat"] .chat-thread-panel.messaging-chat-shell {
  width: var(--message-chat);
  border-left: 1px solid rgba(255, 255, 255, 0.09);
  background: linear-gradient(180deg, #ebe7dd 0%, #ded9cf 100%) !important;
  color: var(--ot-ink);
  box-shadow: -22px 0 70px rgba(0, 0, 0, 0.18);
  animation: sidePanelIn 260ms ease-out both;
}

.messaging-chat-header {
  min-height: auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "title actions"
    "ai actions";
  gap: 8px 10px !important;
  padding: 18px 16px 12px !important;
  border-bottom: 1px solid rgba(35, 36, 31, 0.09) !important;
  background: rgba(235, 231, 221, 0.86) !important;
}

.messaging-chat-header .chat-channel-title {
  grid-area: title;
  grid-template-columns: 38px minmax(0, 1fr) !important;
  gap: 10px !important;
}

.messaging-chat-header .chat-channel-title-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: 13px !important;
  background: linear-gradient(145deg, #252720, #151613) !important;
}

.messaging-chat-header .chat-channel-title h2 {
  color: #1a1b17 !important;
  font-size: 19px !important;
  font-weight: 820;
  letter-spacing: 0.015em;
  text-transform: uppercase;
}

.messaging-chat-header .chat-channel-title p {
  margin-top: 2px !important;
  color: rgba(29, 30, 26, 0.48) !important;
  font-size: 12px !important;
}

.chat-ai-pill {
  grid-area: ai;
  justify-self: start;
  min-height: 28px !important;
  padding: 0 9px !important;
  border-color: rgba(35, 36, 31, 0.08) !important;
  background: rgba(255, 255, 255, 0.45) !important;
  color: rgba(29, 30, 26, 0.72) !important;
  font-size: 11px !important;
  box-shadow: inset 0 1px rgba(255, 255, 255, 0.48);
}

.messaging-chat-header .chat-thread-actions {
  grid-area: actions;
  display: grid !important;
  grid-template-columns: repeat(3, 32px);
  align-content: start;
  gap: 7px !important;
}

.messaging-chat-header .chat-icon-button {
  width: 32px !important;
  height: 32px !important;
  border: 1px solid rgba(35, 36, 31, 0.08);
  border-radius: 11px !important;
  background: rgba(255, 255, 255, 0.38) !important;
  color: rgba(29, 30, 26, 0.62) !important;
  box-shadow: none !important;
}

.messaging-chat-header .chat-icon-button:hover {
  background: rgba(255, 255, 255, 0.7) !important;
  color: #1a1b17 !important;
}

.chat-video-button.is-active {
  background: #1f211c !important;
  color: #f6f3eb !important;
}

.messaging-chat-header [data-chat-panel="tasks"],
.messaging-chat-header [data-chat-panel="calendar"],
.messaging-chat-header [data-chat-panel="members"] {
  display: none !important;
}

.messaging-connection-banner {
  margin: 12px 14px 0 !important;
  padding: 9px 10px !important;
  border-color: rgba(69, 136, 84, 0.16) !important;
  border-radius: 13px !important;
  background: rgba(231, 244, 229, 0.68) !important;
  color: #416349 !important;
  font-size: 11px !important;
  line-height: 1.35;
}

body[data-active-view="chat"] .chat-thread-scroll {
  padding: 16px 14px 14px !important;
  background: transparent !important;
}

.chat-bubble {
  max-width: 100% !important;
  grid-template-columns: 30px minmax(0, 1fr) !important;
  gap: 8px !important;
  margin-bottom: 12px !important;
}

.chat-bubble-avatar {
  width: 30px !important;
  height: 30px !important;
  border-radius: 10px !important;
  font-size: 11px !important;
  background: rgba(35, 36, 31, 0.12) !important;
}

.chat-bubble-body {
  padding: 10px 11px !important;
  border-color: rgba(35, 36, 31, 0.08) !important;
  border-radius: 15px !important;
  background: rgba(255, 255, 255, 0.58) !important;
  box-shadow: 0 10px 28px rgba(35, 36, 31, 0.06) !important;
}

.chat-bubble.is-ai-action .chat-bubble-body {
  border-color: rgba(113, 91, 171, 0.14) !important;
  background: rgba(235, 231, 247, 0.74) !important;
}

.chat-bubble.is-ai-public .chat-bubble-body {
  border-color: rgba(91, 112, 171, 0.14) !important;
  background: rgba(238, 241, 250, 0.78) !important;
}

.chat-bubble.is-pending .chat-bubble-body {
  opacity: 0.78;
}

.chat-bubble-body strong {
  font-size: 12px !important;
  font-weight: 780;
}

.chat-bubble-body time {
  font-size: 10px !important;
  color: rgba(29, 30, 26, 0.38) !important;
}

.chat-bubble-body p {
  margin-top: 6px !important;
  font-size: 13px !important;
  line-height: 1.42 !important;
  color: rgba(29, 30, 26, 0.88) !important;
}

.assistant-note-label {
  display: inline-flex;
  min-height: 22px;
  align-items: center;
  margin-bottom: 7px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.46);
  color: rgba(77, 61, 126, 0.8);
  font-size: 10px;
  font-weight: 820;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.assistant-note-label--public {
  color: rgba(50, 67, 132, 0.8);
}

.assistant-source-card {
  display: grid;
  gap: 4px;
  margin-top: 9px;
  padding: 8px;
  border: 1px solid rgba(113, 91, 171, 0.12);
  border-radius: 11px;
  background: rgba(255, 255, 255, 0.42);
}

.assistant-source-card small {
  color: rgba(77, 61, 126, 0.62);
  font-size: 10px;
  font-weight: 820;
  text-transform: uppercase;
}

.assistant-source-card span {
  color: rgba(29, 30, 26, 0.72);
  font-size: 12px;
  line-height: 1.35;
}

.assistant-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 9px;
}

.assistant-card-actions button {
  min-height: 27px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.56);
  color: rgba(42, 36, 63, 0.82);
  cursor: pointer;
  font-size: 11px;
  font-weight: 780;
}

.chat-reactions button,
.chat-message-flags span {
  min-height: 23px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.44) !important;
  color: rgba(29, 30, 26, 0.58) !important;
}

.messaging-typing-line {
  min-height: 28px !important;
  justify-content: space-between;
  padding: 0 16px !important;
  color: rgba(29, 30, 26, 0.46) !important;
  font-size: 11px !important;
}

body[data-active-view="chat"] .chat-composer.messaging-composer {
  min-height: 62px !important;
  margin: 0 12px 92px !important;
  padding: 8px !important;
  border-color: rgba(35, 36, 31, 0.1) !important;
  border-radius: 18px !important;
  background: rgba(248, 246, 240, 0.8) !important;
  box-shadow: 0 16px 34px rgba(35, 36, 31, 0.12) !important;
}

.messaging-composer .chat-composer-entry {
  min-height: 44px !important;
  grid-template-columns: 34px 34px minmax(0, 1fr) repeat(5, 34px) !important;
  gap: 5px !important;
}

.chat-composer-voice {
  display: none !important;
}

.messaging-composer textarea {
  min-height: 36px !important;
  padding: 9px 7px !important;
  font-size: 13px !important;
}

.messaging-composer textarea::placeholder {
  color: rgba(29, 30, 26, 0.38);
}

.chat-composer-add,
.chat-composer-attach,
.chat-composer-emoji,
.chat-composer-mention,
.chat-composer-command,
.chat-composer-ai,
.chat-composer-send {
  width: 34px !important;
  height: 34px !important;
  border-radius: 11px !important;
  background: rgba(35, 36, 31, 0.06) !important;
  color: rgba(29, 30, 26, 0.64) !important;
}

.chat-composer-send {
  background: #1d1e1a !important;
  color: #ffffff !important;
}

@keyframes pageSettle {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes sidePanelIn {
  from {
    opacity: 0;
    transform: translateX(16px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes dockRise {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

@media (max-width: 780px) {
  body[data-active-view="chat"] .chat-page.messaging-workspace,
  body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
    --message-rail: 64px;
    --message-chat: 300px;
    grid-template-columns: var(--message-rail) minmax(180px, 1fr) var(--message-chat) !important;
  }

  .messaging-directory {
    padding-inline: 14px !important;
  }

  .messaging-directory-header h2 {
    font-size: 32px !important;
  }

  .mention-activity-row,
  .messaging-object-row.mention-activity-row {
    grid-template-columns: 38px minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 11px !important;
  }

  .mention-activity-row .messaging-row-avatar {
    width: 38px !important;
    height: 38px !important;
    border-radius: 13px !important;
  }

  .mention-activity-row em {
    position: absolute;
    right: 12px;
    top: 12px;
  }

  .mention-row-copy {
    padding-right: 34px;
  }

  .mention-row-actions {
    display: none;
  }
}

@media (max-width: 760px) {
  body[data-active-view="chat"] .main-stage,
  body[data-active-view="chat"] .app-shell {
    height: 100vh !important;
    max-height: 100vh !important;
    overflow: hidden !important;
  }

  body[data-active-view="chat"] .chat-page {
    height: 100vh !important;
    max-height: 100vh !important;
    display: grid !important;
    grid-template-rows: 228px minmax(0, 1fr) !important;
    grid-template-columns: minmax(0, 1fr) !important;
    overflow: hidden !important;
  }

  body[data-active-view="chat"] .chat-rail {
    height: 228px !important;
    max-height: 228px !important;
    overflow: hidden !important;
  }

  body[data-active-view="chat"] .chat-thread-panel {
    height: calc(100vh - 228px) !important;
    max-height: calc(100vh - 228px) !important;
    min-height: 0 !important;
    overflow: hidden !important;
    padding-bottom: 240px !important;
  }
}

/* Final priority: keep the conversation as the main screen */
body[data-active-view="chat"] .chat-page.messaging-workspace,
body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
  --message-rail: 68px;
  --activity-side: clamp(190px, 18vw, 260px);
  display: grid !important;
  grid-template-areas: "rail thread activity" !important;
  grid-template-columns: var(--message-rail) minmax(0, 1fr) var(--activity-side) !important;
  grid-template-rows: minmax(0, 1fr) !important;
}

body[data-active-view="chat"] .messaging-left-rail {
  grid-area: rail !important;
}

body[data-active-view="chat"] .messaging-chat-shell {
  grid-area: thread !important;
}

body[data-active-view="chat"] .messaging-directory {
  grid-area: activity !important;
  padding: 32px 18px 116px !important;
  border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-right: 0 !important;
}

body[data-active-view="chat"] .chat-thread-panel.messaging-chat-shell {
  width: auto !important;
  min-width: 0 !important;
  border-left: 0 !important;
  border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
  box-shadow: none !important;
}

body[data-active-view="chat"] .messaging-directory-header h2 {
  font-size: clamp(28px, 2.5vw, 36px) !important;
}

body[data-active-view="chat"] .messaging-list {
  width: 100% !important;
}

body[data-active-view="chat"] .mention-activity-row,
body[data-active-view="chat"] .messaging-object-row.mention-activity-row {
  grid-template-columns: 40px minmax(0, 1fr) !important;
}

body[data-active-view="chat"] .mention-activity-row em {
  position: absolute !important;
  right: 12px !important;
  top: 12px !important;
}

body[data-active-view="chat"] .mention-row-copy {
  padding-right: 34px !important;
}

body[data-active-view="chat"] .mention-row-actions {
  display: none !important;
}

body[data-active-view="chat"] .chat-thread-scroll {
  padding-inline: clamp(20px, 5vw, 72px) !important;
}

body[data-active-view="chat"] .chat-bubble {
  max-width: min(760px, 96%) !important;
}

body[data-active-view="chat"] .chat-composer.messaging-composer {
  margin-inline: clamp(14px, 3.2vw, 42px) !important;
}

@media (max-width: 900px) {
  body[data-active-view="chat"] .chat-page.messaging-workspace,
  body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
    --message-rail: 64px;
    --activity-side: 190px;
    grid-template-areas: "rail thread activity" !important;
    grid-template-columns: var(--message-rail) minmax(0, 1fr) var(--activity-side) !important;
    grid-template-rows: minmax(0, 1fr) !important;
  }

  body[data-active-view="chat"] .messaging-directory {
    padding-inline: 12px !important;
  }

  body[data-active-view="chat"] .messaging-directory-header h2 {
    font-size: 26px !important;
  }

  body[data-active-view="chat"] .messaging-chat-header [data-chat-action="live"],
  body[data-active-view="chat"] .messaging-chat-header [data-chat-panel="pins"] {
    display: none !important;
  }

  body[data-active-view="chat"] .chat-composer-command,
  body[data-active-view="chat"] .chat-composer-ai {
    display: inline-grid !important;
  }

  body[data-active-view="chat"] .messaging-composer .chat-composer-entry {
    grid-template-columns: 34px 34px minmax(0, 1fr) repeat(5, 34px) !important;
  }
}

/* Final chat simplification lock */
body[data-active-view="chat"] .chat-page.messaging-workspace,
body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
  --message-rail: 64px;
  --message-directory: clamp(240px, 24vw, 320px);
  --message-context: clamp(280px, 25vw, 360px);
  grid-template-areas: "rail directory thread" !important;
  grid-template-columns: var(--message-rail) var(--message-directory) minmax(0, 1fr) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  background: #141512 !important;
}

body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
  grid-template-areas: "rail directory thread context" !important;
  grid-template-columns: var(--message-rail) var(--message-directory) minmax(0, 1fr) var(--message-context) !important;
}

body[data-active-view="chat"] .messaging-left-rail {
  grid-area: rail !important;
}

body[data-active-view="chat"] .messaging-directory {
  grid-area: directory !important;
  height: 100vh !important;
  padding: 18px 12px !important;
  border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-left: 0 !important;
  background: #1d1f1b !important;
}

body[data-active-view="chat"] .messaging-directory::after {
  display: none !important;
}

body[data-active-view="chat"] .messaging-directory-header {
  min-height: 48px !important;
  align-items: center !important;
}

body[data-active-view="chat"] .messaging-directory-header p {
  font-size: 11px !important;
  letter-spacing: 0 !important;
}

body[data-active-view="chat"] .messaging-directory-header h2 {
  font-size: 21px !important;
  font-weight: 780 !important;
}

body[data-active-view="chat"] .messaging-directory-search {
  width: 100% !important;
  margin: 14px 0 12px !important;
  border-radius: 10px !important;
  background: rgba(255, 255, 255, 0.055) !important;
}

body[data-active-view="chat"] .messaging-list {
  width: 100% !important;
}

body[data-active-view="chat"] .messaging-conversation-row,
body[data-active-view="chat"] .messaging-object-row,
body[data-active-view="chat"] .messaging-channel-row {
  border-radius: 10px !important;
  background: transparent !important;
  box-shadow: none !important;
}

body[data-active-view="chat"] .messaging-conversation-row.is-active,
body[data-active-view="chat"] .messaging-channel-row.is-active {
  background: rgba(255, 255, 255, 0.08) !important;
}

body[data-active-view="chat"] .messaging-channel-section.is-collapsed .messaging-channel-row {
  display: none !important;
}

body[data-active-view="chat"] .messaging-chat-shell {
  grid-area: thread !important;
}

body[data-active-view="chat"] .messaging-context-panel {
  grid-area: context !important;
}

body[data-active-view="chat"] .chat-thread-panel.messaging-chat-shell {
  width: auto !important;
  min-width: 0 !important;
  border-right: 0 !important;
  background: #f4f1ea !important;
  box-shadow: none !important;
}

body[data-active-view="chat"] .messaging-chat-header {
  min-height: 64px !important;
  grid-template-columns: minmax(0, 1fr) auto auto !important;
  grid-template-areas: "title ai actions" !important;
  padding: 12px 18px !important;
  background: rgba(244, 241, 234, 0.94) !important;
}

body[data-active-view="chat"] .chat-ai-pill {
  align-self: center;
}

body[data-active-view="chat"] .messaging-chat-header .chat-thread-actions {
  grid-template-columns: repeat(4, 34px) !important;
  align-content: center !important;
}

body[data-active-view="chat"] .messaging-connection-banner,
body[data-active-view="chat"] .messaging-typing-line,
body[data-active-view="chat"] .chat-composer-command,
body[data-active-view="chat"] .chat-composer-ai {
  display: none !important;
}

body[data-active-view="chat"] .chat-thread-scroll {
  padding: 20px clamp(18px, 5vw, 64px) !important;
}

body[data-active-view="chat"] .chat-bubble {
  max-width: min(680px, 92%) !important;
}

body[data-active-view="chat"] .chat-bubble.is-highlighted .chat-bubble-body {
  outline: 2px solid rgba(143, 115, 255, 0.5);
  outline-offset: 3px;
}

body[data-active-view="chat"] .chat-bubble-body {
  border-radius: 12px !important;
  background: rgba(255, 255, 255, 0.78) !important;
}

body[data-active-view="chat"] .chat-bubble-body code {
  padding: 2px 5px;
  border-radius: 6px;
  background: rgba(27, 28, 24, 0.1);
  color: inherit;
  font-size: 0.92em;
}

body[data-active-view="chat"] .chat-bubble--right .chat-bubble-body {
  background: #20211d !important;
}

body[data-active-view="chat"] .chat-bubble--right .chat-bubble-body p {
  color: #ffffff !important;
}

body[data-active-view="chat"] .chat-composer.messaging-composer {
  min-height: 58px !important;
  margin: 0 clamp(16px, 4vw, 56px) 86px !important;
  border-radius: 14px !important;
  background: #ffffff !important;
}

body[data-active-view="chat"] .messaging-composer .chat-composer-entry {
  grid-template-columns: 34px 34px minmax(0, 1fr) 34px 34px 34px !important;
}

body[data-active-view="chat"] .composer-command-menu,
body[data-active-view="chat"] .composer-mention-menu,
body[data-active-view="chat"] .composer-add-menu,
body[data-active-view="chat"] .chat-emoji-panel {
  width: min(380px, calc(100vw - 120px)) !important;
}

body[data-active-view="tasks"] .task-row {
  grid-template-columns: 96px 22px minmax(160px, 1fr) repeat(3, auto) !important;
  gap: 10px !important;
}

body[data-active-view="tasks"] .task-row .task-action,
.dashboard-task-row .task-action {
  display: inline-flex !important;
}

body[data-active-view="tasks"] .task-action,
.dashboard-task-row .task-action {
  min-height: 30px !important;
  align-items: center !important;
  justify-content: center !important;
  padding-top: 3px !important;
  line-height: 1 !important;
}

.task-action--quiet {
  background: transparent !important;
  color: var(--text) !important;
  border-color: var(--border-strong) !important;
}

.task-action--danger {
  background: transparent !important;
  color: #ffb4a8 !important;
  border-color: rgba(255, 180, 168, 0.4) !important;
}

.task-action--danger:hover {
  background: #ff6b57 !important;
  color: #ffffff !important;
}

@media (max-width: 860px) {
  body[data-active-view="tasks"] .task-row {
    grid-template-columns: 1fr auto auto !important;
    grid-template-areas:
      "priority progress progress"
      "title title title"
      "edit delete delete" !important;
    align-items: center !important;
  }

  body[data-active-view="tasks"] .task-row > :nth-child(1) {
    grid-area: priority;
  }

  body[data-active-view="tasks"] .task-row > :nth-child(2) {
    display: none;
  }

  body[data-active-view="tasks"] .task-row > :nth-child(3) {
    grid-area: title;
  }

  body[data-active-view="tasks"] .task-row > :nth-child(4) {
    grid-area: progress;
  }

  body[data-active-view="tasks"] .task-row > :nth-child(5) {
    grid-area: edit;
    justify-self: start;
  }

  body[data-active-view="tasks"] .task-row > :nth-child(6) {
    grid-area: delete;
    justify-self: end;
  }

  body[data-active-view="chat"] .chat-page.messaging-workspace,
  body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
    grid-template-areas:
      "rail directory"
      "rail thread" !important;
    grid-template-columns: var(--message-rail) minmax(0, 1fr) !important;
    grid-template-rows: 220px minmax(0, 1fr) !important;
  }

  body[data-active-view="chat"] .messaging-context-panel {
    position: fixed !important;
    inset: 0 0 0 auto !important;
    z-index: 80;
    width: min(360px, calc(100vw - 64px));
  }

  body[data-active-view="chat"] .messaging-directory {
    height: 220px !important;
    min-height: 0 !important;
  }

  body[data-active-view="chat"] .messaging-chat-header {
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-areas:
      "title actions"
      "ai actions" !important;
  }
}

/* Light mode inversion pass: dark surfaces become light, light controls become dark. */
:root[data-theme="light"] {
  color-scheme: light !important;
  --bg: #f4f3ef;
  --panel: #ffffff;
  --panel-soft: #eeece6;
  --panel-muted: #dfdcd4;
  --border: rgba(5, 5, 5, 0.14);
  --border-strong: rgba(5, 5, 5, 0.24);
  --text: #10100f;
  --text-soft: #4c4a45;
  --text-muted: #88847b;
  --white: #050505;
  --black: #ffffff;
  --accent: #6d2fc0;
  --accent-soft: rgba(109, 47, 192, 0.12);
  --accent-border: rgba(109, 47, 192, 0.32);
  --green: var(--accent);
  --cyan: var(--accent);
  --purple: var(--accent);
  --app-button: #111111;
}

:root[data-theme="light"] body,
:root[data-theme="light"] .app-shell {
  background: var(--bg) !important;
  color: var(--text) !important;
}

:root[data-theme="light"] .sidebar {
  background: rgba(255, 255, 255, 0.86) !important;
  border-color: var(--border) !important;
}

:root[data-theme="light"] .sidebar-search,
:root[data-theme="light"] .new-menu,
:root[data-theme="light"] .workspace-card,
:root[data-theme="light"] .connect-apps-card,
:root[data-theme="light"] .request-panel,
:root[data-theme="light"] .promoted-task-panel,
:root[data-theme="light"] .status-panel,
:root[data-theme="light"] .dashboard-task-board,
:root[data-theme="light"] .dashboard-calendar-card,
:root[data-theme="light"] .dashboard-up-next-card,
:root[data-theme="light"] .placeholder-panel,
:root[data-theme="light"] .settings-page,
:root[data-theme="light"] .settings-card,
:root[data-theme="light"] .discord-card,
:root[data-theme="light"] .discord-settings-panel,
:root[data-theme="light"] .integration-detail-card,
:root[data-theme="light"] .integration-detail-logo,
:root[data-theme="light"] .chat-rail,
:root[data-theme="light"] .chat-thread-panel,
:root[data-theme="light"] .chat-members-sidebar,
:root[data-theme="light"] .ai-native-history,
:root[data-theme="light"] .ai-native-panel {
  background: var(--panel) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}

:root[data-theme="light"] .dashboard-request-card,
:root[data-theme="light"] .request-card,
:root[data-theme="light"] .promoted-task-card,
:root[data-theme="light"] .dashboard-task-row,
:root[data-theme="light"] .task-row,
:root[data-theme="light"] .calendar-day,
:root[data-theme="light"] .dashboard-calendar-day,
:root[data-theme="light"] .settings-field input,
:root[data-theme="light"] .settings-field select,
:root[data-theme="light"] .settings-field textarea,
:root[data-theme="light"] .event-form input,
:root[data-theme="light"] .event-form select,
:root[data-theme="light"] .event-form textarea {
  background: var(--panel-soft) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}

:root[data-theme="light"] .task-empty-state,
:root[data-theme="light"] .messaging-empty-state,
:root[data-theme="light"] .ai-native-empty,
:root[data-theme="light"] .notification-empty {
  background: rgba(255, 255, 255, 0.42) !important;
  border-color: var(--border) !important;
  color: var(--text-soft) !important;
}

:root[data-theme="light"] .nav-item:not(.bottom-control-bar .nav-item) {
  color: var(--text-soft) !important;
}

:root[data-theme="light"] .nav-item:not(.bottom-control-bar .nav-item):hover {
  background: var(--panel-soft) !important;
  color: var(--text) !important;
}

:root[data-theme="light"] .nav-item.is-active:not(.nav-item--new):not(.bottom-control-bar .nav-item),
:root[data-theme="light"] .settings-tab.is-active,
:root[data-theme="light"] [data-theme-choice].is-active {
  background: var(--white) !important;
  border-color: var(--white) !important;
  color: var(--black) !important;
}

:root[data-theme="light"] .nav-item--new:not(.bottom-control-bar .nav-item--new),
:root[data-theme="light"] .nav-item--new:not(.bottom-control-bar .nav-item--new):hover,
:root[data-theme="light"] .nav-item--new.is-active:not(.bottom-control-bar .nav-item--new),
:root[data-theme="light"] .page-action,
:root[data-theme="light"] .task-action,
:root[data-theme="light"] .course-open,
:root[data-theme="light"] .request-actions button,
:root[data-theme="light"] .ai-native-action,
:root[data-theme="light"] .ai-native-send,
:root[data-theme="light"] .chat-members-button,
:root[data-theme="light"] .chat-composer-send {
  background: var(--white) !important;
  border-color: var(--white) !important;
  color: var(--black) !important;
}

:root[data-theme="light"] .task-action--quiet {
  background: transparent !important;
  border-color: var(--border-strong) !important;
  color: var(--text) !important;
}

:root[data-theme="light"] .task-action--danger {
  background: transparent !important;
  border-color: rgba(168, 46, 34, 0.42) !important;
  color: #8f251b !important;
}

:root[data-theme="light"] .section-head,
:root[data-theme="light"] .dashboard-task-board__head,
:root[data-theme="light"] .dashboard-task-panel-head {
  border-color: var(--border) !important;
}

:root[data-theme="light"] .section-head h1,
:root[data-theme="light"] .section-head h2,
:root[data-theme="light"] .dashboard-task-board__head h3,
:root[data-theme="light"] .dashboard-task-panel-head h4,
:root[data-theme="light"] .task-title,
:root[data-theme="light"] .dashboard-task-row span:last-of-type,
:root[data-theme="light"] .promoted-task-card h3 {
  color: var(--text) !important;
}

:root[data-theme="light"] .count-badge,
:root[data-theme="light"] .dashboard-mini-count {
  background: var(--white) !important;
  color: var(--black) !important;
}

:root[data-theme="light"] .task-priority,
:root[data-theme="light"] .dashboard-task-priority,
:root[data-theme="light"] .promoted-task-card__meta {
  color: var(--text-soft) !important;
  background: transparent !important;
}

:root[data-theme="light"] body[data-active-view="tasks"] .task-row,
:root[data-theme="light"] body[data-active-view="tasks"] .task-row .task-title,
:root[data-theme="light"] body[data-active-view="tasks"] .task-row > span,
:root[data-theme="light"] body[data-active-view="tasks"] .dashboard-task-row > span {
  color: var(--text) !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

:root[data-theme="light"] .chat-thread-panel.messaging-chat-shell,
:root[data-theme="light"] body[data-active-view="chat"] .chat-thread-panel.messaging-chat-shell,
:root[data-theme="light"] body[data-active-view="chat"] .messaging-chat-header,
:root[data-theme="light"] body[data-active-view="chat"] .chat-composer.messaging-composer {
  background: var(--panel) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}

:root[data-theme="light"] body[data-active-view="chat"] .chat-bubble-body {
  background: var(--panel-soft) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}

:root[data-theme="light"] body[data-active-view="chat"] .chat-bubble--right .chat-bubble-body {
  background: var(--white) !important;
  color: var(--black) !important;
}

:root[data-theme="light"] body[data-active-view="chat"] .chat-bubble--right .chat-bubble-body p {
  color: var(--black) !important;
}

:root[data-theme="light"] .bottom-control-rail {
  background: rgba(238, 238, 236, 0.94) !important;
  border: 0 !important;
  box-shadow: none !important;
}

:root[data-theme="light"] .bottom-control-bar .nav-item,
:root[data-theme="light"] .bottom-control-bar .nav-item:hover,
:root[data-theme="light"] .bottom-control-bar .nav-item:focus-visible,
:root[data-theme="light"] .bottom-control-bar .nav-item.is-active,
:root[data-theme="light"] .bottom-control-bar .nav-item--new,
:root[data-theme="light"] .bottom-control-bar .nav-item--new:hover,
:root[data-theme="light"] .bottom-control-bar .nav-item--new:focus-visible {
  background: #f7f7f5 !important;
  border: 0 !important;
  color: #000000 !important;
  box-shadow: none !important;
}

:root[data-theme="light"] .bottom-control-bar .nav-icon,
:root[data-theme="light"] .bottom-control-bar .nav-label {
  color: #000000 !important;
}

.ai-native-reference-action {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: fit-content !important;
  min-height: 34px !important;
  margin-top: 8px !important;
  padding: 0 14px !important;
  border: 1px solid var(--border-strong, rgba(255, 255, 255, 0.18)) !important;
  border-radius: 999px !important;
  background: var(--panel, #181818) !important;
  color: var(--text, #ffffff) !important;
  font: inherit !important;
  font-size: 13px !important;
  font-weight: 650 !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease !important;
}

.ai-native-reference-action:hover,
.ai-native-reference-action:focus-visible {
  border-color: var(--accent-border, rgba(99, 226, 254, 0.7)) !important;
  background: var(--panel-soft, #202020) !important;
  transform: translateY(-1px) !important;
  outline: none !important;
}

.ai-native-message--user .ai-native-reference-action {
  display: none !important;
}

/* Exact sender from Kovo Group 810.svg, scoped to the AI Hub composer */
body[data-active-view="ai"] .ai-native-composer {
  min-height: 62px !important;
  padding: 8px !important;
}

body[data-active-view="ai"] .ai-native-send {
  position: relative !important;
  width: 36px !important;
  min-width: 36px !important;
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.16) !important;
  color: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;
  opacity: 1 !important;
}

body[data-active-view="ai"] .ai-native-send img {
  width: 36px !important;
  height: 36px !important;
  display: block !important;
  opacity: 0 !important;
  transition: opacity 160ms ease, transform 160ms ease !important;
}

body[data-active-view="ai"] .ai-native-send:disabled::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  background: #ffffff !important;
  mask: url("data:image/svg+xml,%3Csvg width='67' height='67' viewBox='1206 13 67 67' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1249.59 45.214C1249.49 45.3065 1249.38 45.3799 1249.25 45.4299C1249.13 45.48 1248.99 45.5058 1248.85 45.5058C1248.72 45.5058 1248.58 45.48 1248.46 45.4299C1248.33 45.3799 1248.22 45.3065 1248.12 45.214L1240.54 37.9589V57.4414C1240.54 57.7052 1240.43 57.9582 1240.23 58.1447C1240.04 58.3313 1239.77 58.4361 1239.5 58.4361C1239.22 58.4361 1238.96 58.3313 1238.76 58.1447C1238.57 57.9582 1238.46 57.7052 1238.46 57.4414V37.9589L1230.88 45.214C1230.68 45.4007 1230.42 45.5055 1230.14 45.5055C1229.87 45.5055 1229.6 45.4007 1229.41 45.214C1229.21 45.0274 1229.1 44.7742 1229.1 44.5103C1229.1 44.2463 1229.21 43.9932 1229.41 43.8065L1238.76 34.8542C1238.86 34.7617 1238.97 34.6884 1239.1 34.6383C1239.23 34.5883 1239.36 34.5625 1239.5 34.5625C1239.63 34.5625 1239.77 34.5883 1239.9 34.6383C1240.02 34.6884 1240.14 34.7617 1240.23 34.8542L1249.59 43.8065C1249.69 43.8989 1249.76 44.0086 1249.82 44.1294C1249.87 44.2501 1249.89 44.3796 1249.89 44.5103C1249.89 44.641 1249.87 44.7704 1249.82 44.8912C1249.76 45.0119 1249.69 45.1216 1249.59 45.214Z'/%3E%3C/svg%3E") center / contain no-repeat !important;
  -webkit-mask: url("data:image/svg+xml,%3Csvg width='67' height='67' viewBox='1206 13 67 67' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1249.59 45.214C1249.49 45.3065 1249.38 45.3799 1249.25 45.4299C1249.13 45.48 1248.99 45.5058 1248.85 45.5058C1248.72 45.5058 1248.58 45.48 1248.46 45.4299C1248.33 45.3799 1248.22 45.3065 1248.12 45.214L1240.54 37.9589V57.4414C1240.54 57.7052 1240.43 57.9582 1240.23 58.1447C1240.04 58.3313 1239.77 58.4361 1239.5 58.4361C1239.22 58.4361 1238.96 58.3313 1238.76 58.1447C1238.57 57.9582 1238.46 57.7052 1238.46 57.4414V37.9589L1230.88 45.214C1230.68 45.4007 1230.42 45.5055 1230.14 45.5055C1229.87 45.5055 1229.6 45.4007 1229.41 45.214C1229.21 45.0274 1229.1 44.7742 1229.1 44.5103C1229.1 44.2463 1229.21 43.9932 1229.41 43.8065L1238.76 34.8542C1238.86 34.7617 1238.97 34.6884 1239.1 34.6383C1239.23 34.5883 1239.36 34.5625 1239.5 34.5625C1239.63 34.5625 1239.77 34.5883 1239.9 34.6383C1240.02 34.6884 1240.14 34.7617 1240.23 34.8542L1249.59 43.8065C1249.69 43.8989 1249.76 44.0086 1249.82 44.1294C1249.87 44.2501 1249.89 44.3796 1249.89 44.5103C1249.89 44.641 1249.87 44.7704 1249.82 44.8912C1249.76 45.0119 1249.69 45.1216 1249.59 45.214Z'/%3E%3C/svg%3E") center / contain no-repeat !important;
}

body[data-active-view="ai"] .ai-native-send:not(:disabled) img {
  opacity: 1 !important;
}

body[data-active-view="ai"] .ai-native-send:not(:disabled) {
  background: transparent !important;
}

body[data-active-view="ai"] .ai-native-send:not(:disabled):hover img {
  transform: translateY(-1px) !important;
}

body[data-active-view="ai"] .ai-native-send::before,
body[data-active-view="ai"] .ai-native-send__sending {
  display: none !important;
}

body[data-active-view="ai"] .ai-native-message--assistant {
  display: grid !important;
  grid-template-columns: 32px minmax(0, 1fr) !important;
  gap: 8px 10px !important;
  align-items: start !important;
}

body[data-active-view="ai"] .ai-native-message--assistant .ai-native-message__logo {
  grid-row: 1 / span 2 !important;
  display: block !important;
  width: 32px !important;
  height: 32px !important;
  padding: 7px !important;
  border: 1px solid var(--border) !important;
  border-radius: 999px !important;
  background: var(--panel-soft) !important;
  object-fit: contain !important;
}

body[data-active-view="ai"] .ai-native-message--assistant .ai-native-message__meta,
body[data-active-view="ai"] .ai-native-message--assistant .ai-native-message__body,
body[data-active-view="ai"] .ai-native-message--assistant .ai-native-reference-action {
  grid-column: 2 !important;
}

body[data-active-view="ai"] .ai-native-loading-circle {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
  border: 2px solid rgba(255, 255, 255, 0.16) !important;
  border-top-color: var(--white) !important;
  border-radius: 999px !important;
  animation: aiLoadingCircle 780ms linear infinite !important;
}

@keyframes aiLoadingCircle {
  to {
    transform: rotate(360deg);
  }
}

.command-palette {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: start center;
  padding: 24px 16px;
}

.command-palette-backdrop {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  background: rgba(18, 19, 17, 0.54);
  cursor: default;
}

.command-palette-card {
  position: relative;
  width: min(680px, calc(100vw - 32px));
  max-height: min(500px, calc(100vh - 48px));
  display: grid;
  grid-template-rows: 52px minmax(0, 1fr) 44px;
  overflow: hidden;
  border: 1px solid rgba(26, 27, 24, 0.14);
  border-radius: 7px;
  background: #fbfaf8;
  color: #2b2c27;
  box-shadow: 0 28px 90px rgba(0, 0, 0, 0.32), 0 0 0 1px rgba(255, 255, 255, 0.34);
  animation: commandPaletteIn 150ms ease both;
}

.command-palette-search {
  min-width: 0;
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  border-bottom: 1px solid rgba(31, 32, 28, 0.1);
  color: #9b9a96;
}

.command-palette-search i {
  font-size: 19px;
}

.command-palette-search input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: #2b2c27;
  font: inherit;
  font-size: 17px;
  font-weight: 500;
}

.command-palette-search input::placeholder {
  color: #c7c6c2;
}

.command-palette-list {
  min-height: 0;
  overflow-y: auto;
  padding: 8px 14px;
  scrollbar-color: #b9b8b4 transparent;
  scrollbar-width: thin;
}

.command-palette-list::-webkit-scrollbar {
  width: 14px;
}

.command-palette-list::-webkit-scrollbar-thumb {
  border: 4px solid #fbfaf8;
  border-radius: 999px;
  background: #b9b8b4;
}

.command-palette-group {
  padding: 8px 0 6px;
  color: #b8b7b3;
  font-size: 14px;
  font-weight: 500;
}

.command-palette-item {
  width: 100%;
  min-height: 44px;
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr) 20px;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: #4d4e49;
  cursor: pointer;
  font: inherit;
  text-align: left;
}

.command-palette-item span:not(.command-palette-icon) {
  overflow: hidden;
  font-size: 16px;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.command-palette-icon {
  width: 30px;
  height: 30px;
  display: inline-grid;
  place-items: center;
  border-radius: 7px;
  background: #f7f6f4;
  color: #bbb9b4;
  font-size: 17px;
}

.command-palette-arrow {
  color: #a5a4a0;
  font-size: 18px;
  opacity: 0;
}

.command-palette-item.is-active {
  background: #f3f2f0;
  color: #30312d;
}

.command-palette-item.is-active .command-palette-arrow {
  opacity: 1;
}

.command-palette-empty {
  padding: 26px 0;
  color: #8e8d88;
  font-size: 14px;
  text-align: center;
}

.command-palette-footer {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
  padding: 0 14px;
  border-top: 1px solid rgba(31, 32, 28, 0.1);
  color: #c0bfbb;
  font-size: 13px;
}

.command-palette-footer span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  white-space: nowrap;
}

.command-palette-footer kbd {
  min-width: 26px;
  height: 26px;
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(31, 32, 28, 0.1);
  border-radius: 7px;
  background: #f8f7f5;
  color: #b5b4af;
  font: inherit;
  font-size: 13px;
  box-shadow: 0 1px 2px rgba(31, 32, 28, 0.08);
}

body.is-command-palette-open {
  overflow: hidden;
}

@keyframes commandPaletteIn {
  from {
    opacity: 0;
    transform: translateY(-8px) scale(0.985);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 700px) {
  .command-palette {
    padding: 14px 10px;
  }

  .command-palette-card {
    width: calc(100vw - 20px);
    max-height: calc(100vh - 28px);
    grid-template-rows: 56px minmax(0, 1fr) auto;
  }

  .command-palette-search {
    gap: 10px;
    padding: 0 14px;
  }

  .command-palette-search input,
  .command-palette-item span:not(.command-palette-icon) {
    font-size: 17px;
  }

  .command-palette-list {
    padding: 10px;
  }

  .command-palette-group {
    font-size: 14px;
  }

  .command-palette-item {
    min-height: 52px;
    grid-template-columns: 36px minmax(0, 1fr) 20px;
    gap: 10px;
    padding: 7px 9px;
  }

  .command-palette-icon {
    width: 34px;
    height: 34px;
    font-size: 18px;
  }

  .command-palette-footer {
    flex-wrap: wrap;
    gap: 8px 14px;
    padding: 10px 12px;
    font-size: 13px;
  }

  .command-palette-footer kbd {
    min-width: 28px;
    height: 28px;
    font-size: 13px;
  }
}

/* Dashboard layout repair */
body[data-active-view="dashboard"] .view-panel--board {
  width: min(100%, 1320px) !important;
  max-width: 1320px !important;
  margin: 0 auto !important;
}

body[data-active-view="dashboard"] .dashboard-overview {
  display: grid !important;
  grid-template-rows: auto auto !important;
  gap: clamp(18px, 2vw, 26px) !important;
  width: 100% !important;
}

body[data-active-view="dashboard"] .dashboard-figma-top {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px) !important;
  gap: clamp(16px, 2vw, 24px) !important;
  align-items: stretch !important;
  min-height: 0 !important;
}

body[data-active-view="dashboard"] .dashboard-hero-copy {
  min-height: 232px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  padding: clamp(24px, 3vw, 36px) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  background: var(--panel) !important;
}

body[data-active-view="dashboard"] .dashboard-hero-copy h3 {
  max-width: 760px !important;
  margin: 0 0 18px !important;
  font-size: clamp(34px, 4.2vw, 56px) !important;
  line-height: 1.02 !important;
  letter-spacing: 0 !important;
}

body[data-active-view="dashboard"] .dashboard-hero-copy span {
  max-width: 720px !important;
  color: var(--text-soft) !important;
  font-size: clamp(15px, 1.35vw, 18px) !important;
  line-height: 1.5 !important;
}

body[data-active-view="dashboard"] .dashboard-new-grid {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

body[data-active-view="dashboard"] .dashboard-new-card {
  grid-column: span 2 !important;
  min-height: 111px !important;
  padding: 16px 12px !important;
  border: 1px solid var(--border-strong) !important;
  border-radius: 8px !important;
  background: var(--panel) !important;
}

body[data-active-view="dashboard"] .dashboard-new-card:nth-child(4) {
  grid-column: 2 / span 2 !important;
}

body[data-active-view="dashboard"] .dashboard-new-card:nth-child(5) {
  grid-column: 4 / span 2 !important;
}

body[data-active-view="dashboard"] .dashboard-new-icon {
  font-size: 34px !important;
}

body[data-active-view="dashboard"] .dashboard-main-grid--figma {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 340px) !important;
  gap: clamp(16px, 2vw, 24px) !important;
  align-items: start !important;
}

body[data-active-view="dashboard"] .dashboard-primary-stack,
body[data-active-view="dashboard"] .dashboard-side-stack {
  min-width: 0 !important;
}

body[data-active-view="dashboard"] .dashboard-task-row {
  min-width: 0 !important;
  grid-template-columns: minmax(72px, auto) 22px minmax(0, 1fr) auto !important;
}

body[data-active-view="dashboard"] .dashboard-task-row > span:last-of-type {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card,
body[data-active-view="dashboard"] .dashboard-up-next-card,
body[data-active-view="dashboard"] .dashboard-task-board {
  border-radius: 8px !important;
}

@media (max-width: 1180px) {
  body[data-active-view="dashboard"] .main-stage {
    width: 100% !important;
    max-width: 100vw !important;
    padding-right: 24px !important;
    padding-left: 24px !important;
    overflow-x: hidden !important;
  }

  body[data-active-view="dashboard"] .view-panel--board {
    max-width: calc(100vw - 48px) !important;
  }

  body[data-active-view="dashboard"] .dashboard-figma-top {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  body[data-active-view="dashboard"] .dashboard-new-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }

  body[data-active-view="dashboard"] .dashboard-new-card {
    grid-column: span 2 !important;
  }

  body[data-active-view="dashboard"] .dashboard-new-card:nth-child(4) {
    grid-column: 2 / span 2 !important;
  }

  body[data-active-view="dashboard"] .dashboard-new-card:nth-child(5) {
    grid-column: 4 / span 2 !important;
  }
}

@media (max-width: 980px) {
  body[data-active-view="dashboard"] .dashboard-main-grid--figma {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  body[data-active-view="dashboard"] .dashboard-hero-copy {
    min-height: 0 !important;
  }

  body[data-active-view="dashboard"] .dashboard-side-stack {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  body[data-active-view="dashboard"] .main-stage {
    padding: 16px 14px 168px !important;
  }

  body[data-active-view="dashboard"] .dashboard-overview {
    gap: 14px !important;
  }

  body[data-active-view="dashboard"] .dashboard-hero-copy {
    padding: 22px !important;
  }

  body[data-active-view="dashboard"] .dashboard-hero-copy h3 {
    font-size: 32px !important;
  }

  body[data-active-view="dashboard"] .dashboard-new-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  body[data-active-view="dashboard"] .dashboard-new-card,
  body[data-active-view="dashboard"] .dashboard-new-card:nth-child(4),
  body[data-active-view="dashboard"] .dashboard-new-card:nth-child(5) {
    grid-column: auto !important;
    min-height: 118px !important;
  }

  body[data-active-view="dashboard"] .dashboard-new-card:nth-child(5) {
    grid-column: 1 / -1 !important;
  }

  body[data-active-view="dashboard"] .dashboard-side-stack {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  body[data-active-view="dashboard"] .dashboard-task-board__requests {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  body[data-active-view="dashboard"] .dashboard-task-row {
    grid-template-columns: 1fr auto !important;
    gap: 6px 10px !important;
    min-height: 58px !important;
  }

  body[data-active-view="dashboard"] .dashboard-task-priority,
  body[data-active-view="dashboard"] .dashboard-task-row .task-bullet {
    display: none !important;
  }
}

/* Desktop-first dashboard lock */
body[data-active-view="dashboard"] {
  overflow-x: auto !important;
}

body[data-active-view="dashboard"] .main-stage {
  width: min(100%, 1540px) !important;
  max-width: none !important;
  min-width: 1180px !important;
  padding: 28px 40px 148px !important;
  overflow-x: visible !important;
}

body[data-active-view="dashboard"] .view-panel--board {
  width: 100% !important;
  max-width: 1320px !important;
  min-width: 1100px !important;
  margin: 0 auto !important;
}

body[data-active-view="dashboard"] .dashboard-overview {
  display: grid !important;
  grid-template-rows: auto auto !important;
  gap: 24px !important;
}

body[data-active-view="dashboard"] .dashboard-figma-top {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 520px !important;
  gap: 24px !important;
  align-items: stretch !important;
}

body[data-active-view="dashboard"] .dashboard-hero-copy {
  min-height: 248px !important;
  padding: 34px !important;
}

body[data-active-view="dashboard"] .dashboard-hero-copy h3 {
  font-size: 52px !important;
  line-height: 1.02 !important;
}

body[data-active-view="dashboard"] .dashboard-hero-copy span {
  max-width: 700px !important;
  font-size: 17px !important;
}

body[data-active-view="dashboard"] .dashboard-new-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

body[data-active-view="dashboard"] .dashboard-new-card,
body[data-active-view="dashboard"] .dashboard-new-card:nth-child(4),
body[data-active-view="dashboard"] .dashboard-new-card:nth-child(5) {
  grid-column: auto !important;
  min-height: 119px !important;
}

body[data-active-view="dashboard"] .dashboard-main-grid--figma {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 320px !important;
  gap: 24px !important;
  align-items: start !important;
}

body[data-active-view="dashboard"] .dashboard-side-stack {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

body[data-active-view="dashboard"] .dashboard-task-board__requests {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

body[data-active-view="dashboard"] .dashboard-task-row {
  grid-template-columns: 86px 22px minmax(0, 1fr) auto !important;
  min-height: 48px !important;
}

body[data-active-view="dashboard"] .dashboard-task-priority,
body[data-active-view="dashboard"] .dashboard-task-row .task-bullet {
  display: inline-flex !important;
}

/* Dashboard desktop composition reset */
body[data-active-view="dashboard"] {
  overflow-x: auto !important;
}

body[data-active-view="dashboard"] .main-stage {
  width: min(100%, 1540px) !important;
  max-width: none !important;
  min-width: 1180px !important;
  padding: 28px clamp(24px, 3vw, 40px) 148px !important;
}

body[data-active-view="dashboard"] .view-panel--board {
  width: 100% !important;
  max-width: 1380px !important;
  min-width: 1100px !important;
  margin: 0 auto !important;
}

body[data-active-view="dashboard"] .dashboard-overview {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 26px !important;
}

body[data-active-view="dashboard"] .dashboard-figma-top {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) clamp(360px, 32vw, 430px) !important;
  gap: 24px !important;
  align-items: stretch !important;
}

body[data-active-view="dashboard"] .dashboard-hero-copy {
  min-height: 232px !important;
  padding: 30px !important;
  justify-content: center !important;
}

body[data-active-view="dashboard"] .dashboard-hero-copy h3 {
  max-width: 780px !important;
  margin-bottom: 16px !important;
  font-size: clamp(42px, 3.8vw, 56px) !important;
}

body[data-active-view="dashboard"] .dashboard-new-grid {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

body[data-active-view="dashboard"] .dashboard-new-card {
  grid-column: span 2 !important;
  min-height: 108px !important;
  padding: 14px 12px !important;
}

body[data-active-view="dashboard"] .dashboard-new-card:nth-child(4) {
  grid-column: 2 / span 2 !important;
}

body[data-active-view="dashboard"] .dashboard-new-card:nth-child(5) {
  grid-column: 4 / span 2 !important;
}

body[data-active-view="dashboard"] .dashboard-new-icon {
  font-size: 32px !important;
}

body[data-active-view="dashboard"] .dashboard-main-grid--figma {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) clamp(300px, 26vw, 340px) !important;
  gap: 24px !important;
  align-items: start !important;
}

body[data-active-view="dashboard"] .dashboard-primary-stack {
  width: 100% !important;
  min-width: 0 !important;
}

body[data-active-view="dashboard"] .dashboard-side-stack {
  width: 100% !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

body[data-active-view="dashboard"] .dashboard-task-board,
body[data-active-view="dashboard"] .dashboard-calendar-card,
body[data-active-view="dashboard"] .dashboard-up-next-card {
  width: 100% !important;
  min-width: 0 !important;
}

body[data-active-view="dashboard"] .dashboard-task-board__head,
body[data-active-view="dashboard"] .dashboard-task-panel-head {
  min-height: 52px !important;
  padding: 13px 18px !important;
}

body[data-active-view="dashboard"] .dashboard-task-board__head h3,
body[data-active-view="dashboard"] .dashboard-task-panel-head h4 {
  font-size: 15px !important;
}

body[data-active-view="dashboard"] .dashboard-task-board__requests {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
  padding: 12px !important;
}

body[data-active-view="dashboard"] .dashboard-request-card {
  min-height: 130px !important;
  padding: 14px !important;
}

body[data-active-view="dashboard"] .dashboard-task-row {
  display: grid !important;
  grid-template-columns: 82px 20px minmax(0, 1fr) auto !important;
  min-height: 48px !important;
  padding: 8px 14px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card {
  min-height: 300px !important;
  padding: 14px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card .widget-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin-bottom: 14px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card .widget-head h3 {
  font-size: 15px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-grid,
body[data-active-view="dashboard"] .dashboard-calendar-weekdays {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  gap: 6px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-day {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 30px !important;
  border: 1px solid var(--border-strong) !important;
  border-radius: 8px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-weekdays span,
body[data-active-view="dashboard"] .dashboard-calendar-day span {
  font-size: 10px !important;
}

body[data-active-view="dashboard"] .dashboard-up-next-card {
  min-height: 132px !important;
  padding: 14px !important;
}

@media (max-width: 1240px) {
  body[data-active-view="dashboard"] .dashboard-figma-top {
    grid-template-columns: minmax(0, 1fr) 360px !important;
  }

  body[data-active-view="dashboard"] .dashboard-main-grid--figma {
    grid-template-columns: minmax(0, 1fr) 300px !important;
  }
}

/* Dashboard AI homepage */
body[data-active-view="dashboard"] {
  overflow-x: auto !important;
}

body[data-active-view="dashboard"] .main-stage {
  width: min(100%, 1540px) !important;
  max-width: none !important;
  min-width: 1180px !important;
  margin: 0 !important;
  padding: 28px clamp(28px, 4vw, 56px) 148px !important;
}

body[data-active-view="dashboard"] .view-panel--board {
  width: min(100%, 1380px) !important;
  max-width: 1380px !important;
  min-width: 0 !important;
  margin: 0 auto !important;
}

body[data-active-view="dashboard"] .dashboard-overview {
  width: 100% !important;
  display: block !important;
}

.dashboard-home-grid {
  width: 100%;
  min-width: 1080px;
  min-height: calc(100vh - 204px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 24px;
  align-items: stretch;
}

.dashboard-ai-home {
  min-width: 0;
  min-height: 640px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--panel);
}

.dashboard-ai-home__header {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border-strong);
}

.dashboard-ai-home__header p {
  margin: 0 0 4px;
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.dashboard-ai-home__header h3 {
  margin: 0;
  color: var(--white);
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: 0;
}

.dashboard-ai-home__open {
  white-space: nowrap;
}

.dashboard-ai-home__thread {
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px;
  scrollbar-color: #3a3a3a transparent;
  scrollbar-width: thin;
}

.dashboard-ai-home__empty {
  max-width: 560px;
  margin: auto;
  text-align: center;
}

.dashboard-ai-home__empty h4 {
  margin: 0 0 10px;
  color: var(--white);
  font-size: 28px;
  line-height: 1.1;
}

.dashboard-ai-home__empty p {
  margin: 0;
  color: var(--text-soft);
  font-size: 16px;
  line-height: 1.55;
}

.dashboard-ai-message {
  max-width: min(720px, 82%);
}

.dashboard-ai-message--user {
  align-self: flex-end;
}

.dashboard-ai-message--assistant {
  align-self: flex-start;
}

.dashboard-ai-message__meta {
  margin: 0 0 7px;
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 700;
}

.dashboard-ai-message--user .dashboard-ai-message__meta {
  text-align: right;
}

.dashboard-ai-message__body {
  padding: 14px 16px;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: var(--panel-soft);
  color: var(--text);
  line-height: 1.55;
}

.dashboard-ai-message--user .dashboard-ai-message__body {
  background: #f1f1ef;
  color: #121212;
}

.dashboard-ai-message__body p {
  margin: 0 0 12px;
}

.dashboard-ai-message__body p:last-child {
  margin-bottom: 0;
}

.dashboard-ai-home__composer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 44px;
  align-items: end;
  gap: 10px;
  margin: 0 18px 18px;
  padding: 10px;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: #111111;
}

.dashboard-ai-home__input {
  min-width: 0;
}

.dashboard-ai-home__input textarea {
  width: 100%;
  min-height: 32px;
  max-height: 140px;
  display: block;
  resize: none;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
  font: inherit;
  font-size: 15px;
  line-height: 1.5;
}

.dashboard-ai-home__input textarea::placeholder {
  color: #858583;
}

.dashboard-ai-home__send {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--white);
  cursor: pointer;
}

.dashboard-ai-home__send:disabled {
  opacity: 0.45;
  cursor: default;
}

.dashboard-ai-home__send img {
  width: 28px;
  height: 28px;
}

body[data-active-view="dashboard"] .dashboard-side-stack {
  width: 100% !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card,
body[data-active-view="dashboard"] .dashboard-up-next-card {
  width: 100% !important;
  min-width: 0 !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  background: var(--panel) !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card {
  min-height: 354px !important;
  padding: 16px !important;
}

body[data-active-view="dashboard"] .dashboard-up-next-card {
  min-height: 160px !important;
  padding: 16px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card .widget-head {
  margin-bottom: 16px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-grid,
body[data-active-view="dashboard"] .dashboard-calendar-weekdays {
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  gap: 7px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-day {
  min-height: 32px !important;
}

@media (max-width: 1100px) {
  .dashboard-home-grid {
    grid-template-columns: minmax(0, 1fr) 320px;
  }
}

/* Dashboard final desktop spacing */
body[data-active-view="dashboard"] {
  overflow-x: hidden !important;
}

body[data-active-view="dashboard"] .main-stage {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 28px clamp(12px, 2vw, 30px) 148px !important;
}

body[data-active-view="dashboard"] .view-panel--board {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
}

body[data-active-view="dashboard"] .dashboard-overview {
  width: 100% !important;
  display: block !important;
}

body[data-active-view="dashboard"] .dashboard-home-grid {
  width: 100% !important;
  min-width: 0 !important;
  min-height: calc(100vh - 204px) !important;
  display: flex !important;
  gap: 8px !important;
  align-items: stretch !important;
}

body[data-active-view="dashboard"] .dashboard-ai-home {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  min-height: 720px !important;
}

body[data-active-view="dashboard"] .dashboard-side-stack {
  flex: 0 0 clamp(260px, 30vw, 420px) !important;
  width: clamp(260px, 30vw, 420px) !important;
  min-width: 260px !important;
  max-width: 420px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  justify-self: stretch !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card {
  min-height: 430px !important;
  padding: clamp(12px, 1.4vw, 18px) !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card .widget-head h3 {
  font-size: 18px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-grid,
body[data-active-view="dashboard"] .dashboard-calendar-weekdays {
  gap: 9px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-day {
  min-height: clamp(28px, 3vw, 40px) !important;
  border-radius: 9px !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-weekdays span,
body[data-active-view="dashboard"] .dashboard-calendar-day span {
  font-size: clamp(10px, 1vw, 12px) !important;
}

body[data-active-view="dashboard"] .dashboard-up-next-card {
  min-height: 0 !important;
  flex: 1 1 auto !important;
  padding: 18px !important;
}

body[data-active-view="dashboard"] .dashboard-up-next-card h3 {
  font-size: 15px !important;
  margin-bottom: 12px !important;
}

body[data-active-view="dashboard"] .dashboard-upcoming-item {
  min-height: 58px !important;
  padding: 12px !important;
}

body[data-active-view="dashboard"] .dashboard-ai-home {
  width: 100% !important;
  min-height: calc(100vh - 204px) !important;
}

body[data-active-view="dashboard"] .dashboard-calendar-card,
body[data-active-view="dashboard"] .dashboard-up-next-card {
  width: 100% !important;
}

@media (max-width: 900px) {
  body[data-active-view="dashboard"] .dashboard-home-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
  }

  body[data-active-view="dashboard"] .dashboard-ai-home {
    min-height: calc(100vh - 204px) !important;
  }

  body[data-active-view="dashboard"] .dashboard-side-stack {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 12px !important;
  }

  body[data-active-view="dashboard"] .dashboard-calendar-card,
  body[data-active-view="dashboard"] .dashboard-up-next-card {
    min-height: 300px !important;
  }
}

/* Open Thread brand unification: light-first, crisp workspace surfaces. */
:root,
:root[data-theme="light"] {
  color-scheme: light !important;
  --bg: #f8f6f3;
  --panel: #ffffff;
  --panel-soft: #f2f6fb;
  --panel-muted: #e9eef7;
  --border: #d8dce6;
  --border-strong: #b9c2d1;
  --text: #182235;
  --text-soft: #4f5d72;
  --text-muted: #7c8796;
  --white: #182235;
  --black: #ffffff;
  --accent: #7cc8ff;
  --accent-pink: #f5a3c7;
  --accent-lavender: #c8b6ff;
  --accent-soft: rgba(124, 200, 255, 0.16);
  --accent-border: rgba(124, 200, 255, 0.46);
  --green: #4f9f74;
  --red: #c24b5b;
  --cyan: #3aa6d8;
  --purple: #8c72d9;
  --yellow: #b9902e;
  --app-button: #182235;
  --radius-xs: 3px;
  --radius-sm: 5px;
  --radius-md: 7px;
  --shadow-soft: 0 14px 36px rgba(24, 34, 53, 0.08);
}

html,
body,
.app-shell,
.main-stage,
body[data-active-view] .main-stage {
  background: var(--bg) !important;
  color: var(--text) !important;
}

body,
button,
input,
select,
textarea {
  letter-spacing: 0 !important;
}

.sidebar,
.bottom-control-rail,
.request-panel,
.promoted-task-panel,
.status-panel,
.summary-card,
.placeholder-panel,
.embed-shell,
.dashboard-ai-home,
.dashboard-task-board,
.dashboard-calendar-card,
.dashboard-up-next-card,
.dashboard-messages-widget,
.dashboard-ai-widget,
.dashboard-hero-panel,
.dashboard-metric-card,
.messaging-left-rail,
.messaging-directory,
.messaging-chat-shell,
.messaging-context-panel,
.chat-thread-panel,
.chat-members-sidebar,
.ai-native-history,
.ai-native-panel,
.settings-page,
.settings-card,
.discord-header,
.discord-card,
.discord-settings-panel,
.integration-detail-card,
.integration-detail-logo,
.integration-icon-tile,
.connect-apps-card,
.workspace-card,
.new-menu,
.command-palette-card,
.event-modal-card,
.task-modal-card,
.lesson-modal-card {
  background: var(--panel) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

.request-card,
.promoted-task-card,
.task-row,
.dashboard-task-row,
.dashboard-request-card,
.dashboard-calendar-day,
.dashboard-upcoming-item,
.dashboard-message-panel,
.dashboard-message-card,
.dashboard-message-groups,
.dashboard-message-thread,
.dashboard-ai-preview,
.dashboard-ai-message__body,
.calendar-day,
.notification-card,
.notification-empty,
.task-empty-state,
.messaging-row,
.messaging-channel-row,
.messaging-object-row,
.messaging-empty-state,
.chat-bubble-body,
.chat-file-card,
.ai-native-message__body,
.ai-native-composer,
.ai-native-history-item,
.settings-field input,
.settings-field select,
.settings-field textarea,
.settings-label-form input,
.event-form input,
.event-form select,
.event-form textarea,
.discord-form-grid select,
.discord-toggle,
.discord-activity-item,
.discord-empty-state,
.discord-status,
.lesson-option,
.auth-clerk-panel,
.auth-clerk-card {
  background: var(--panel-soft) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

.sidebar,
.messaging-left-rail,
.messaging-directory,
.ai-native-history,
.account-sidebar {
  background: #fbfaf8 !important;
}

.section-head,
.dashboard-task-board__head,
.dashboard-task-panel-head,
.messaging-directory-header,
.messaging-chat-header,
.chat-thread-header,
.ai-native-panel__header,
.ai-native-history__header,
.settings-section-head,
.discord-settings-panel__top {
  background: transparent !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}

h1,
h2,
h3,
h4,
strong,
.brand,
.section-head h1,
.section-head h2,
.dashboard-hero-copy h3,
.dashboard-task-board__head h3,
.dashboard-task-panel-head h4,
.dashboard-calendar-card .widget-head h3,
.dashboard-up-next-card h3,
.calendar-day__number,
.notification-group__header h3,
.notification-card strong,
.task-title,
.dashboard-task-row span:last-of-type,
.request-card h3,
.promoted-task-card h3,
.chat-channel-title h2,
.messaging-directory-header h2,
.ai-native-panel__header h2,
.ai-native-history__header h2,
.settings-section-head h2,
.discord-header h1,
.discord-card h2,
.integrations-copy h1,
.integration-section-head h2 {
  color: var(--text) !important;
}

p,
small,
span,
label,
.dashboard-hero-copy span,
.dashboard-calendar-card p,
.dashboard-upcoming-item span,
.dashboard-upcoming-item small,
.request-meta,
.promoted-task-card__meta,
.task-priority,
.dashboard-task-priority,
.notification-card p,
.notification-card__meta,
.messaging-row-main small,
.messaging-channel-row small,
.messaging-object-row small,
.chat-channel-title p,
.settings-section-head span,
.discord-header span,
.discord-card > span,
.discord-empty-state {
  color: var(--text-soft) !important;
}

.nav-item,
.page-action,
.task-action,
.request-actions button,
.dashboard-calendar-actions .widget-link-button,
.chat-composer-send,
.chat-ai-pill,
.chat-icon-button,
.ai-native-action,
.ai-native-send,
.course-open,
.auth-nav button,
.auth-nav-link,
.pricing-workspace-link,
.pricing-setup-notice a,
.auth-start-button {
  border: 1px solid var(--border-strong) !important;
  background: #ffffff !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

.nav-item:hover,
.nav-item.is-active,
.settings-tab.is-active,
[data-theme-choice].is-active,
.page-action:hover,
.task-action:hover,
.request-actions button:hover,
.chat-icon-button:hover,
.ai-native-action:hover {
  border-color: var(--accent-border) !important;
  background: var(--accent-soft) !important;
  color: var(--text) !important;
}

.nav-item--new,
.nav-item--new:hover,
.nav-item--new.is-active,
.chat-composer-send,
.ai-native-send,
.auth-nav button:last-child,
.auth-nav-link--upgrade {
  background: var(--app-button) !important;
  border-color: var(--app-button) !important;
  color: #ffffff !important;
}

.count-badge,
.dashboard-mini-count,
.notification-group__count,
.request-tag,
.calendar-pill,
.dashboard-calendar-day strong,
.discord-tile-status {
  border: 1px solid var(--accent-border) !important;
  background: var(--accent-soft) !important;
  color: var(--text) !important;
}

.chat-bubble--right .chat-bubble-body,
.ai-native-message--user .ai-native-message__body,
.dashboard-ai-message--user .dashboard-ai-message__body {
  background: #182235 !important;
  border-color: #182235 !important;
  color: #ffffff !important;
}

.chat-bubble--right .chat-bubble-body p,
.ai-native-message--user .ai-native-message__body,
.dashboard-ai-message--user .dashboard-ai-message__body {
  color: #ffffff !important;
}

.calendar-theme-picker,
.sidebar-search,
.messaging-directory-search,
.chat-composer,
.dashboard-ai-home__composer,
.theme-toggle,
.account-search {
  background: #ffffff !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

.calendar-theme-swatch,
.notification-dot,
.podium-orb,
.dashboard-user-pill::before,
.dashboard-message-chip::before,
.task-bullet,
.chat-channel-title-icon {
  border-radius: 999px !important;
}

.request-panel,
.promoted-task-panel,
.status-panel,
.summary-card,
.placeholder-panel,
.embed-shell,
.dashboard-ai-home,
.dashboard-task-board,
.dashboard-calendar-card,
.dashboard-up-next-card,
.dashboard-messages-widget,
.dashboard-ai-widget,
.dashboard-hero-panel,
.dashboard-metric-card,
.messaging-left-rail,
.messaging-directory,
.messaging-chat-shell,
.messaging-context-panel,
.ai-native-history,
.ai-native-panel,
.settings-page,
.settings-card,
.discord-header,
.discord-card,
.discord-settings-panel,
.integration-detail-card,
.integration-icon-tile,
.connect-apps-card,
.workspace-card,
.new-menu,
.command-palette-card,
.event-modal-card,
.task-modal-card,
.lesson-modal-card,
.auth-clerk-panel,
.auth-clerk-card,
.pricing-table-shell,
.pricing-setup-notice {
  border-radius: var(--radius-md) !important;
}

.request-card,
.promoted-task-card,
.task-row,
.dashboard-task-row,
.dashboard-request-card,
.dashboard-calendar-day,
.dashboard-upcoming-item,
.dashboard-message-panel,
.dashboard-message-card,
.dashboard-message-groups,
.dashboard-message-thread,
.dashboard-ai-preview,
.dashboard-ai-message__body,
.calendar-day,
.notification-card,
.notification-empty,
.task-empty-state,
.messaging-row,
.messaging-channel-row,
.messaging-object-row,
.chat-bubble-body,
.chat-file-card,
.ai-native-message__body,
.ai-native-composer,
.ai-native-history-item,
.settings-field input,
.settings-field select,
.settings-field textarea,
.event-form input,
.event-form select,
.event-form textarea,
.page-action,
.task-action,
.request-actions button,
.nav-item,
.auth-nav button,
.auth-nav-link {
  border-radius: var(--radius-sm) !important;
}

.request-panel,
.promoted-task-panel,
.notification-card,
.dashboard-ai-widget,
.dashboard-hero-panel,
.dashboard-messages-widget,
.auth-flow,
.account-app,
.account-sidebar,
.dashboard-ai-home,
.dashboard-ai-home::before,
.landing-hero,
.pricing-setup-notice {
  background-image: none !important;
}

.brand-mark img,
.messaging-brand-button img,
.account-logo img {
  filter: none !important;
  opacity: 1 !important;
}

.auth-flow,
body:has(.auth-flow),
.account-app,
body:has(.account-app),
.clerk-settings-page,
body:has(.clerk-settings-page) {
  background: var(--bg) !important;
  color: var(--text) !important;
}

.auth-welcome-lockup h1,
.auth-start-copy h2,
.auth-start-copy p {
  color: var(--text) !important;
}

.auth-thread-logo {
  opacity: 0.78 !important;
}

.auth-thread-line {
  opacity: 0.34 !important;
}

/* Final Open Thread brand lock: keep late view-specific overrides light and boxy. */
:root,
:root[data-theme="light"] {
  color-scheme: light !important;
  --bg: #f8f6f3 !important;
  --panel: #ffffff !important;
  --panel-soft: #f2f6fb !important;
  --panel-muted: #e9eef7 !important;
  --border: #d8dce6 !important;
  --border-strong: #b9c2d1 !important;
  --text: #182235 !important;
  --text-soft: #4f5d72 !important;
  --text-muted: #7c8796 !important;
  --white: #182235 !important;
  --black: #ffffff !important;
  --accent: #7cc8ff !important;
  --accent-soft: rgba(124, 200, 255, 0.16) !important;
  --accent-border: rgba(124, 200, 255, 0.46) !important;
  --app-button: #182235 !important;
}

html,
body,
.app-shell,
.main-stage,
body[data-active-view="chat"] .app-shell,
body[data-active-view="chat"] .main-stage,
body[data-active-view="chat"] .chat-page.messaging-workspace,
body[data-active-view="chat"] .chat-page.messaging-workspace:has(.messaging-context-panel:not([hidden])) {
  background: var(--bg) !important;
  color: var(--text) !important;
}

body[data-active-view="chat"] .messaging-left-rail,
body[data-active-view="chat"] .messaging-directory,
body[data-active-view="chat"] .messaging-chat-shell,
body[data-active-view="chat"] .messaging-context-panel,
body[data-active-view="chat"] .chat-thread-panel.messaging-chat-shell,
.request-panel,
.status-panel,
.placeholder-panel,
.settings-page,
.calendar-page,
.dashboard-ai-home,
.dashboard-calendar-card,
.dashboard-up-next-card,
.ai-native-history,
.ai-native-panel {
  background: var(--panel) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

body[data-active-view="chat"] .messaging-directory::after,
.dashboard-ai-home::before {
  display: none !important;
}

body[data-active-view="chat"] .messaging-directory-search,
body[data-active-view="chat"] .messaging-conversation-row,
body[data-active-view="chat"] .messaging-object-row,
body[data-active-view="chat"] .messaging-channel-row,
body[data-active-view="chat"] .messaging-empty-state,
body[data-active-view="chat"] .chat-bubble-body,
body[data-active-view="chat"] .chat-composer.messaging-composer,
body[data-active-view="chat"] .composer-command-menu,
body[data-active-view="chat"] .composer-mention-menu,
body[data-active-view="chat"] .composer-add-menu,
body[data-active-view="chat"] .chat-emoji-panel,
.task-empty-state,
.calendar-day,
.dashboard-calendar-day,
.notification-empty,
.ai-native-message__body,
.ai-native-composer,
.settings-field input,
.settings-field select,
.settings-field textarea {
  background: var(--panel-soft) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

body[data-active-view="chat"] .messaging-directory-header,
body[data-active-view="chat"] .messaging-chat-header {
  background: transparent !important;
  border-color: var(--border) !important;
}

body[data-active-view="chat"] .messaging-directory-header h2,
body[data-active-view="chat"] .messaging-chat-header .chat-channel-title h2,
body[data-active-view="chat"] .chat-channel-title h2,
.section-head h1,
.section-head h2,
.calendar-header h2,
.placeholder-panel h2,
.settings-section-head h2,
.ai-native-panel__header h2,
.ai-native-history__header h2 {
  color: var(--text) !important;
}

body[data-active-view="chat"] .messaging-directory-header p,
body[data-active-view="chat"] .messaging-chat-header .chat-channel-title p,
body[data-active-view="chat"] .messaging-empty-state,
body[data-active-view="chat"] .chat-bubble-body p,
.calendar-weekdays span,
.placeholder-panel p,
.settings-section-head span,
.ai-native-empty {
  color: var(--text-soft) !important;
}

body[data-active-view="chat"] .chat-bubble--right .chat-bubble-body,
.ai-native-message--user .ai-native-message__body {
  background: var(--app-button) !important;
  border-color: var(--app-button) !important;
  color: #ffffff !important;
}

body[data-active-view="chat"] .chat-bubble--right .chat-bubble-body p,
.ai-native-message--user .ai-native-message__body p {
  color: #ffffff !important;
}

.nav-item,
.page-action,
.task-action,
.request-actions button,
body[data-active-view="chat"] .chat-ai-pill,
body[data-active-view="chat"] .messaging-directory-actions button,
body[data-active-view="chat"] .chat-icon-button,
.ai-native-action,
.ai-native-send {
  border-radius: 5px !important;
  box-shadow: none !important;
}

.request-panel,
.status-panel,
.placeholder-panel,
.settings-page,
.calendar-day,
.dashboard-calendar-day,
body[data-active-view="chat"] .messaging-left-rail,
body[data-active-view="chat"] .messaging-directory,
body[data-active-view="chat"] .messaging-chat-shell,
body[data-active-view="chat"] .messaging-context-panel,
.ai-native-history,
.ai-native-panel {
  border-radius: 7px !important;
}

.nav-item--new,
.nav-item--new:hover,
.nav-item--new.is-active,
.page-action,
.chat-composer-send,
.ai-native-send,
body[data-active-view="chat"] .chat-ai-pill,
body[data-active-view="chat"] .messaging-directory-actions button {
  background: var(--app-button) !important;
  border-color: var(--app-button) !important;
  color: #ffffff !important;
}

.bottom-control-rail,
.bottom-control-bar .nav-item,
.bottom-control-bar .nav-item:hover,
.bottom-control-bar .nav-item.is-active {
  background: rgba(255, 255, 255, 0.78) !important;
  border-color: var(--border) !important;
  color: #111111 !important;
}

.brand-mark img,
.messaging-brand-button img,
.nav-icon {
  filter: none !important;
  opacity: 1 !important;
}

/* Diff comment fixes */
body[data-active-view="chat"] #chatNewRailButton {
  background: var(--app-button) !important;
  border-color: var(--app-button) !important;
  color: #ffffff !important;
}

body[data-active-view="chat"] #chatNewRailButton span {
  background: var(--app-button) !important;
  border-color: var(--app-button) !important;
  color: #ffffff !important;
}

body[data-active-view="chat"] .messaging-rail-nav .messaging-rail-button.is-active::before {
  display: none !important;
}

body[data-active-view="chat"] .messaging-chat-header .chat-channel-title h2 {
  color: var(--text) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

body[data-active-view="chat"] .messaging-chat-header .chat-channel-title p {
  color: var(--text-soft) !important;
}

.ai-native-history__header {
  grid-template-columns: minmax(0, 1fr) !important;
}

.bottom-control-bar .new-menu {
  border-color: var(--border) !important;
  background: #ffffff !important;
  color: var(--text) !important;
}

.bottom-control-bar .new-menu::after {
  border-color: var(--border) !important;
  background: #ffffff !important;
}

.bottom-control-bar .new-menu-item {
  color: var(--text) !important;
}

.bottom-control-bar .new-menu-item:hover {
  background: var(--panel-soft) !important;
  color: var(--text) !important;
}

.integration-glyph,
.discord-tile-icon {
  filter: brightness(0) !important;
}

.page-action--icon {
  width: 42px !important;
  min-width: 42px !important;
  padding: 0 !important;
}

.page-action--icon i {
  font-size: 18px;
  line-height: 1;
}

.calendar-day-modal[hidden] {
  display: none;
}

.calendar-day-modal {
  position: fixed;
  inset: 0;
  z-index: 24;
}

.calendar-day-card {
  position: relative;
  width: min(780px, calc(100vw - 32px));
  max-height: calc(100vh - 72px);
  margin: 36px auto;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: var(--panel);
  color: var(--text);
  box-shadow: 0 24px 70px rgba(24, 34, 53, 0.18);
}

.calendar-day-card__head,
.calendar-day-card__actions {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.calendar-day-card__head p,
.calendar-day-card__head h2 {
  margin: 0;
}

.calendar-day-card__head p {
  margin-bottom: 4px;
  color: var(--text-soft);
  font-size: 13px;
  font-weight: 700;
}

.calendar-day-card__head h2 {
  color: var(--text);
  font-size: clamp(24px, 4vw, 34px);
  line-height: 1.05;
}

.calendar-day-agenda {
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 14px;
}

.calendar-day-all-day,
.calendar-day-hour {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 12px;
}

.calendar-day-all-day {
  padding: 12px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.calendar-day-all-day > span,
.calendar-day-hour time {
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 700;
}

.calendar-day-all-day em {
  color: var(--text-muted);
  font-size: 13px;
  font-style: normal;
}

.calendar-day-timeline {
  min-height: 0;
  overflow: auto;
}

.calendar-day-hour {
  min-height: 52px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}

.calendar-day-agenda-item {
  width: 100%;
  min-height: 34px;
  margin-bottom: 6px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--accent-border);
  border-radius: 5px;
  background: var(--accent-soft);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  text-align: left;
  cursor: pointer;
}

.calendar-day-agenda-item:hover,
.calendar-day-agenda-item:focus-visible {
  border-color: var(--accent);
  outline: none;
}

.calendar-day-agenda-item small {
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 800;
}

@media (max-width: 640px) {
  .calendar-day-card {
    width: calc(100vw - 18px);
    margin: 18px auto;
    padding: 16px;
  }

  .calendar-day-card__head {
    flex-direction: column;
  }

  .calendar-day-all-day,
  .calendar-day-hour {
    grid-template-columns: 64px minmax(0, 1fr);
  }
}

@media (min-width: 901px) {
  html:has(body[data-active-view="dashboard"]),
  body[data-active-view="dashboard"] {
    height: 100vh;
    overflow-y: hidden !important;
  }

  body[data-active-view="dashboard"] .app-shell,
  body[data-active-view="dashboard"] .main-stage {
    height: 100vh;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  body[data-active-view="dashboard"] .main-stage {
    padding-bottom: 28px !important;
  }

  body[data-active-view="dashboard"] .view-panel--board.is-active {
    height: 100%;
    min-height: 0 !important;
    display: flex;
    flex-direction: column;
  }

  body[data-active-view="dashboard"] .dashboard-header {
    flex: 0 0 auto;
  }

  body[data-active-view="dashboard"] .dashboard-overview,
  body[data-active-view="dashboard"] .dashboard-home-grid,
  body[data-active-view="dashboard"] .dashboard-ai-home,
  body[data-active-view="dashboard"] .dashboard-side-stack {
    min-height: 0 !important;
  }

  body[data-active-view="dashboard"] .dashboard-overview,
  body[data-active-view="dashboard"] .dashboard-home-grid,
  body[data-active-view="dashboard"] .dashboard-ai-home {
    height: 100% !important;
  }

  body[data-active-view="dashboard"] .dashboard-overview {
    flex: 1 1 auto;
  }

  body[data-active-view="dashboard"] .dashboard-calendar-card {
    min-height: clamp(280px, 52vh, 430px) !important;
  }
}
