/* -- New Medley Hub -- hub-dashboard.css -------------------------------------
   Dashboard-shell extensions to hub.css.
   Adds: hero-bar pill selects, user avatar pill + dropdown menu,
         communications rail items, and a few weight refinements.
   Drops in after hub.css. Uses only --nm-* tokens from hub.css.
   -------------------------------------------------------------------------- */

/* -- Weight refinements -----------------------------------------------------
   Dial back from 700/800 to 600/700 so the dashboard reads calmer when many
   bold elements compete for attention. */
.nm-stat-value      { font-weight: 700; }
.nm-page-header h1,
.nm-page-title      { font-weight: 600; }

/* -- Hero-bar pill controls (theme + language) -------------------------------
   Use as: <button class="nm-pill"><i class="ti ti-palette"></i> Continuo
             <i class="ti ti-chevron-down nm-pill-caret"></i></button>
   For a native <select>, give it .nm-pill-select instead. */
.nm-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.65rem;
  border: 1px solid var(--nm-border);
  border-radius: 99px;
  background: var(--nm-bg);
  color: var(--nm-text-muted);
  font-size: var(--nm-text-sm);
  font-weight: 500;
  font-family: inherit;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.nm-pill:hover {
  background: var(--nm-surface-2);
  color: var(--nm-text);
  border-color: var(--nm-text-light);
}
.nm-pill .ti { font-size: 1rem; }
.nm-pill .nm-pill-caret { font-size: 0.85rem; opacity: 0.7; }

.nm-pill-select {
  appearance: none;
  -webkit-appearance: none;
  padding: 0.3rem 1.8rem 0.3rem 0.65rem;
  border: 1px solid var(--nm-border);
  border-radius: 99px;
  background: var(--nm-bg);
  color: var(--nm-text-muted);
  font-size: var(--nm-text-sm);
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.55rem center;
}
.nm-pill-select:focus {
  outline: 2px solid var(--nm-accent);
  outline-offset: 2px;
}

/* -- Notification bell with badge -------------------------------------------
   <button class="nm-bell" aria-label="Notifications">
     <i class="ti ti-bell"></i>
     <span class="nm-bell-dot">3</span>
   </button> */
.nm-bell {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  color: var(--nm-text-muted);
  cursor: pointer;
  border: none;
  background: transparent;
  border-radius: var(--nm-radius);
  transition: background 0.15s, color 0.15s;
}
.nm-bell:hover { background: var(--nm-surface-2); color: var(--nm-text); }
.nm-bell .ti  { font-size: 1.15rem; }
.nm-bell-dot {
  position: absolute;
  top: 0.25rem;
  right: 0.25rem;
  min-width: 1rem;
  height: 1rem;
  padding: 0 0.25rem;
  background: var(--nm-error);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 600;
  border-radius: 99px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* -- User avatar pill (hero bar trigger) -------------------------------------
   <button class="nm-user-pill" aria-haspopup="menu" aria-expanded="false">
     <span class="nm-avatar nm-avatar-sm"><i class="ti ti-user"></i></span>
     <span class="nm-user-pill-name">Armando</span>
     <i class="ti ti-chevron-down nm-pill-caret"></i>
   </button> */
.nm-user-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.2rem 0.65rem 0.2rem 0.2rem;
  border: 1px solid var(--nm-border);
  border-radius: 99px;
  background: var(--nm-bg);
  color: var(--nm-text);
  font-family: inherit;
  font-size: var(--nm-text-sm);
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.nm-user-pill:hover {
  background: var(--nm-surface-2);
  border-color: var(--nm-text-light);
}
.nm-user-pill-name {
  max-width: 8rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* -- Avatar -----------------------------------------------------------------
   Reusable in hero bar, dropdown header, comms list. */
.nm-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: var(--nm-accent-light);
  color: var(--nm-accent);
  font-size: 0.75rem;
  font-weight: 600;
  overflow: hidden;
  flex-shrink: 0;
}
.nm-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nm-avatar .ti        { font-size: 1.1rem; }
.nm-avatar-sm         { width: 1.65rem; height: 1.65rem; font-size: 0.65rem; }
.nm-avatar-sm .ti     { font-size: 0.95rem; }
.nm-avatar-lg         { width: 2.5rem;  height: 2.5rem;  font-size: 0.85rem; }
.nm-avatar-lg .ti     { font-size: 1.35rem; }

/* -- Dropdown menu ----------------------------------------------------------
   Anchor on a positioned parent (.nm-menu-anchor).
   Toggle [hidden] on .nm-menu to show/hide. */
.nm-menu-anchor { position: relative; }

.nm-menu {
  position: absolute;
  top: calc(100% + 0.4rem);
  right: 0;
  min-width: 14rem;
  background: var(--nm-bg);
  border: 1px solid var(--nm-border);
  border-radius: var(--nm-radius-lg);
  box-shadow: var(--nm-shadow-md);
  padding: 0.4rem;
  z-index: 200;
}
.nm-menu[hidden] { display: none; }

.nm-menu-header {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.5rem 0.6rem 0.65rem;
  border-bottom: 1px solid var(--nm-border);
  margin-bottom: 0.35rem;
}
.nm-menu-header-name  { font-size: var(--nm-text-sm); font-weight: 600; color: var(--nm-text); }
.nm-menu-header-email { font-size: 0.75rem; color: var(--nm-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.nm-menu-item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  width: 100%;
  padding: 0.5rem 0.6rem;
  border: none;
  background: transparent;
  border-radius: var(--nm-radius);
  color: var(--nm-text);
  font-family: inherit;
  font-size: var(--nm-text-sm);
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.12s, color 0.12s;
}
.nm-menu-item:hover {
  background: var(--nm-accent-light);
  color: var(--nm-accent);
  text-decoration: none;
}
.nm-menu-item .ti        { font-size: 1rem; color: var(--nm-text-muted); }
.nm-menu-item:hover .ti  { color: var(--nm-accent); }

.nm-menu-sep { height: 1px; background: var(--nm-border); margin: 0.35rem 0; }

.nm-menu-item-danger        { color: var(--nm-error); }
.nm-menu-item-danger:hover  { background: var(--nm-error-bg); color: var(--nm-error); }
.nm-menu-item-danger:hover .ti { color: var(--nm-error); }

/* -- Three-column dashboard layout ------------------------------------------
   Override .nm-dash-page on pages that want the right rail.
   Use .nm-dash-page-3col on the wrapper instead of .nm-dash-page. */
.nm-dash-page-3col {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 280px;
  gap: 1.5rem;
  padding: 2rem 0;
}
.nm-dash-rail { min-width: 0; }

@media (max-width: 1100px) {
  .nm-dash-page-3col { grid-template-columns: 220px minmax(0, 1fr); }
  .nm-dash-rail { grid-column: 1 / -1; }
}
@media (max-width: 768px) {
  .nm-dash-page-3col { grid-template-columns: 1fr; }
}

/* -- Communications rail ----------------------------------------------------
   Reuses .nm-card / .nm-card-header from hub.css. */
.nm-comms-section-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--nm-text-muted);
  padding: 0.85rem 1.25rem 0.4rem;
}
.nm-comms-list { list-style: none; margin: 0; padding: 0; }
.nm-comms-item {
  display: block;
  padding: 0.65rem 1.25rem;
  border-top: 1px solid var(--nm-border);
  font-size: 0.8125rem;
  color: var(--nm-text);
  text-decoration: none;
  transition: background 0.12s;
}
.nm-comms-item:hover { background: var(--nm-surface); text-decoration: none; }
.nm-comms-head {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-weight: 600;
  margin-bottom: 0.15rem;
}
.nm-comms-head .ti    { font-size: 0.9rem; }
.nm-comms-body        { color: var(--nm-text-muted); line-height: 1.4; margin: 0; }
.nm-comms-time        { color: var(--nm-text-light); font-size: 0.7rem; margin-top: 0.25rem; display: block; }
.nm-comms-footer {
  border-top: 1px solid var(--nm-border);
  padding: 0.7rem 1.25rem;
  text-align: center;
  font-size: var(--nm-text-sm);
  color: var(--nm-accent);
}
.nm-comms-head-info    { color: var(--nm-info); }
.nm-comms-head-warning { color: var(--nm-warning); }
.nm-comms-head-muted   { color: var(--nm-text-muted); }

/* -- Activity feed ----------------------------------------------------------
   ul.nm-activity > li.nm-activity-item */
.nm-activity { list-style: none; margin: 0; padding: 0; }
.nm-activity-item {
  display: flex;
  gap: 0.65rem;
  padding: 0.7rem 1.5rem;
  border-top: 1px solid var(--nm-border);
  font-size: var(--nm-text-sm);
  align-items: flex-start;
}
.nm-activity-item:first-child { border-top: none; }
.nm-activity-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--nm-text-light);
  margin-top: 0.5rem;
  flex-shrink: 0;
}
.nm-activity-dot-success { background: var(--nm-success); }
.nm-activity-dot-danger  { background: var(--nm-error);   }
.nm-activity-dot-warning { background: var(--nm-warning); }
.nm-activity-dot-info    { background: var(--nm-info);    }
.nm-activity-time        { color: var(--nm-text-muted); }

/* -- Progress bar -----------------------------------------------------------
   Inline use inside .nm-table rows. */
.nm-progress {
  display: block;
  width: 100%;
  height: 0.35rem;
  background: var(--nm-surface-2);
  border-radius: 99px;
  overflow: hidden;
}
.nm-progress-bar {
  display: block;
  height: 100%;
  background: var(--nm-accent);
  border-radius: 99px;
}
.nm-progress-bar-success { background: var(--nm-success); }
.nm-progress-bar-warning { background: var(--nm-warning); }
.nm-progress-bar-danger  { background: var(--nm-error);   }
.nm-progress-bar-muted   { background: var(--nm-text-light); }

/* -- Small input variant for inline table editing --------------------------- */
.nm-input-sm {
  padding: 0.25rem 0.5rem;
  font-size: var(--nm-text-sm);
  width: auto;
  min-width: 0;
}

/* ── Authenticated two-frame shell ──────────────────────────────────────────
   body becomes a flex column at full viewport height.
   The header is always full-width at the top.
   nm-app-body splits the remaining space: nm-app-main (scrollable page) +
   nm-chat-frame (right or bottom panel, never overlapping the page). */

body.nm-authenticated {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}
body.nm-authenticated .nm-header {
  flex-shrink: 0;
  position: relative; /* disable sticky — header is always at top in this layout */
  z-index: 100;
  box-shadow: var(--nm-shadow);
}
.nm-app-body {
  flex: 1;
  display: flex;
  flex-direction: row;
  overflow: hidden;
  min-height: 0;
}
.nm-app-main {
  flex: 1;
  overflow-y: auto;
  min-width: 0;
}
/* override the min-height that assumed a normal-flow page */
body.nm-authenticated .nm-main { min-height: 0; }

/* ── Chat frame: right panel (default) ───────────────────────────────────── */
.nm-chat-frame {
  width: 380px;
  min-width: 280px;
  flex-shrink: 0;
  border-left: 1px solid var(--nm-border);
  background: var(--nm-bg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.nm-cf-hidden { display: none !important; }

/* ── Chat frame: bottom panel ────────────────────────────────────────────── */
.nm-app-body.nm-chat-bottom {
  flex-direction: column;
}
.nm-app-body.nm-chat-bottom .nm-chat-frame {
  width: 100%;
  height: 340px;
  min-width: 0;
  flex-shrink: 0;
  border-left: none;
  border-top: 2px solid var(--nm-border);
}
/* In bottom mode the input row goes horizontal */
.nm-app-body.nm-chat-bottom .nm-cf-input {
  flex-direction: row;
  align-items: flex-end;
  gap: 8px;
}
.nm-app-body.nm-chat-bottom .nm-cf-input textarea { flex: 1; }
.nm-app-body.nm-chat-bottom .nm-cf-send { flex-shrink: 0; }

/* ── Chat frame components ───────────────────────────────────────────────── */
.nm-cf-header {
  flex-shrink: 0;
  background: var(--nm-surface-2);
  border-bottom: 1px solid var(--nm-border);
  padding: 8px 10px 6px;
}
.nm-cf-header-top {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
}
.nm-cf-select {
  flex: 1;
  min-width: 0;
  max-width: 130px;
  font-size: 12px;
  padding: 3px 6px;
  border: 1px solid var(--nm-border);
  border-radius: 5px;
  background: var(--nm-bg);
  color: var(--nm-text);
  font-family: inherit;
}
.nm-cf-modes { display: flex; gap: 4px; flex-wrap: wrap; }
.nm-cf-mode {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  border: 1px solid var(--nm-border);
  cursor: pointer;
  background: transparent;
  color: var(--nm-text-muted);
  white-space: nowrap;
  font-family: inherit;
}
.nm-cf-mode.active { background: var(--nm-accent); border-color: transparent; color: #fff; }
.nm-cf-pos-btns {
  display: flex;
  gap: 0;
  background: var(--nm-bg);
  border: 1px solid var(--nm-border);
  border-radius: 8px;
  padding: 3px;
  flex-shrink: 0;
}
.nm-cf-pos-btn {
  background: none;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  color: var(--nm-text-muted);
  padding: 5px 10px;
  font-family: inherit;
  line-height: 1;
  font-size: 18px;
  transition: background .1s, color .1s;
}
.nm-cf-pos-btn:hover { background: var(--nm-accent-light); color: var(--nm-accent); }
.nm-cf-pos-btn.active { background: var(--nm-accent); color: #fff; }
.nm-cf-return-btn {
  background: none;
  border: 1px solid var(--nm-border);
  border-radius: 4px;
  cursor: pointer;
  color: var(--nm-text-muted);
  padding: 2px 5px;
  font-family: inherit;
  line-height: 1;
  font-size: 14px;
}
.nm-cf-return-btn:hover { background: var(--nm-accent-light); color: var(--nm-accent); }
.nm-cf-close {
  background: none; border: none; cursor: pointer;
  color: var(--nm-text-muted); font-size: 14px; padding: 2px 4px;
  line-height: 1; font-family: inherit; margin-left: auto;
}
.nm-cf-close:hover { color: var(--nm-error); }

.nm-cf-icon-btn {
  background: none; border: none; cursor: pointer;
  color: var(--nm-text-muted); font-size: 15px; padding: 2px 5px;
  line-height: 1; font-family: inherit; border-radius: 4px;
  display: flex; align-items: center;
}
.nm-cf-icon-btn:hover { background: var(--nm-accent-light); color: var(--nm-accent); }

/* ── Search modal ──────────────────────────────────────────────────────────── */
.nm-search-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.45);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 60px;
}
.nm-search-modal {
  background: var(--nm-surface); border: 1px solid var(--nm-border);
  border-radius: 10px; width: min(680px, 95vw);
  max-height: 80vh; display: flex; flex-direction: column;
  box-shadow: 0 8px 32px rgba(0,0,0,.25);
}
.nm-search-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; border-bottom: 1px solid var(--nm-border);
  font-weight: 600; font-size: 14px;
}
.nm-search-filters {
  padding: 12px 16px; display: flex; flex-direction: column; gap: 8px;
  border-bottom: 1px solid var(--nm-border);
}
.nm-search-input {
  width: 100%; padding: 7px 10px; border: 1px solid var(--nm-border);
  border-radius: 6px; background: var(--nm-bg); color: var(--nm-text);
  font-size: 13px; box-sizing: border-box;
}
.nm-search-input:focus { outline: none; border-color: var(--nm-accent); }
.nm-search-row { display: flex; gap: 8px; align-items: center; }
.nm-search-results {
  flex: 1; overflow-y: auto; padding: 8px 12px;
  display: flex; flex-direction: column; gap: 6px;
}
.nm-search-result {
  position: relative; border: 1px solid var(--nm-border); border-radius: 6px;
  padding: 8px 36px 8px 10px; background: var(--nm-bg); cursor: default;
}
.nm-search-result:hover { border-color: var(--nm-accent-light); }
.nm-search-meta {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 4px;
  font-size: 10px; color: var(--nm-text-muted);
}
.nm-search-type   { font-weight: 600; }
.nm-search-author { color: var(--nm-accent); }
.nm-search-body   { font-size: 12px; color: var(--nm-text); white-space: pre-wrap; word-break: break-word; }
.nm-search-copy {
  position: absolute; top: 6px; right: 6px;
  background: none; border: none; cursor: pointer;
  color: var(--nm-text-muted); font-size: 13px; padding: 2px 4px;
  border-radius: 4px;
}
.nm-search-copy:hover { background: var(--nm-accent-light); color: var(--nm-accent); }

.nm-cf-private-badge {
  flex-shrink: 0;
  padding: 3px 12px;
  font-size: 11px;
  background: var(--nm-error-bg);
  color: var(--nm-error);
  border-bottom: 1px solid var(--nm-border);
  text-align: center;
}
.nm-cf-context {
  flex-shrink: 0;
  padding: 3px 12px;
  font-size: 11px;
  color: var(--nm-text-muted);
  border-bottom: 1px solid var(--nm-border);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nm-cf-messages {
  flex: 1;
  overflow-y: auto;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: var(--nm-surface);
}
.nm-cf-msg { max-width: 88%; }
.nm-cf-msg.user    { align-self: flex-end; }
.nm-cf-msg.endpoint { align-self: flex-start; }
.nm-cf-bubble {
  padding: 7px 11px;
  border-radius: 10px;
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word;
  font-size: 13px;
}
.nm-cf-msg.user .nm-cf-bubble {
  background: var(--nm-accent);
  color: #fff;
  border-radius: 10px 10px 2px 10px;
}
.nm-cf-msg.endpoint .nm-cf-bubble {
  background: var(--nm-surface-2);
  color: var(--nm-text);
  border-radius: 10px 10px 10px 2px;
}
.nm-cf-meta { font-size: 10px; color: var(--nm-text-muted); margin-top: 2px; text-align: right; }
.nm-cf-msg.endpoint .nm-cf-meta { text-align: left; }
.nm-cf-empty { color: var(--nm-text-muted); font-size: 12px; text-align: center; margin-top: 16px; }

.nm-cf-toolbar {
  flex-shrink: 0;
  display: flex;
  gap: 4px;
  padding: 4px 12px;
  border-top: 1px solid var(--nm-border);
  background: var(--nm-surface-2);
}
.nm-cf-toolbar-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  padding: 3px 8px;
  border: 1px solid var(--nm-border);
  border-radius: 5px;
  background: var(--nm-bg);
  color: var(--nm-text-muted);
  cursor: pointer;
  font-family: inherit;
}
.nm-cf-toolbar-btn:hover { background: var(--nm-accent-light); color: var(--nm-accent); border-color: var(--nm-accent); }
.nm-cf-input {
  flex-shrink: 0;
  padding: 10px 12px;
  border-top: 1px solid var(--nm-border);
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: var(--nm-bg);
}
.nm-cf-input textarea {
  width: 100%;
  min-height: 4.5rem; /* 3 visible rows */
  max-height: 8rem;
  resize: vertical;
  background: var(--nm-bg);
  color: var(--nm-text);
  border: 1px solid var(--nm-border);
  border-radius: 7px;
  padding: 7px 10px;
  font-size: 13px;
  font-family: inherit;
  box-sizing: border-box;
}
.nm-cf-input textarea:focus { outline: none; border-color: var(--nm-accent); }
.nm-cf-send {
  align-self: flex-end;
  padding: 6px 18px;
  background: var(--nm-accent);
  color: #fff;
  border: none;
  border-radius: 7px;
  cursor: pointer;
  font-size: 13px;
  font-family: inherit;
}
.nm-cf-send:disabled { opacity: .4; cursor: not-allowed; }
.nm-cf-send:not(:disabled):hover { filter: brightness(1.1); }

/* ── Chat: send-button quiver on click ──────────────────────────────────── */
@keyframes nm-cf-quiver {
  0%   { transform: translateX(0) rotate(0deg); }
  18%  { transform: translateX(-4px) rotate(-2.5deg); }
  36%  { transform: translateX(4px) rotate(2deg); }
  54%  { transform: translateX(-3px) rotate(-1.2deg); }
  72%  { transform: translateX(2px) rotate(1deg); }
  88%  { transform: translateX(-1px) rotate(-0.4deg); }
  100% { transform: translateX(0) rotate(0deg); }
}
.nm-cf-send.nm-quiver { animation: nm-cf-quiver 0.38s ease-in-out; }

/* ── Chat: optimistic (pending) message ─────────────────────────────────── */
.nm-cf-msg.nm-pending { opacity: 0.5; }
.nm-cf-msg.nm-pending .nm-cf-meta::after { content: ' ⏳'; }

/* ── Chat: private session messages (both sides — fully isolated) ────────── */
.nm-cf-msg.user.nm-private .nm-cf-bubble {
  background: #6d28d9;
  color: #fff;
  border-radius: 10px 10px 2px 10px;
}
.nm-cf-msg.user.nm-private .nm-cf-meta { color: #a78bfa; }
.nm-cf-msg.endpoint.nm-private .nm-cf-bubble {
  background: #ede9fe;
  color: #3b0764;
  border-left: 3px solid #7c3aed;
  border-radius: 10px 10px 10px 2px;
}
.nm-cf-msg.endpoint.nm-private .nm-cf-meta { color: #7c3aed; }

/* ── Chat: direct session — user msg is private, endpoint reply is public ── */
.nm-cf-msg.user.nm-direct .nm-cf-bubble {
  background: #92400e;
  color: #fef3c7;
  border-radius: 10px 10px 2px 10px;
  font-style: italic;
}
.nm-cf-msg.user.nm-direct .nm-cf-meta { color: #d97706; }
.nm-cf-msg.endpoint.nm-direct .nm-cf-bubble {
  background: var(--nm-surface-2);
  color: var(--nm-text);
  border-left: 3px solid var(--nm-accent);
  border-radius: 10px 10px 10px 2px;
}

/* ── Chat: direct badge variant ─────────────────────────────────────────── */
.nm-cf-private-badge.nm-badge-direct {
  background: #fef3c7;
  color: #78350f;
  border-bottom-color: #fde68a;
}

/* ── Chat toggle button (floating, shown when panel is closed) ────────────── */
#nm-chat-toggle {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9000;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--nm-accent);
  border: none;
  cursor: pointer;
  box-shadow: var(--nm-shadow-md);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .15s;
}
#nm-chat-toggle:hover { transform: scale(1.1); }
#nm-chat-toggle svg { width: 26px; height: 26px; }

/* ── Popup-mode indicator (shown in the main page when chat is in a separate window) */
#nm-cf-popup-indicator {
  position: fixed;
  bottom: 80px;
  right: 20px;
  z-index: 8999;
  background: var(--nm-surface);
  border: 1px solid var(--nm-border);
  border-radius: 8px;
  padding: 6px 12px;
  font-size: 11px;
  color: var(--nm-text-muted);
  box-shadow: var(--nm-shadow-sm);
  display: none;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  transition: background .12s;
}
#nm-cf-popup-indicator:hover { background: var(--nm-accent-light); color: var(--nm-accent); }

/* ── Standalone popup page body ─────────────────────────────────────────── */
body.nm-chat-popup-body {
  margin: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--nm-bg);
}
body.nm-chat-popup-body .nm-chat-frame {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  border-radius: 0;
  border: none;
  border-left: none;
  width: 100%;
  position: static;
}

/* -- Endpoint Queue ---------------------------------------------------------*/

.eq-stats {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.eq-stat {
  flex: 1;
  min-width: 100px;
  background: var(--nm-surface);
  border: 1px solid var(--nm-border);
  border-radius: var(--nm-radius);
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.eq-stat-value {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--nm-text);
  line-height: 1;
}
.eq-stat-label {
  font-size: var(--nm-text-sm);
  color: var(--nm-text-muted);
}
.eq-stat-active  { border-left: 3px solid var(--nm-accent); }
.eq-stat-done    { border-left: 3px solid var(--nm-success, #22c55e); }
.eq-stat-blocked { border-left: 3px solid var(--nm-error); }

.eq-card {
  background: var(--nm-surface);
  border: 1px solid var(--nm-border);
  border-radius: var(--nm-radius);
  padding: 1rem 1.25rem;
  margin-bottom: 0.75rem;
  transition: border-color 0.15s;
}
.eq-card:hover { border-color: var(--nm-accent); }
.eq-card[data-status="complete"]     { opacity: 0.75; }
.eq-card[data-status="blocked"]      { border-left: 3px solid var(--nm-error); }
.eq-card[data-status="implementing"] { border-left: 3px solid var(--nm-accent); }
.eq-card[data-status="consulting"]   { border-left: 3px solid var(--nm-warning, #f59e0b); }

.eq-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
  gap: 0.5rem;
}
.eq-card-left, .eq-card-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.eq-badge {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 2px 7px;
  border-radius: 999px;
  background: var(--nm-surface-2, #2a2a3a);
  color: var(--nm-text-muted);
}
.eq-badge-queued       { background: #334155; color: #94a3b8; }
.eq-badge-consulting   { background: #78350f; color: #fcd34d; }
.eq-badge-implementing { background: #1e3a5f; color: #60a5fa; }
.eq-badge-complete     { background: #14532d; color: #86efac; }
.eq-badge-blocked      { background: #7f1d1d; color: #fca5a5; }
.eq-badge-failed       { background: #3b0764; color: #e879f9; }

.eq-pos {
  font-size: var(--nm-text-sm);
  color: var(--nm-text-muted);
  font-weight: 600;
}
.eq-project {
  font-size: var(--nm-text-sm);
  color: var(--nm-text-muted);
}
.eq-priority {
  font-size: 0.65rem;
  color: var(--nm-text-muted);
  border: 1px solid var(--nm-border);
  padding: 1px 5px;
  border-radius: 4px;
}
.eq-vis { color: var(--nm-text-muted); font-size: 0.8rem; }
.eq-vis-private { color: var(--nm-warning, #f59e0b); }

.eq-title {
  font-weight: 600;
  font-size: var(--nm-text-base);
  color: var(--nm-text);
  margin-bottom: 0.25rem;
}
.eq-body {
  font-size: var(--nm-text-sm);
  color: var(--nm-text-muted);
  margin-bottom: 0.75rem;
  line-height: 1.5;
}

.eq-card-footer {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.eq-meta {
  font-size: var(--nm-text-xs, 0.7rem);
  color: var(--nm-text-muted);
  display: flex;
  align-items: center;
  gap: 3px;
}
.eq-meta-done { color: var(--nm-success, #22c55e); }

.eq-report {
  margin-top: 0.75rem;
  padding: 0.75rem;
  background: var(--nm-bg);
  border-radius: var(--nm-radius-sm, 4px);
  border: 1px solid var(--nm-border);
}
.eq-report-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--nm-text-muted);
  margin-bottom: 0.35rem;
}
.eq-report-body {
  font-size: var(--nm-text-sm);
  color: var(--nm-text);
  white-space: pre-wrap;
  line-height: 1.5;
}

.eq-blocked-notice {
  margin-top: 0.5rem;
  font-size: var(--nm-text-sm);
  color: var(--nm-error);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
