:root {
  color-scheme: dark;
  --bg: #080a0f;
  --bg-2: #111821;
  --surface: rgba(18, 24, 32, 0.82);
  --surface-strong: #17212c;
  --surface-soft: rgba(255, 255, 255, 0.055);
  --ink: #f5f7fb;
  --muted: #99a6b5;
  --line: rgba(255, 255, 255, 0.12);
  --line-strong: rgba(255, 255, 255, 0.24);
  --accent: #35ead5;
  --accent-2: #7aa2ff;
  --accent-3: #ffd166;
  --accent-4: #ff6b4a;
  --ok: #3ee08f;
  --warn: #ffc857;
  --danger: #ff5d73;
  --shadow: 0 24px 80px rgba(0, 0, 0, 0.42);
  --radius: 8px;
}

* {
  box-sizing: border-box;
}

html {
  background: var(--bg);
}

body {
  margin: 0;
  min-height: 100vh;
  background:
    linear-gradient(120deg, rgba(53, 234, 213, 0.13), transparent 32%),
    linear-gradient(300deg, rgba(122, 162, 255, 0.12), transparent 34%),
    radial-gradient(circle at 82% 10%, rgba(255, 209, 102, 0.12), transparent 28%),
    var(--bg);
  color: var(--ink);
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: 0;
}

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

button {
  cursor: pointer;
}

.hidden {
  display: none !important;
}

.login-shell {
  position: relative;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}

.login-panel {
  width: min(440px, 100%);
  display: grid;
  gap: 18px;
  background: rgba(15, 20, 28, 0.84);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 30px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(22px);
}

.login-language {
  position: absolute;
  top: 18px;
  right: 18px;
}

.eyebrow {
  margin: 0 0 8px;
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: 0;
  font-size: 34px;
  line-height: 1.05;
}

h2 {
  margin-bottom: 8px;
  font-size: 26px;
  line-height: 1.15;
}

h3 {
  margin-bottom: 12px;
  font-size: 15px;
  line-height: 1.2;
}

label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

input,
textarea,
select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--ink);
  padding: 10px 12px;
  outline: none;
}

select option {
  color: #10151c;
}

textarea {
  min-height: 98px;
  resize: vertical;
}

input::placeholder,
textarea::placeholder {
  color: #728094;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(53, 234, 213, 0.14);
}

button {
  border: 0;
  border-radius: 7px;
  padding: 10px 14px;
  background: linear-gradient(135deg, var(--accent), #8be9ff);
  color: #061014;
  cursor: pointer;
  font-weight: 900;
}

button:hover {
  filter: brightness(1.06);
}

a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.ghost-btn,
.icon-btn,
.tab,
.lang-btn {
  background: rgba(255, 255, 255, 0.06);
  color: var(--ink);
  border: 1px solid var(--line);
}

.danger-btn {
  background: linear-gradient(135deg, var(--danger), var(--accent-4));
  color: white;
}

.icon-btn {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  padding: 0;
  font-size: 20px;
  text-decoration: none;
}

.language-switch {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 3px;
  max-width: min(360px, calc(100vw - 32px));
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px;
  background: rgba(255, 255, 255, 0.045);
}

.lang-btn {
  min-width: 0;
  height: 28px;
  padding: 0 8px;
  border: 0;
  border-radius: 999px;
  color: var(--muted);
  font-size: 12px;
}

.lang-btn.active {
  background: var(--accent);
  color: #061014;
}

.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.app-shell::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  z-index: 80;
  width: 100%;
  height: 2px;
  background: var(--accent);
  opacity: 0;
  pointer-events: none;
  transform: scaleX(0);
  transform-origin: left;
}

.app-shell.is-tab-refreshing::before {
  opacity: 0.92;
  animation: tab-refresh-progress 1.1s ease-in-out infinite;
}

@keyframes tab-refresh-progress {
  0% {
    transform: scaleX(0.08);
  }
  55% {
    transform: scaleX(0.72);
  }
  100% {
    transform: scaleX(0.98);
    opacity: 0.34;
  }
}

.app-topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: auto minmax(360px, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  background: rgba(8, 10, 15, 0.78);
  backdrop-filter: blur(22px);
}

.brand-row,
.brand-row > div,
.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.brand-mark {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #061014;
  font-weight: 1000;
}

.tabs {
  display: flex;
  justify-content: center;
  gap: 8px;
  min-width: 0;
}

.tab {
  min-width: 78px;
  padding: 9px 12px;
  color: var(--muted);
}

.tab.active {
  background: rgba(255, 255, 255, 0.12);
  color: var(--ink);
  border-color: var(--accent);
}

#userEmail {
  max-width: 210px;
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workspace {
  min-width: 0;
}

.view {
  display: none;
  min-width: 0;
  padding: 22px;
}

.view.active {
  display: block;
}

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

.toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

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

.board-panel,
.panel {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset;
}

.board-panel {
  min-width: 0;
  padding: 16px;
}

.panel {
  padding: 16px;
}

.panel.highlight {
  border-color: rgba(53, 234, 213, 0.34);
  background: rgba(53, 234, 213, 0.07);
}

.metric-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.metric-strip > div,
.metric-mini {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.045);
  padding: 12px;
}

.metric-strip span,
.metric-mini span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.metric-strip strong,
.metric-mini strong {
  font-size: 23px;
}

.board-filters {
  display: grid;
  grid-template-columns: minmax(180px, 1.4fr) minmax(150px, 0.8fr) minmax(150px, 0.8fr) auto;
  gap: 10px;
  align-items: end;
  margin-bottom: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  padding: 12px;
}

.lens-strip {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding-bottom: 2px;
}

.lens-strip > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 1000;
  text-transform: uppercase;
}

.network-lens-btn {
  padding: 7px 10px;
  background: rgba(255, 255, 255, 0.055);
  color: var(--muted);
  border: 1px solid var(--line);
}

.network-lens-btn.active {
  background: rgba(53, 234, 213, 0.13);
  color: var(--ink);
  border-color: var(--accent);
}

.filter-summary {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.network-board {
  position: relative;
  min-height: 540px;
  max-height: min(72vh, 760px);
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(rgba(255, 255, 255, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.045) 1px, transparent 1px),
    radial-gradient(circle at 50% 50%, rgba(53, 234, 213, 0.12), transparent 36%),
    rgba(0, 0, 0, 0.18);
  background-size:
    34px 34px,
    34px 34px,
    auto,
    auto;
  cursor: grab;
  overscroll-behavior: contain;
  user-select: none;
}

.network-board.is-panning {
  cursor: grabbing;
}

.network-canvas {
  position: relative;
  min-width: 100%;
  min-height: 540px;
}

.network-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.network-edge {
  fill: none;
  stroke-width: 2.1;
  opacity: 0.64;
}

.network-edge.explicit {
  stroke: var(--accent);
}

.network-edge.broad {
  stroke: var(--accent-3);
  stroke-dasharray: 8 8;
}

.network-edge.selected {
  opacity: 1;
  stroke-width: 3;
}

.network-svg marker path {
  fill: var(--accent);
}

.network-hub {
  position: absolute;
  left: 50%;
  top: 50%;
  display: grid;
  place-items: center;
  width: 76px;
  height: 76px;
  border: 1px solid rgba(255, 209, 102, 0.55);
  border-radius: var(--radius);
  background: rgba(255, 209, 102, 0.1);
  color: var(--accent-3);
  font-size: 10px;
  font-weight: 1000;
  text-align: center;
  transform: translate(-50%, -50%);
}

.network-node {
  position: absolute;
  z-index: 3;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) 8px;
  gap: 7px;
  align-items: center;
  width: 142px;
  min-height: 44px;
  padding: 7px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  background: rgba(17, 24, 33, 0.92);
  color: var(--ink);
  text-align: left;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
  transform: translate(-50%, -50%);
}

.network-node:hover,
.network-node:focus-visible {
  z-index: 5;
  border-color: var(--accent);
  transform: translate(-50%, -50%) scale(1.04);
}

.network-node.selected {
  border-color: var(--accent);
  box-shadow:
    0 0 0 3px rgba(53, 234, 213, 0.16),
    0 12px 32px rgba(0, 0, 0, 0.22);
}

.node-mark {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface);
  color: #061014;
  font-size: 10px;
  font-weight: 1000;
}

.node-mark.ok {
  border-color: color-mix(in srgb, var(--ok) 50%, var(--line));
  background: color-mix(in srgb, var(--ok) 72%, var(--surface));
}

.node-mark.warn {
  border-color: color-mix(in srgb, var(--warn) 50%, var(--line));
  background: color-mix(in srgb, var(--warn) 72%, var(--surface));
}

.node-mark.danger {
  border-color: color-mix(in srgb, var(--danger) 50%, var(--line));
  background: color-mix(in srgb, var(--danger) 72%, var(--surface));
}

.node-mark.large {
  width: 54px;
  height: 54px;
  font-size: 16px;
}

.node-main {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.node-main strong,
.inspector-head strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.node-main span {
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.network-node .node-main strong {
  font-size: 11px;
  line-height: 1.15;
}

.node-status-dot {
  width: 8px;
  height: 8px;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--muted);
}

.node-status-dot.ok {
  border-color: rgba(62, 224, 143, 0.42);
  background: var(--ok);
}

.node-status-dot.warn {
  border-color: rgba(255, 200, 87, 0.42);
  background: var(--warn);
}

.node-status-dot.danger {
  border-color: rgba(255, 93, 115, 0.42);
  background: var(--danger);
}

.board-empty {
  display: grid;
  min-height: 610px;
  place-items: center;
  color: var(--muted);
  font-weight: 900;
}

.board-empty.compact {
  min-height: 96px;
  border: 1px dashed var(--line);
}

.board-agent-map {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.board-agent-map-grid {
  display: grid;
  gap: 10px;
}

.board-agent-group {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--control-bg) 82%, var(--bg));
  padding: 10px;
}

.board-agent-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}

.board-agent-group-head strong,
.board-agent-group-head span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.board-agent-group-head span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.board-agent-chip-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 7px;
}

.board-agent-chip {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  padding: 8px;
  text-align: left;
}

.board-agent-chip:hover,
.board-agent-chip:focus-visible,
.board-agent-chip.selected {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.board-agent-chip.ok {
  border-left: 3px solid var(--ok);
}

.board-agent-chip.warn {
  border-left: 3px solid var(--warn);
}

.board-agent-chip.danger {
  border-left: 3px solid var(--danger);
}

.board-agent-chip .node-mark {
  width: 30px;
  height: 30px;
}

.board-agent-chip-main,
.board-agent-chip-tags {
  min-width: 0;
}

.board-agent-chip-main {
  display: grid;
  gap: 2px;
}

.board-agent-chip-main strong,
.board-agent-chip-main small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.board-agent-chip-main small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.board-agent-chip-tags {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.board-agent-chip-tags em {
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--muted);
  padding: 2px 5px;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
}

.board-details-drawer {
  margin-top: 14px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.board-details-drawer summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  cursor: pointer;
  list-style: none;
}

.board-details-drawer summary::-webkit-details-marker {
  display: none;
}

.board-details-drawer summary::after {
  content: "+";
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--accent);
  font-weight: 1000;
}

.board-details-drawer[open] summary::after {
  content: "-";
}

.board-details-drawer summary span {
  color: var(--ink);
  font-weight: 1000;
}

.board-details-drawer summary em {
  grid-column: 1;
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
}

.board-details-grid {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.board-details-grid > * {
  margin-top: 0;
}

.command-summary,
.ops-command-center,
.team-matrix,
.task-status-board,
.task-inbox,
.readiness-panel,
.action-panel,
.handoff-brief,
.priority-panel {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.command-summary {
  margin-bottom: 14px;
}

.ops-command-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

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

.readiness-grid,
.chat-context-grid,
.settings-overview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.summary-grid > div {
  display: grid;
  gap: 5px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  padding: 11px;
}

.readiness-grid > div,
.chat-context-grid > div {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid var(--line);
  background: var(--panel-alt);
  padding: 10px;
}

.readiness-grid span,
.chat-context-grid span,
.settings-overview-grid span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.readiness-grid strong,
.chat-context-grid strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.action-list,
.handoff-candidate-grid,
.priority-list {
  display: grid;
  gap: 8px;
}

.action-item,
.handoff-candidate,
.priority-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--panel-alt);
  padding: 10px;
  text-align: left;
}

.action-item.danger {
  border-color: color-mix(in srgb, var(--danger) 48%, var(--line));
}

.action-item.warn {
  border-color: color-mix(in srgb, var(--warn) 48%, var(--line));
}

.handoff-candidate {
  grid-template-columns: 38px minmax(0, 1fr) auto auto;
  width: 100%;
  color: var(--ink);
}

.handoff-candidate.ok {
  border-color: color-mix(in srgb, var(--ok) 36%, var(--line));
}

.handoff-candidate.warn {
  border-color: color-mix(in srgb, var(--warn) 44%, var(--line));
}

.handoff-candidate span,
.handoff-candidate strong,
.handoff-candidate small,
.handoff-candidate em {
  min-width: 0;
  overflow: hidden;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.handoff-candidate em,
.handoff-candidate i {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.priority-item {
  grid-template-columns: minmax(0, 1fr) auto auto;
  width: 100%;
  color: var(--ink);
}

.priority-item span,
.priority-item strong,
.priority-item small,
.action-item span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.summary-grid span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.summary-grid strong {
  overflow: hidden;
  font-size: 18px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.compare-panel {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  padding: 12px;
}

.compare-row {
  display: grid;
  grid-template-columns: minmax(90px, 0.75fr) minmax(72px, 0.45fr) minmax(95px, 0.7fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
}

.compare-row span,
.compare-row small {
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.compare-row strong {
  overflow: hidden;
  color: var(--accent);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.matrix-head {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  justify-content: space-between;
  gap: 10px;
}

.matrix-head h3,
.matrix-head p {
  margin-bottom: 0;
}

.matrix-table {
  display: grid;
  gap: 6px;
}

.matrix-row {
  display: grid;
  grid-template-columns:
    minmax(130px, 1.1fr) minmax(150px, 1.15fr) minmax(90px, 0.75fr)
    minmax(105px, 0.75fr) minmax(70px, 0.48fr) minmax(76px, 0.52fr);
  gap: 10px;
  align-items: center;
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  color: var(--ink);
  padding: 9px 11px;
  text-align: left;
}

.matrix-row.active {
  border-color: var(--accent);
  background: rgba(53, 234, 213, 0.09);
}

.matrix-header {
  min-height: 32px;
  background: transparent;
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  letter-spacing: 0;
  text-transform: uppercase;
}

.matrix-row span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.matrix-row small {
  display: block;
  overflow: hidden;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  text-overflow: ellipsis;
}

.matrix-row em {
  font-style: normal;
  font-weight: 1000;
}

.matrix-row em.ok {
  color: var(--ok);
}

.matrix-row em.warn {
  color: var(--warn);
}

.matrix-row em.danger {
  color: var(--danger);
}

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

.task-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.task-search button {
  height: 40px;
}

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

.status-column {
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 154px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  padding: 10px;
}

.status-column-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.status-task {
  display: grid;
  gap: 3px;
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.045);
  color: var(--ink);
  padding: 9px;
  text-align: left;
}

.status-task span,
.status-task small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.status-task small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.status-task em {
  width: fit-content;
  color: var(--accent-3);
  font-size: 11px;
  font-style: normal;
  font-weight: 1000;
}

.task-item {
  display: grid;
  grid-template-columns: minmax(180px, 0.95fr) minmax(220px, 1.4fr) auto;
  gap: 12px;
  align-items: center;
  width: 100%;
  min-height: 58px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  color: var(--ink);
  padding: 10px 12px;
  text-align: left;
}

.task-item:hover {
  border-color: var(--accent-2);
}

.task-item span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.task-item small {
  display: block;
  overflow: hidden;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  text-overflow: ellipsis;
}

.task-item em {
  color: var(--accent-3);
  font-size: 12px;
  font-style: normal;
  font-weight: 1000;
}

.task-meta-stack {
  display: grid;
  gap: 3px;
  justify-items: end;
}

.task-age {
  width: fit-content;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px 7px;
}

.task-age.ok {
  border-color: rgba(62, 224, 143, 0.42);
  color: var(--ok);
}

.task-age.warn {
  border-color: rgba(255, 200, 87, 0.42);
  color: var(--warn);
}

.task-age.danger {
  border-color: rgba(255, 93, 115, 0.42);
  color: var(--danger);
}

.inspector-panel {
  position: sticky;
  top: 92px;
  display: grid;
  gap: 14px;
}

.inspector-head {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.inspector-block {
  display: grid;
  gap: 6px;
}

.compact-metrics {
  gap: 10px;
}

.dispatch-form,
.risk-panel,
.activity-panel {
  display: grid;
  gap: 10px;
}

.dispatch-form textarea {
  min-height: 88px;
}

.risk-panel,
.activity-panel {
  border-top: 1px solid var(--line);
  padding-top: 14px;
}

.risk-item {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px 11px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.risk-item.warn {
  border-color: rgba(255, 200, 87, 0.38);
  color: var(--warn);
  background: rgba(255, 200, 87, 0.07);
}

.risk-item.danger {
  border-color: rgba(255, 93, 115, 0.38);
  color: var(--danger);
  background: rgba(255, 93, 115, 0.07);
}

.activity-item {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  padding: 10px 11px;
}

.activity-item span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.activity-item p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  overflow-wrap: anywhere;
}

.grid-2,
.grid-3,
.provider-grid {
  display: grid;
  gap: 14px;
}

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

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

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

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

.template-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  padding: 12px;
}

.launch-checklist,
.prompt-lint {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.checklist-grid,
.lint-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 8px;
}

.check-item,
.lint-item {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  padding: 8px 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
}

.check-item b,
.lint-item b {
  display: grid;
  flex: 0 0 auto;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 10px;
}

.check-item.ok,
.lint-item.ok {
  border-color: rgba(62, 224, 143, 0.36);
  color: var(--ok);
}

.check-item.ok b,
.lint-item.ok b {
  background: rgba(62, 224, 143, 0.16);
  color: var(--ok);
}

.check-item.warn,
.lint-item.warn {
  border-color: rgba(255, 200, 87, 0.36);
  color: var(--warn);
}

.check-item.warn b,
.lint-item.warn b {
  background: rgba(255, 200, 87, 0.15);
  color: var(--warn);
}

.form-actions {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 6px;
}

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

.checkbox-row,
.radio-row {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
}

.checkbox-row input,
.radio-row input {
  width: auto;
}

.muted {
  color: var(--muted);
}

.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.pill {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.055);
  padding: 4px 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
}

.pill.ok {
  border-color: rgba(62, 224, 143, 0.42);
  color: var(--ok);
}

.pill.warn {
  border-color: rgba(255, 200, 87, 0.42);
  color: var(--warn);
}

.pill.danger {
  border-color: rgba(255, 93, 115, 0.42);
  color: var(--danger);
}

.chat-layout {
  height: calc(100vh - 120px);
  min-height: 560px;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr) 320px;
  gap: 14px;
}

.conversation-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
  margin-bottom: 12px;
}

.conversation-search button {
  height: 40px;
}

.conversation-list,
.message-list,
.log-list {
  overflow: auto;
}

.conversation-list {
  display: grid;
  align-content: start;
  gap: 8px;
}

.chat-menu-stack {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 12px;
  min-height: 0;
}

.chat-menu-stack.direct-only {
  grid-template-rows: minmax(0, 1fr);
}

.chat-menu-section {
  display: grid;
  gap: 8px;
  min-height: 0;
}

.chat-menu-stack.direct-only .chat-agent-list {
  min-height: 0;
  margin-bottom: 0;
  overflow: auto;
  padding-right: 2px;
}

.chat-menu-stack.direct-only .chat-menu-section {
  grid-template-rows: auto minmax(0, 1fr);
}

.chat-menu-section.threads {
  overflow: hidden;
}

.chat-thread-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.chat-thread-filter-btn {
  min-height: 30px;
  border-color: var(--line);
  background: var(--surface);
  color: var(--ink);
  font-size: 11px;
  font-weight: 950;
}

.chat-thread-filter-btn.active {
  border-color: var(--accent-line);
  background: var(--active-fill);
  color: var(--accent-2);
}

.chat-menu-title {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.chat-menu-title small {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 2px 6px;
}

.conversation-item {
  text-align: left;
  background: rgba(255, 255, 255, 0.045);
  color: var(--ink);
  border: 1px solid var(--line);
}

.conversation-item strong,
.conversation-item span {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.conversation-item.active {
  border-color: var(--accent-2);
  background: rgba(122, 162, 255, 0.1);
}

.chat-panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  min-height: 0;
}

.message-list {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 12px;
  background: rgba(0, 0, 0, 0.14);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.chat-empty-state {
  align-self: center;
  justify-self: center;
  display: grid;
  justify-items: center;
  gap: 12px;
  max-width: 520px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 84%, var(--accent));
  padding: 22px;
  text-align: center;
}

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

.chat-empty-state h3 {
  color: var(--ink);
  font-size: 18px;
}

.chat-empty-state p {
  color: var(--muted);
  line-height: 1.45;
}

.message {
  max-width: min(780px, 88%);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px 12px;
  background: var(--surface-strong);
}

.message.user {
  justify-self: end;
  border-color: rgba(53, 234, 213, 0.42);
}

.message.agent {
  justify-self: start;
  border-color: rgba(122, 162, 255, 0.42);
}

.message small {
  display: block;
  margin-bottom: 5px;
  color: var(--muted);
  font-weight: 900;
}

.message p {
  margin: 0;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.attachment-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.attachment-card {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  gap: 9px;
  align-items: center;
  min-height: 58px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  color: var(--ink);
  padding: 8px;
  text-decoration: none;
}

.attachment-card.download-link {
  cursor: pointer;
}

.attachment-card.download-link:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 9%, var(--surface));
  transform: translateY(-1px);
}

.attachment-card.blocked {
  border-color: color-mix(in srgb, var(--danger) 42%, var(--line));
  background: color-mix(in srgb, var(--danger) 7%, var(--surface));
  cursor: not-allowed;
}

.attachment-card.blocked b,
.attachment-card.blocked em {
  border-color: color-mix(in srgb, var(--danger) 45%, var(--line));
  background: color-mix(in srgb, var(--danger) 12%, var(--surface));
  color: var(--danger);
}

.attachment-card b {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 7px;
  background: rgba(53, 234, 213, 0.13);
  color: var(--accent);
  font-size: 11px;
  font-weight: 1000;
  overflow: hidden;
  padding: 0 3px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.attachment-card img {
  width: 42px;
  height: 42px;
  border-radius: 7px;
  object-fit: cover;
  background: rgba(255, 255, 255, 0.08);
}

.attachment-card span,
.attachment-card strong,
.attachment-card small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.attachment-card span {
  display: grid;
  gap: 3px;
}

.attachment-card small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.attachment-card em,
.attachment-download {
  border: 1px solid var(--accent-line);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  color: var(--accent);
  padding: 5px 7px;
  font-size: 10px;
  font-style: normal;
  font-weight: 1000;
  text-decoration: none;
  text-transform: uppercase;
}

.composer {
  display: grid;
  gap: 10px;
}

.composer.locked {
  border-color: var(--line-strong);
  background: color-mix(in srgb, var(--surface) 78%, var(--surface-soft));
}

.composer.is-busy {
  opacity: 0.72;
}

.composer-lock {
  display: grid;
  gap: 4px;
  border: 1px solid var(--warn);
  background: color-mix(in srgb, var(--warn) 10%, var(--surface));
  color: var(--ink);
  padding: 10px;
}

.composer-lock.compact {
  margin-bottom: 8px;
}

.composer-lock strong {
  font-size: 12px;
  text-transform: uppercase;
}

.composer-lock span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.composer-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: end;
}

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

.attach-btn,
.schedule-toggle-btn {
  display: inline-grid;
  place-items: center;
  min-width: 40px;
  min-height: 40px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  cursor: pointer;
  font-weight: 1000;
}

.attach-btn {
  grid-template-columns: auto auto;
  gap: 5px;
  padding: 0 10px;
  text-transform: uppercase;
}

.attach-btn small {
  color: var(--muted);
  font-size: 10px;
  font-weight: 1000;
}

.attach-btn:hover,
.schedule-toggle-btn:hover {
  border-color: var(--accent);
  background: var(--hover-fill);
}

button:disabled,
textarea:disabled,
input:disabled,
select:disabled,
.attach-btn.disabled {
  cursor: not-allowed;
  opacity: 0.52;
}

.composer-hint {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.log-row,
.model-row,
.usage-row,
.provider-head {
  display: grid;
  gap: 6px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}

.provider-head {
  padding-top: 0;
}

.log-row:last-child,
.model-row:last-child,
.usage-row:last-child,
.provider-head:last-child {
  border-bottom: 0;
}

.log-meta,
.usage-meta {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.log-filters {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(140px, 0.45fr) auto;
  gap: 10px;
  align-items: end;
  margin-bottom: 14px;
}

.handoff-trail {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.handoff-rows {
  display: grid;
  gap: 8px;
}

.handoff-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.35fr) minmax(180px, 1fr) minmax(150px, 0.45fr);
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  padding: 10px;
}

.handoff-row.warning {
  border-color: rgba(255, 200, 87, 0.36);
}

.handoff-row.error {
  border-color: rgba(255, 93, 115, 0.36);
}

.handoff-row span,
.handoff-row small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.handoff-row small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.metric {
  display: grid;
  gap: 4px;
}

.forecast-panel,
.model-ops {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.catalog-filters {
  display: grid;
  grid-template-columns: minmax(190px, 1.4fr) minmax(150px, 0.8fr) minmax(150px, 0.8fr);
  gap: 10px;
  align-items: end;
  margin: 14px 0;
}

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

.forecast-grid > div {
  display: grid;
  gap: 5px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  padding: 11px;
}

.forecast-grid span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.forecast-grid strong {
  overflow: hidden;
  font-size: 18px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.compact-strip {
  margin-bottom: 0;
}

.metric strong {
  font-size: 28px;
}

.bar {
  height: 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.09);
  overflow: hidden;
}

.bar span {
  display: block;
  height: 100%;
  min-width: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-3));
}

.toast {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 50;
  max-width: 380px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #ecfbff;
  color: #08151a;
  box-shadow: var(--shadow);
  font-weight: 800;
}

.error {
  min-height: 20px;
  margin: 0;
  color: var(--danger);
  font-size: 13px;
  font-weight: 800;
}

@media (max-width: 1120px) {
  .app-topbar {
    grid-template-columns: 1fr;
  }

  .tabs {
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 2px;
  }

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

  .overview-shell {
    grid-template-columns: 1fr;
  }

  .inspector-panel {
    position: static;
  }
}

@media (max-width: 820px) {
  .view {
    padding: 14px;
  }

  .metric-strip,
  .board-filters,
  .chat-layout,
  .chat-context-grid,
  .compare-row,
  .matrix-row,
  .summary-grid,
  .readiness-grid,
  .settings-overview-grid,
  .status-columns,
  .task-search,
  .task-item,
  .forecast-grid,
  .catalog-filters,
  .log-filters,
  .handoff-row,
  .grid-2,
  .grid-3 {
    grid-template-columns: 1fr;
  }

  .chat-layout {
    height: auto;
  }

  .network-board {
    min-height: 520px;
  }

  .network-node {
    width: 136px;
  }
}

@media (max-width: 560px) {
  .header-actions,
  .toolbar,
  .composer-row {
    align-items: stretch;
  }

  .header-actions,
  .composer-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  .provider-grid,
  .template-row,
  .conversation-search,
  .checkbox-grid {
    grid-template-columns: 1fr;
  }

  .tab {
    min-width: 96px;
  }
}

/* Clean coder redesign: square surfaces, orange accent, dark/light themes. */
:root {
  color-scheme: dark;
  --bg: #151413;
  --bg-2: #191715;
  --surface: #1d1a17;
  --surface-strong: #221f1b;
  --surface-soft: #28241f;
  --control-bg: #181614;
  --panel-alt: #211e1a;
  --ink: #ded8cf;
  --muted: #9b9288;
  --line: #36302a;
  --line-strong: #4d443a;
  --grid-line: rgba(229, 131, 58, 0.045);
  --accent: #e5833a;
  --accent-2: #f09a4c;
  --accent-3: #d1a153;
  --accent-4: #ca6c2d;
  --ok: #79c796;
  --warn: #d6a04f;
  --danger: #dc7379;
  --shadow: none;
  --radius: 2px;
  --button-ink: #22150e;
  --topbar-bg: rgba(21, 20, 19, 0.97);
  --toast-bg: #f0dcc7;
  --toast-ink: #24170f;
}

:root[data-theme="light"] {
  color-scheme: light;
  --bg: #f3f2ef;
  --bg-2: #ece9e3;
  --surface: #fffefd;
  --surface-strong: #f8f6f2;
  --surface-soft: #eeebe5;
  --control-bg: #ffffff;
  --panel-alt: #f7f4ee;
  --ink: #1d1b18;
  --muted: #70695f;
  --line: #d4cec4;
  --line-strong: #aca294;
  --grid-line: rgba(181, 91, 24, 0.075);
  --accent: #d7661e;
  --accent-2: #ef8a37;
  --accent-3: #a97625;
  --accent-4: #bb581b;
  --ok: #168447;
  --warn: #b45309;
  --danger: #dc2626;
  --button-ink: #fffefd;
  --topbar-bg: rgba(243, 242, 239, 0.96);
  --toast-bg: #1c1915;
  --toast-ink: #fffaf2;
}

:root[data-theme="dusk"] {
  color-scheme: dark;
  --bg: #24211f;
  --bg-2: #2a2622;
  --surface: #302b26;
  --surface-strong: #383129;
  --surface-soft: #433a31;
  --control-bg: #292520;
  --panel-alt: #373027;
  --ink: #eee5da;
  --muted: #b8ab9c;
  --line: #5a4d41;
  --line-strong: #726151;
  --grid-line: rgba(229, 131, 58, 0.06);
  --accent: #ec8d42;
  --accent-2: #f2a35c;
  --accent-3: #d4ad66;
  --accent-4: #cf7431;
  --ok: #8fd6a8;
  --warn: #e1af62;
  --danger: #e4868b;
  --shadow: none;
  --button-ink: #23160f;
  --topbar-bg: rgba(36, 33, 31, 0.96);
  --toast-bg: #f1dec9;
  --toast-ink: #24170f;
}

html {
  background: var(--bg);
}

body {
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    var(--bg);
  background-size: 28px 28px;
  font-family:
    ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

h1,
h2,
h3,
strong,
button,
label {
  letter-spacing: 0;
}

.login-panel,
.board-panel,
.panel,
.metric-strip > div,
.metric-mini,
.board-filters,
.network-board,
.network-node,
.summary-grid > div,
.compare-panel,
.matrix-row,
.status-column,
.status-task,
.task-item,
.risk-item,
.activity-item,
.template-row,
.check-item,
.lint-item,
.conversation-item,
.message-list,
.message,
.attachment-card,
.handoff-row,
.forecast-grid > div {
  background: var(--surface);
  border-color: var(--line);
  border-radius: var(--radius);
  box-shadow: none;
  backdrop-filter: none;
}

.panel.highlight {
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
  border-color: var(--accent);
}

.app-topbar {
  background: var(--topbar-bg);
  backdrop-filter: none;
}

input,
textarea,
select {
  border-radius: var(--radius);
  background: var(--control-bg);
  color: var(--ink);
}

select option {
  background: var(--surface);
  color: var(--ink);
}

input::placeholder,
textarea::placeholder {
  color: color-mix(in srgb, var(--muted) 72%, transparent);
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 24%, transparent);
}

button {
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  background: var(--accent);
  color: var(--button-ink);
  text-transform: none;
}

button:hover {
  filter: none;
  background: var(--accent-2);
  border-color: var(--accent-2);
}

.ghost-btn,
.icon-btn,
.tab,
.lang-btn,
.theme-btn,
.network-lens-btn,
.conversation-item,
.status-task,
.task-item,
.matrix-row {
  background: var(--control-bg);
  color: var(--ink);
  border: 1px solid var(--line);
}

.ghost-btn:hover,
.icon-btn:hover,
.tab:hover,
.lang-btn:hover,
.theme-btn:hover,
.network-lens-btn:hover,
.conversation-item:hover,
.status-task:hover,
.task-item:hover,
.matrix-row:hover {
  background: var(--surface-soft);
  border-color: var(--accent);
}

.danger-btn {
  background: var(--danger);
  border-color: var(--danger);
  color: white;
}

.language-switch,
.theme-switch {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0;
  background: var(--control-bg);
}

.theme-btn,
.lang-btn {
  min-width: 0;
  height: 30px;
  padding: 0 10px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--muted);
  font-size: 12px;
}

.theme-btn + .theme-btn,
.lang-btn + .lang-btn {
  border-left: 1px solid var(--line);
}

.language-switch .lang-btn {
  min-width: 42px;
}

.login-language {
  justify-content: center;
}

.theme-btn.active,
.lang-btn.active {
  background: var(--accent);
  color: var(--button-ink);
}

.copy-btn {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--accent);
  padding: 0;
  font-size: 14px;
  line-height: 1;
}

.copy-btn:hover {
  border-color: var(--accent);
  background: var(--active-fill);
}

.copy-line {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  max-width: 100%;
}

.copy-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding-right: 4px;
}

.copy-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.copy-meta span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
  max-width: 100%;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--muted);
  padding: 5px 6px;
  font-size: 11px;
  font-weight: 850;
}

.copy-meta code {
  max-width: min(320px, 56vw);
  overflow: hidden;
  color: var(--ink);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.login-theme {
  position: absolute;
  top: 18px;
  left: 18px;
}

.brand-mark,
.node-mark {
  border-radius: var(--radius);
  background: var(--accent);
  color: var(--button-ink);
}

.tab {
  min-width: 72px;
  color: var(--muted);
}

.tab.active,
.network-lens-btn.active,
.matrix-row.active,
.conversation-item.active {
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
  color: var(--ink);
  border-color: var(--accent);
}

.network-board {
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    var(--surface-strong);
  background-size: 28px 28px;
}

.network-node {
  background: var(--surface);
}

.network-node.selected {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 30%, transparent);
}

.network-edge.explicit,
.network-edge.selected {
  stroke: var(--accent);
}

.network-edge.broad {
  stroke: var(--accent-3);
}

.network-svg marker path {
  fill: var(--accent);
}

.network-hub {
  border-color: var(--accent-3);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--accent-3) 10%, var(--surface));
  color: var(--accent-3);
}

.node-status,
.pill,
.task-age,
.check-item b,
.lint-item b,
.bar {
  border-radius: var(--radius);
}

.pill,
.summary-grid > div,
.compare-panel,
.status-column,
.status-task,
.activity-item,
.template-row,
.check-item,
.lint-item,
.forecast-grid > div,
.attachment-card,
.handoff-row {
  background: var(--panel-alt);
}

.message-list {
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    var(--surface-strong);
  background-size: 24px 24px;
}

.message.user {
  border-color: var(--accent);
}

.message.agent {
  border-color: var(--line-strong);
}

.attachment-card b {
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  color: var(--accent);
}

.attachment-card img {
  border-radius: var(--radius);
}

.attachment-card.audio {
  grid-template-columns: 42px minmax(0, 1fr) auto;
}

.attachment-card.audio audio {
  grid-column: 1 / -1;
  width: 100%;
}

.reply-btn {
  margin-top: 10px;
  padding: 5px 8px;
  font-size: 11px;
  opacity: 0;
  transform: translateY(2px);
  transition:
    opacity 0.12s ease,
    transform 0.12s ease;
}

.message:hover .reply-btn,
.message:focus-within .reply-btn {
  opacity: 1;
  transform: translateY(0);
}

.reply-preview {
  display: grid;
  gap: 5px;
  border: 1px solid var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
  padding: 10px;
}

.reply-preview span {
  color: var(--accent);
  font-size: 12px;
  font-weight: 1000;
}

.reply-preview p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.reply-preview button {
  justify-self: start;
}

.bar span {
  background: var(--accent);
}

.toast {
  background: var(--toast-bg);
  color: var(--toast-ink);
  border-color: var(--accent);
  box-shadow: none;
}

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

.brand-row {
  min-width: 0;
}

.header-actions {
  position: relative;
  justify-content: flex-end;
  min-width: 0;
}

.settings-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 40;
  display: grid;
  gap: 14px;
  width: min(920px, calc(100vw - 28px));
  max-height: calc(100vh - 92px);
  overflow: auto;
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 14px;
}

.settings-popover-head {
  position: sticky;
  top: -14px;
  z-index: 2;
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
  padding-bottom: 12px;
}

.settings-popover-head button {
  min-width: 34px;
  padding: 6px 10px;
}

.settings-panel p {
  margin: 4px 0 0;
  font-size: 12px;
}

.settings-row {
  display: grid;
  grid-template-columns: minmax(78px, 0.5fr) minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.settings-row > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.app-body {
  display: grid;
  grid-template-columns: 232px minmax(0, 1fr);
  min-height: 0;
}

.workspace {
  min-width: 0;
}

.side-nav {
  position: sticky;
  top: 65px;
  align-self: start;
  display: grid;
  gap: 8px;
  height: calc(100vh - 65px);
  min-width: 0;
  padding: 16px;
  border-right: 1px solid var(--line);
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    color-mix(in srgb, var(--bg) 92%, var(--surface));
  background-size: 28px 28px;
}

.side-nav .tab {
  display: grid;
  gap: 4px;
  justify-items: start;
  width: 100%;
  min-width: 0;
  min-height: 58px;
  padding: 10px 12px;
  text-align: left;
}

.side-nav .tab span {
  color: var(--ink);
  font-size: 13px;
  font-weight: 1000;
}

.side-nav .tab small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.side-nav .tab.active {
  border-color: var(--accent);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 26%, transparent) 0 4px, transparent 4px),
    color-mix(in srgb, var(--accent) 10%, var(--surface));
}

.side-nav .tab.active small {
  color: color-mix(in srgb, var(--accent) 74%, var(--muted));
}

@media (max-width: 1120px) {
  .app-topbar {
    grid-template-columns: 1fr;
  }

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

  .settings-panel {
    right: 0;
  }
}

@media (max-width: 920px) {
  .app-body {
    grid-template-columns: 1fr;
  }

  .side-nav {
    position: sticky;
    top: 0;
    z-index: 15;
    grid-auto-flow: column;
    grid-auto-columns: minmax(132px, 1fr);
    height: auto;
    overflow-x: auto;
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding: 10px 14px;
  }

  .side-nav .tab {
    min-height: 52px;
  }
}

@media (max-width: 560px) {
  .settings-row {
    grid-template-columns: 1fr;
  }

  .settings-panel {
    right: 0;
  }
}

.agents-layout {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.agent-workspace-nav {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: 14px;
  align-items: center;
  margin-bottom: 14px;
}

.agent-mode-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.agent-mode-btn {
  min-height: 34px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--muted);
  padding: 0 11px;
  font-size: 12px;
  font-weight: 1000;
}

.agent-mode-btn.active,
.agent-mode-btn:hover {
  border-color: var(--accent);
  background: var(--active-fill);
  color: var(--ink);
}

.agent-workspace-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(58px, 1fr));
  gap: 6px;
  min-width: 300px;
}

.agent-workspace-stats span {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  padding: 7px 8px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
}

.agent-workspace-stats b {
  color: var(--ink);
  font-size: 18px;
}

.agent-org-view,
.template-console {
  display: grid;
  gap: 14px;
}

.org-hero {
  display: grid;
  grid-template-columns: minmax(260px, 0.65fr) minmax(0, 1fr);
  gap: 12px;
  align-items: stretch;
}

.operator-node {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  border: 1px solid var(--accent-line);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
  padding: 12px;
}

.operator-node p {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.operator-node strong,
.operator-node small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.operator-node small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.summary-grid.compact {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.summary-grid.compact div {
  min-height: 64px;
}

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

.org-structure-panel,
.org-graph-panel,
.org-project-orbit,
.agent-template-gallery,
.template-console-hero,
.access-matrix-panel,
.agent-directory-panel,
.team-directory-panel {
  display: grid;
  gap: 12px;
}

.org-side {
  display: grid;
  gap: 14px;
}

.org-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 10px;
}

.org-team-card,
.agent-template-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 12px;
}

.org-team-card.solo {
  border-style: dashed;
  background: var(--quiet-fill);
}

.org-card-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}

.org-card-head h3,
.org-card-head p {
  margin: 0;
}

.org-agent-row,
.org-project-row,
.org-project-list,
.agent-template-grid {
  display: grid;
  gap: 8px;
}

.org-agent-row {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.org-agent-chip,
.matrix-agent-btn {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  padding: 8px;
  text-align: left;
}

.org-agent-chip:hover,
.matrix-agent-btn:hover,
.org-project-card:hover,
.matrix-project-btn:hover,
.project-pill:hover {
  border-color: var(--accent);
  background: var(--active-fill);
}

.org-agent-chip.ok {
  border-color: color-mix(in srgb, var(--ok) 26%, var(--line));
}

.org-agent-chip.warn {
  border-color: color-mix(in srgb, var(--warn) 34%, var(--line));
}

.org-agent-chip.danger {
  border-color: color-mix(in srgb, var(--danger) 42%, var(--line));
}

.org-agent-chip strong,
.org-agent-chip small,
.matrix-agent-btn strong,
.matrix-agent-btn small,
.org-project-card strong,
.org-project-card small,
.org-project-card em {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.org-agent-chip small,
.matrix-agent-btn small,
.org-project-card small,
.org-project-card em {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  font-style: normal;
}

.org-project-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.project-pill {
  cursor: pointer;
}

.org-project-card {
  display: grid;
  gap: 6px;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.org-graph-canvas {
  position: relative;
  min-height: 560px;
  overflow: hidden;
  border: 1px solid var(--line);
  background:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px),
    var(--quiet-fill);
  background-size: 36px 36px;
}

.org-graph-lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.org-graph-lines path {
  fill: none;
  stroke: color-mix(in srgb, var(--muted) 38%, transparent);
  stroke-width: 2;
}

.org-graph-lines path.project {
  stroke: color-mix(in srgb, var(--accent) 36%, transparent);
  stroke-dasharray: 6 7;
}

.org-graph-node {
  position: absolute;
  z-index: 1;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  width: 188px;
  min-height: 58px;
  transform: translate(-50%, -50%);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  color: var(--ink);
  padding: 8px;
  text-align: left;
  box-shadow: var(--shadow);
}

.org-graph-node span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--accent);
  font-size: 10px;
  font-weight: 1000;
}

.org-graph-node strong,
.org-graph-node small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.org-graph-node small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.org-graph-node.operator {
  border-color: var(--accent);
  background: var(--active-fill);
}

.org-graph-node.team {
  border-color: color-mix(in srgb, var(--accent) 42%, var(--line));
}

.org-graph-node.project span {
  color: var(--ok);
}

.org-graph-node.agent.ok {
  border-color: color-mix(in srgb, var(--ok) 34%, var(--line));
}

.org-graph-node.agent.warn {
  border-color: color-mix(in srgb, var(--warn) 40%, var(--line));
}

.org-graph-node.agent.danger {
  border-color: color-mix(in srgb, var(--danger) 48%, var(--line));
}

.org-graph-node.more {
  width: 120px;
  opacity: 0.82;
}

.org-tree {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  background:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px),
    var(--quiet-fill);
  background-size: 32px 32px;
  padding: 12px;
}

.org-tree-root {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  max-width: 420px;
  border: 1px solid var(--accent);
  background: var(--active-fill);
  padding: 10px;
}

.org-tree-root strong,
.org-tree-root small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.org-tree-root small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.org-tree-branches,
.org-tree-leaves {
  display: grid;
  gap: 7px;
}

.org-tree-branches {
  padding-left: 18px;
}

.org-tree-leaves {
  padding: 7px 0 4px 42px;
}

.org-tree-branch {
  border: 0;
}

.org-tree-branch summary {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  list-style: none;
}

.org-tree-branch summary::-webkit-details-marker {
  display: none;
}

.tree-prefix {
  color: var(--muted);
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 900;
}

.org-tree-team,
.org-tree-leaf,
.org-tree-team.static {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  width: 100%;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  color: var(--ink);
  padding: 9px 10px;
  text-align: left;
}

.org-tree-team:hover,
.org-tree-leaf:hover {
  border-color: var(--accent);
  background: var(--active-fill);
}

.org-tree-team.static {
  border-style: dashed;
  color: var(--ink);
}

.org-tree-team strong,
.org-tree-team small,
.org-tree-leaf strong,
.org-tree-leaf small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.org-tree-team small,
.org-tree-leaf small,
.org-tree-team em,
.org-tree-leaf em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
}

.org-tree-team em,
.org-tree-leaf em {
  font-weight: 1000;
}

.org-tree-leaf {
  grid-template-columns: 34px minmax(0, 1fr) auto 34px;
}

.org-tree-agent-main {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  text-align: left;
}

.org-tree-agent-main:hover {
  background: transparent;
}

.org-tree-leaf.ok {
  border-color: color-mix(in srgb, var(--ok) 24%, var(--line));
}

.org-tree-leaf.warn {
  border-color: color-mix(in srgb, var(--warn) 32%, var(--line));
}

.org-tree-leaf.danger {
  border-color: color-mix(in srgb, var(--danger) 42%, var(--line));
}

.agent-directory-filter {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(160px, 0.28fr) auto;
  gap: 10px;
  align-items: end;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  padding: 10px;
}

.agent-directory-grid,
.team-directory-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  gap: 10px;
}

.agent-directory-list {
  display: grid;
  border: 1px solid var(--line);
  background: var(--surface);
}

.agent-list-row {
  display: grid;
  grid-template-columns: minmax(220px, 1.25fr) minmax(130px, 0.6fr) minmax(130px, 0.55fr) minmax(150px, 0.7fr) minmax(80px, 0.3fr) auto;
  gap: 10px;
  align-items: center;
  min-height: 58px;
  border-bottom: 1px solid var(--line);
  padding: 9px 10px;
}

.agent-list-row:last-child {
  border-bottom: 0;
}

.agent-list-row.head {
  min-height: 38px;
  background: var(--control-bg);
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.agent-list-open {
  grid-column: 1 / 6;
  display: grid;
  grid-template-columns: minmax(220px, 1.25fr) minmax(130px, 0.6fr) minmax(130px, 0.55fr) minmax(150px, 0.7fr) minmax(80px, 0.3fr);
  gap: 10px;
  align-items: center;
  min-width: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
}

.agent-list-open:hover .agent-list-main strong {
  color: var(--accent);
}

.agent-list-row.ok {
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--ok) 68%, var(--line));
}

.agent-list-row.warn {
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--warn) 68%, var(--line));
}

.agent-list-row.danger {
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--danger) 68%, var(--line));
}

.agent-list-main {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

.agent-list-main strong,
.agent-list-main small,
.agent-list-row > span,
.agent-list-open > span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.agent-list-main small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.agent-list-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.danger-icon-btn {
  border-color: color-mix(in srgb, var(--danger) 48%, var(--line));
  color: var(--danger);
}

.icon-archive {
  position: relative;
  display: inline-block;
  width: 15px;
  height: 12px;
  border: 2px solid currentColor;
}

.icon-archive::before {
  content: "";
  position: absolute;
  left: -2px;
  right: -2px;
  top: -5px;
  height: 3px;
  border: 2px solid currentColor;
  background: var(--surface);
}

.agent-card-modal {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  max-height: min(760px, calc(100vh - 56px));
  overflow: hidden;
}

.agent-modal-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}

.agent-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  justify-content: flex-end;
}

.agent-modal-scroll {
  display: grid;
  gap: 10px;
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
}

.agent-modal-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

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

.agent-directory-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 12px;
}

.agent-directory-card.ok {
  border-color: color-mix(in srgb, var(--ok) 26%, var(--line));
}

.agent-directory-card.warn {
  border-color: color-mix(in srgb, var(--warn) 32%, var(--line));
}

.agent-directory-card.danger {
  border-color: color-mix(in srgb, var(--danger) 42%, var(--line));
}

.agent-directory-title {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
}

.agent-directory-title h3,
.agent-directory-title p {
  margin: 0;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-detail-shell,
.agent-editor.full {
  display: grid;
  gap: 12px;
}

.team-directory-members {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.org-agent-mini {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 170px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  padding: 5px 7px;
  font-size: 11px;
  font-weight: 950;
}

.org-agent-mini span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-template-config-form,
.team-template-config-list {
  display: grid;
  gap: 8px;
}

.team-template-member-config {
  border: 1px solid var(--line);
  background: var(--surface);
}

.team-template-member-config summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  cursor: pointer;
  padding: 10px;
}

.team-template-member-config summary strong,
.team-template-member-config summary small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-template-member-config summary small,
.team-template-member-config summary em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.team-template-config-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 10px;
  border-top: 1px solid var(--line);
}

.team-template-config-grid label.wide,
.template-runtime-details,
.team-template-permissions {
  grid-column: 1 / -1;
}

.team-template-config-grid select[multiple] {
  min-height: 78px;
}

.team-template-permissions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  padding: 9px;
}

.template-runtime-details {
  border: 1px solid var(--line);
  background: var(--quiet-fill);
}

.template-runtime-details summary {
  cursor: pointer;
  padding: 9px 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 1000;
}

.template-console-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 1fr);
  gap: 14px;
  align-items: start;
}

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

.agent-template-card p {
  min-height: 42px;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.45;
}

.access-matrix-scroll {
  overflow: auto;
  border: 1px solid var(--line);
}

.access-matrix-table {
  width: 100%;
  min-width: 820px;
  border-collapse: collapse;
  background: var(--surface);
}

.access-matrix-table th,
.access-matrix-table td {
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
  padding: 8px;
  vertical-align: middle;
}

.access-matrix-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--control-bg);
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-align: left;
}

.matrix-project-btn {
  max-width: 160px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--ink);
  padding: 5px 6px;
  overflow: hidden;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.matrix-access-cell {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 58px;
  min-height: 26px;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  color: var(--muted);
  padding: 2px 7px;
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.matrix-access-cell.visible {
  border-color: color-mix(in srgb, var(--accent) 34%, var(--line));
  background: var(--active-fill);
  color: var(--ink);
}

.matrix-access-cell.owner {
  border-color: color-mix(in srgb, var(--ok) 34%, var(--line));
  background: color-mix(in srgb, var(--ok) 10%, var(--surface));
  color: var(--ok);
}

.matrix-access-cell.none {
  opacity: 0.62;
}

.agent-roster {
  position: sticky;
  top: 82px;
  display: grid;
  gap: 12px;
}

.agent-roster-list {
  display: grid;
  gap: 8px;
}

.agent-roster-section {
  display: grid;
  gap: 8px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

.agent-roster-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.agent-roster-section-title small {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 2px 6px;
}

.agent-team-list {
  display: grid;
  gap: 8px;
}

.team-roster-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.team-roster-card.active {
  border-color: var(--accent);
  background: var(--active-fill);
}

.team-roster-card span,
.team-roster-card strong,
.team-roster-card small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-roster-card small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.team-roster-card em {
  color: var(--accent);
  font-size: 12px;
  font-style: normal;
  font-weight: 1000;
}

.team-roster-card i {
  grid-column: 1 / -1;
  display: flex;
  gap: 4px;
  min-height: 24px;
  font-style: normal;
}

.team-roster-card i b {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--accent);
  font-size: 9px;
}

.agent-filter-form,
.project-search-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 8px;
}

.project-search-form {
  grid-template-columns: minmax(220px, 1fr) minmax(150px, 0.35fr) auto;
  align-items: end;
  margin-bottom: 14px;
}

.portfolio-lanes {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.portfolio-lane-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.portfolio-lane {
  display: grid;
  align-content: start;
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.portfolio-lane.attention {
  border-color: color-mix(in srgb, var(--warn) 44%, var(--line));
}

.portfolio-lane.moving {
  border-color: color-mix(in srgb, var(--ok) 34%, var(--line));
}

.portfolio-lane-head,
.portfolio-project-btn {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.portfolio-lane-list {
  display: grid;
  gap: 7px;
}

.portfolio-project-btn {
  width: 100%;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  padding: 8px;
  text-align: left;
}

.portfolio-project-btn span,
.portfolio-project-btn strong,
.portfolio-project-btn small,
.portfolio-project-btn i {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.portfolio-project-btn small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.portfolio-project-btn em,
.portfolio-project-btn i {
  color: var(--accent);
  font-size: 11px;
  font-style: normal;
  font-weight: 950;
}

.portfolio-project-btn i.warn {
  color: var(--warn);
}

.portfolio-project-btn i.ok {
  color: var(--ok);
}

.agent-roster-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.agent-roster-item.active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}

.agent-roster-item span,
.agent-roster-item strong,
.agent-roster-item small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.agent-roster-item small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.agent-roster-item em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 1000;
}

.agent-roster-item em.ok {
  color: var(--ok);
}

.agent-roster-item em.warn {
  color: var(--warn);
}

.agent-roster-item em.danger {
  color: var(--danger);
}

.agent-editor {
  min-width: 0;
}

.agent-snapshot {
  display: grid;
  gap: 12px;
  margin-bottom: 14px;
}

.draft-agent-note {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border: 1px dashed var(--line-strong);
  background: var(--quiet-fill);
  color: var(--muted);
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 850;
}

.agent-inline-logs {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.project-access-panel {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  padding: 12px;
}

.project-checkbox-grid .checkbox-row {
  align-items: start;
}

.project-checkbox-grid small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.team-template-panel {
  display: grid;
  gap: 12px;
  margin-bottom: 14px;
}

.team-template-browser {
  display: grid;
  grid-template-columns: minmax(220px, 0.55fr) minmax(0, 1fr);
  gap: 10px;
}

.team-template-grid {
  display: grid;
  gap: 8px;
  align-content: start;
}

.team-template-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  color: var(--ink);
  padding: 12px;
  text-align: left;
}

.team-template-card.active {
  border-color: var(--accent);
  background: var(--active-fill);
}

.team-template-card strong {
  color: var(--ink);
}

.team-template-card small {
  display: block;
  min-width: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-template-card em {
  color: var(--accent);
  font-size: 11px;
  font-style: normal;
  font-weight: 1000;
}

.team-template-preview {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 12px;
}

.team-template-preview select[multiple] {
  min-height: 78px;
}

.team-preview-graph {
  display: grid;
  grid-template-columns: minmax(150px, 0.45fr) minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.team-preview-core,
.team-preview-members span {
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 10px;
}

.team-preview-core strong,
.team-preview-core small,
.team-preview-members b,
.team-preview-members small {
  display: block;
}

.team-preview-core small,
.team-preview-members small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.team-preview-members {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
}

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

.team-template-member {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 9px;
}

.team-template-member span,
.team-template-member small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.agent-team-workspace {
  min-width: 0;
}

.team-entity-panel,
.agent-team-graph,
.team-member-panel {
  display: grid;
  gap: 12px;
  margin-bottom: 14px;
}

.agent-team-map {
  display: grid;
  grid-template-columns: minmax(160px, 0.35fr) minmax(0, 1fr);
  gap: 12px;
  align-items: stretch;
}

.team-map-core {
  display: grid;
  align-content: center;
  gap: 6px;
  border: 1px solid var(--accent-line);
  background: color-mix(in srgb, var(--accent) 9%, var(--surface));
  padding: 14px;
}

.team-map-core strong {
  color: var(--ink);
  font-size: 18px;
}

.team-map-core span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.team-map-members {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
}

.team-map-agent,
.team-member-card {
  display: grid;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  text-align: left;
}

.team-map-agent {
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  min-height: 64px;
  padding: 8px;
}

.team-map-agent small,
.team-member-card small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.team-map-projects {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.team-member-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 8px;
}

.team-member-card {
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 8px;
  padding: 9px;
}

.team-member-card span,
.team-member-card strong,
.team-member-card small,
.team-map-agent strong,
.team-map-agent small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-member-card em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 1000;
}

.team-member-card em.ok {
  color: var(--ok);
}

.team-member-card em.warn {
  color: var(--warn);
}

.team-member-card em.danger {
  color: var(--danger);
}

.team-map-agent.ok {
  border-color: color-mix(in srgb, var(--ok) 34%, var(--line));
}

.team-map-agent.warn {
  border-color: color-mix(in srgb, var(--warn) 42%, var(--line));
}

.team-map-agent.danger {
  border-color: color-mix(in srgb, var(--danger) 50%, var(--line));
}

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

.projects-layout.folders-expanded {
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
}

.project-navigator,
.project-detail {
  display: grid;
  gap: 10px;
}

.project-navigator {
  position: sticky;
  top: 82px;
  align-content: start;
  max-height: calc(100vh - 118px);
  overflow: auto;
}

.project-navigator-head {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  padding: 10px;
}

.project-navigator-head span,
.project-navigator-head small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.project-navigator-head strong {
  min-width: 0;
  color: var(--ink);
  font-size: 13px;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.project-folder-list {
  display: grid;
  gap: 8px;
}

.project-navigator-projects {
  display: grid;
  gap: 10px;
  border-top: 1px solid var(--line);
  margin-top: 4px;
  padding-top: 12px;
}

.project-list-stack {
  display: grid;
  gap: 8px;
}

.folder-btn,
.project-card {
  width: 100%;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.folder-btn {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  min-height: 54px;
}

.folder-mark {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--accent);
  font-size: 10px;
  font-weight: 1000;
}

.folder-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.folder-copy strong,
.folder-copy small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.folder-copy strong {
  color: var(--ink);
  font-size: 12px;
}

.folder-copy small {
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
}

.folder-toggle-btn {
  border: 1px dashed var(--line-strong);
  background: color-mix(in srgb, var(--accent) 7%, var(--surface));
  color: var(--ink);
}

.folder-btn.active,
.project-card.active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}

.folder-btn.active .folder-mark {
  border-color: var(--accent);
  background: var(--accent);
  color: #071014;
}

.project-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  padding: 8px;
}

.project-breadcrumbs button,
.project-breadcrumbs strong,
.project-breadcrumbs span {
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 5px 8px;
  font-size: 11px;
  font-weight: 950;
}

.project-breadcrumbs span {
  color: var(--muted);
  background: transparent;
}

.project-breadcrumbs strong {
  color: var(--accent);
}

.project-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.project-card span,
.project-card strong,
.project-card small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-card small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.project-card em,
.folder-btn em {
  color: var(--accent);
  font-style: normal;
  font-weight: 1000;
}

.project-card-bar {
  grid-column: 1 / -1;
  height: 4px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--surface);
}

.project-card-bar b {
  display: block;
  height: 100%;
  background: var(--accent);
}

.project-progress {
  margin: 12px 0 16px;
}

.project-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: start;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 14px;
}

.project-detail-hero h3,
.project-detail-hero p {
  margin: 0;
}

.project-hero-progress {
  display: grid;
  justify-items: end;
  gap: 4px;
  min-width: 96px;
}

.project-hero-progress strong {
  color: var(--accent);
  font-size: 28px;
  line-height: 1;
}

.project-hero-progress span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.project-focus-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 12px;
  margin-bottom: 14px;
}

.project-timeline-panel,
.project-work-block,
.project-system-drawer {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.project-system-drawer {
  margin-top: 14px;
}

.project-system-drawer summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  color: var(--ink);
  cursor: pointer;
  font-weight: 1000;
  list-style: none;
}

.project-system-drawer summary::-webkit-details-marker {
  display: none;
}

.project-system-drawer summary::after {
  content: "+";
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--accent);
}

.project-system-drawer[open] summary::after {
  content: "-";
}

.project-system-drawer summary em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
  overflow: hidden;
  text-align: right;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

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

.project-create-form textarea {
  min-height: 120px;
  resize: vertical;
}

.project-create-form select[multiple] {
  min-height: 82px;
}

.project-create-modal {
  width: min(860px, 100%);
}

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

.project-create-grid .wide {
  grid-column: 1 / -1;
}

.project-team {
  display: grid;
  gap: 10px;
  margin: 14px 0;
}

.project-team-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 8px;
}

.project-team-agent {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 8px;
  text-align: left;
}

.project-team-agent span,
.project-team-agent strong,
.project-team-agent small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-team-agent small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.project-team-agent em {
  grid-column: 1 / -1;
  color: var(--accent);
  font-size: 11px;
  font-style: normal;
  font-weight: 950;
}

.project-timeline {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
  margin-bottom: 16px;
}

.timeline-step {
  display: grid;
  gap: 6px;
  min-height: 82px;
  border: 1px solid var(--line);
  background: var(--panel-alt);
  padding: 10px;
}

.timeline-step.done {
  border-color: color-mix(in srgb, var(--ok) 55%, var(--line));
}

.timeline-step b {
  color: var(--accent);
  font-size: 12px;
}

.timeline-step.done b {
  color: var(--ok);
}

.timeline-step span {
  color: var(--ink);
  font-size: 12px;
  font-weight: 850;
}

.project-task-list {
  display: grid;
  gap: 6px;
}

.project-task-groups {
  display: grid;
  gap: 12px;
}

.project-task-group {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-alt) 78%, var(--bg));
  padding: 10px;
}

.project-task-group .matrix-head {
  margin-bottom: 0;
}

.project-task-group .matrix-head h4,
.project-task-group .matrix-head p {
  margin: 0;
}

.project-task {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr) minmax(124px, auto) minmax(116px, auto) 74px;
  gap: 8px;
  align-items: center;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--panel-alt);
  color: var(--ink);
  padding: 8px 10px;
  text-align: left;
  cursor: pointer;
}

.project-task.done {
  opacity: 0.78;
}

.project-task.active {
  border-color: var(--accent-line);
  background: var(--active-fill);
  opacity: 1;
}

.project-task-main,
.project-task-main strong,
.project-task-main small,
.project-task .task-owner-state,
.project-task .task-evidence,
.project-task-open,
.project-task-state {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-task-state {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--warn);
  padding: 4px 7px;
  font-size: 10px;
  font-weight: 1000;
  text-transform: uppercase;
}

.project-task-state.ok {
  color: var(--ok);
}

.project-task-main {
  display: grid;
  gap: 3px;
}

.project-task-main strong {
  color: var(--ink);
  font-size: 13px;
  line-height: 1.2;
}

.project-task-main small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.project-task .task-evidence,
.project-task .task-owner-state {
  justify-self: end;
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 950;
}

.project-task .task-owner-state {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 3px 7px;
  text-transform: uppercase;
}

.project-task .task-owner-state.ok {
  border-color: rgba(62, 224, 143, 0.42);
  color: var(--ok);
}

.project-task .task-owner-state.warn {
  border-color: rgba(255, 200, 87, 0.42);
  color: var(--warn);
}

.project-task-open {
  justify-self: end;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--accent);
  padding: 5px 7px;
  font-size: 10px;
  font-weight: 1000;
  text-transform: uppercase;
}

.project-task-detail {
  display: grid;
  gap: 12px;
  margin: 14px 0 16px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 68%, var(--bg));
  padding: 14px;
}

.task-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  padding: 24px;
}

.task-modal {
  position: relative;
  width: min(920px, 100%);
  max-height: min(86vh, 840px);
  overflow: auto;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.32);
  padding: 14px;
}

.task-detail-modal {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  width: min(1040px, calc(100vw - 32px));
  height: min(88vh, 860px);
  max-height: min(88vh, 860px);
  overflow: hidden;
  padding: 0;
}

.task-modal-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
  padding: 12px 14px;
}

.task-modal-head div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.task-modal-head strong,
.task-modal-head small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.task-modal-head small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.task-modal-scroll {
  min-height: 0;
  overflow: auto;
  padding: 14px;
}

.task-modal .project-task-detail {
  margin: 0;
  border-color: transparent;
  background: transparent;
  padding: 0;
}

.task-detail-modal .project-task-detail {
  min-height: min-content;
}

.task-modal-close {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  min-height: 34px;
  margin-left: auto;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
}

.task-detail-modal .task-modal-close {
  position: static;
  margin-left: 0;
}

.task-detail-hero {
  display: grid;
  gap: 10px;
  border-left: 3px solid var(--accent);
  background: var(--control-bg);
  padding: 12px;
}

.task-detail-hero > strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.22;
}

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

.task-detail-block {
  display: grid;
  gap: 8px;
  min-width: 0;
  border: 1px solid var(--line);
  background: var(--quiet-fill);
  padding: 12px;
}

.task-detail-block > span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.task-detail-block p {
  margin: 0;
  color: var(--ink);
  line-height: 1.45;
  overflow-wrap: anywhere;
  white-space: pre-wrap;
}

.task-link-list,
.task-history-list {
  display: grid;
  gap: 8px;
}

.task-link-row,
.task-history-row {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
  color: var(--ink);
  text-decoration: none;
}

.task-link-row {
  grid-template-columns: 76px minmax(0, 1fr);
  align-items: center;
}

.task-link-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 30px;
  gap: 6px;
  align-items: stretch;
}

.task-link-shell .copy-btn {
  width: 30px;
  height: auto;
  min-height: 42px;
}

.task-link-row b {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--accent);
  font-size: 10px;
  font-weight: 1000;
  text-transform: uppercase;
}

.task-link-row span {
  display: grid;
  gap: 3px;
}

.task-link-row.action-link {
  cursor: pointer;
}

.task-link-row:hover {
  border-color: var(--accent-line);
  background: var(--hover-fill);
}

.task-link-row.download-link:hover b {
  border-color: var(--accent);
  background: var(--accent);
  color: #071014;
}

.task-link-row.path-link {
  cursor: default;
  opacity: 0.86;
}

.task-link-row strong,
.task-link-row span,
.task-link-row small,
.task-history-row b,
.task-history-row span,
.task-history-row em {
  min-width: 0;
  overflow-wrap: anywhere;
}

.task-link-row small,
.task-history-row span,
.task-history-row em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.task-history-row {
  grid-template-columns: 120px minmax(0, 1fr) auto;
  align-items: center;
}

.task-history-row b {
  color: var(--accent);
  font-size: 12px;
}

.nav-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--ink);
  text-decoration: none;
}

.nav-link-btn.download-link::before {
  content: "DL";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  min-height: 20px;
  border: 1px solid var(--accent-line);
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
  color: var(--accent);
  font-size: 10px;
  font-weight: 1000;
}

.nav-link-btn.download-link:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
}

.chat-agent-list {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}

.chat-agent {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 8px;
  text-align: left;
}

.chat-agent .node-mark {
  width: 34px;
  height: 34px;
  font-size: 11px;
}

.chat-agent.active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}

.chat-agent span,
.chat-agent strong,
.chat-agent small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-agent small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.chat-agent-status {
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--muted);
  padding: 4px 6px;
  font-size: 9px;
  font-style: normal;
  font-weight: 1000;
  text-transform: uppercase;
}

.chat-agent-status.ok {
  border-color: color-mix(in srgb, var(--ok) 35%, var(--line));
  color: var(--ok);
}

.chat-agent-status.warn {
  border-color: color-mix(in srgb, var(--warning) 35%, var(--line));
  color: var(--warning);
}

.settings-preferences,
.settings-section {
  display: grid;
  gap: 14px;
  margin-bottom: 14px;
}

.settings-preferences {
  border: 1px solid var(--line);
  background: var(--panel-alt);
  padding: 14px;
}

.settings-section > .toolbar {
  margin-bottom: 10px;
}

.settings-section .grid-2,
.settings-section .grid-3 {
  gap: 10px;
}

@media (max-width: 1180px) {
  .projects-layout,
  .projects-layout.folders-expanded {
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  }

  .project-create-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .project-detail {
    grid-column: auto;
  }
}

@media (max-width: 920px) {
  .agents-layout,
  .projects-layout,
  .project-focus-grid,
  .project-system-grid,
  .portfolio-lane-grid,
  .project-create-grid,
  .project-detail-hero,
  .team-template-browser,
  .team-preview-graph,
  .agent-team-map {
    grid-template-columns: 1fr;
  }

  .agent-roster,
  .project-navigator {
    position: static;
    max-height: none;
  }
}

@media (max-width: 700px) {
  .project-task {
    grid-template-columns: 74px minmax(0, 1fr);
  }

  .project-task-main {
    grid-column: 2;
    grid-row: 1 / 3;
  }

  .project-task .task-owner-state {
    grid-column: 2;
    grid-row: 3;
    justify-self: start;
  }

  .project-task .task-evidence {
    grid-column: 2;
    grid-row: 4;
    justify-self: start;
  }

  .project-task-open {
    grid-column: 2;
    grid-row: 5;
    justify-self: start;
  }

  .task-detail-grid,
  .task-history-row {
    grid-template-columns: 1fr;
  }

  .task-modal-backdrop {
    padding: 10px;
  }

  .task-modal {
    max-height: 92vh;
    padding: 12px;
  }

  .project-search-form,
  .project-create-form,
  .action-item,
  .priority-item,
  .budget-guardrail,
  .settings-overview-card {
    grid-template-columns: 1fr;
  }
}

/* Five-pass design polish: softer dark mode, clearer nav, cleaner work surfaces. */
:root {
  --active-fill: color-mix(in srgb, var(--accent) 11%, var(--surface));
  --hover-fill: color-mix(in srgb, var(--accent) 7%, var(--surface-soft));
  --quiet-fill: color-mix(in srgb, var(--surface) 74%, var(--bg));
  --raised-fill: color-mix(in srgb, var(--surface-strong) 86%, var(--accent));
  --accent-line: color-mix(in srgb, var(--accent) 52%, var(--line));
}

body {
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    linear-gradient(180deg, var(--bg-2), var(--bg));
  background-size:
    32px 32px,
    32px 32px,
    auto;
  color: var(--ink);
  font-size: 14px;
}

h2 {
  font-size: 22px;
  line-height: 1.18;
}

h3 {
  font-size: 14px;
}

h4 {
  margin: 0;
  font-size: 12px;
  line-height: 1.2;
}

.muted,
#userEmail {
  color: var(--muted);
}

.view {
  padding: 18px 20px 24px;
}

button {
  min-height: 36px;
  transition:
    background-color 0.14s ease,
    border-color 0.14s ease,
    color 0.14s ease;
}

.ghost-btn,
.icon-btn,
.tab,
.lang-btn,
.theme-btn,
.network-lens-btn,
.conversation-item,
.status-task,
.task-item,
.project-task,
.project-team-agent,
.matrix-row,
.folder-btn,
.project-card,
.agent-roster-item,
.chat-agent {
  background: var(--control-bg);
  border-color: var(--line);
}

.ghost-btn:hover,
.icon-btn:hover,
.tab:hover,
.lang-btn:hover,
.theme-btn:hover,
.network-lens-btn:hover,
.conversation-item:hover,
.status-task:hover,
.task-item:hover,
.project-task:hover,
.project-team-agent:hover,
.matrix-row:hover,
.folder-btn:hover,
.project-card:hover,
.agent-roster-item:hover,
.chat-agent:hover {
  background: var(--hover-fill);
  border-color: var(--accent-line);
}

.app-topbar {
  min-height: 62px;
  padding: 12px 16px;
  border-bottom-color: var(--line);
}

.brand-row > div {
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 4px 9px 4px 4px;
}

.brand-mark,
.node-mark {
  background: var(--accent);
}

.brand-mark {
  width: 32px;
  height: 32px;
}

#userEmail {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 7px 9px;
}

.app-body {
  grid-template-columns: 216px minmax(0, 1fr);
}

.side-nav {
  top: 62px;
  height: calc(100vh - 62px);
  align-content: start;
  gap: 7px;
  padding: 14px 12px;
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    var(--bg-2);
  background-size: 32px 32px;
}

.side-nav .tab {
  position: relative;
  grid-template-columns: 14px minmax(0, 1fr);
  grid-template-rows: auto auto;
  column-gap: 9px;
  min-height: 54px;
  padding: 10px;
}

.side-nav .tab::before {
  content: "";
  grid-row: 1 / 3;
  width: 8px;
  height: 8px;
  margin-top: 5px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
}

.side-nav .tab span,
.side-nav .tab small {
  grid-column: 2;
}

.side-nav .tab.active,
.tab.active,
.network-lens-btn.active,
.matrix-row.active,
.conversation-item.active,
.agent-roster-item.active,
.folder-btn.active,
.project-card.active,
.project-task.active,
.chat-agent.active {
  background: var(--active-fill);
  border-color: var(--accent-line);
  color: var(--ink);
}

.side-nav .tab.active::before {
  border-color: var(--accent);
  background: var(--accent);
}

.side-nav .tab.active {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 35%, transparent) 0 3px, transparent 3px),
    var(--active-fill);
}

.board-panel,
.panel,
.login-panel,
.metric-strip > div,
.metric-mini,
.summary-grid > div,
.compare-panel,
.matrix-row,
.status-column,
.status-task,
.task-item,
.risk-item,
.activity-item,
.template-row,
.check-item,
.lint-item,
.conversation-item,
.message,
.attachment-card,
.handoff-row,
.forecast-grid > div,
.timeline-step,
.project-task,
.project-team-agent,
.team-template-card,
.project-access-panel {
  background: var(--quiet-fill);
  border-color: var(--line);
}

.board-panel,
.panel {
  padding: 18px;
}

.metric-strip > div,
.metric-mini,
.summary-grid > div,
.forecast-grid > div {
  padding: 13px;
}

.workspace > .view > .toolbar,
.board-panel > .toolbar,
.agent-editor > .toolbar,
.settings-section > .toolbar {
  border-bottom: 1px solid var(--line);
  padding-bottom: 12px;
}

.pill {
  border-color: var(--line);
  background: var(--control-bg);
}

.bar {
  height: 8px;
  background: color-mix(in srgb, var(--line) 46%, var(--bg));
}

.bar span {
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
}

.network-board,
.message-list {
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    var(--surface-strong);
  background-size: 32px 32px;
}

.network-board {
  min-height: 540px;
}

.network-edge {
  stroke-width: 1.7;
  opacity: 0.46;
}

.network-edge.selected {
  stroke-width: 2.5;
  opacity: 0.76;
}

.network-node {
  width: 142px;
  min-height: 44px;
  border-color: var(--line);
  background: var(--raised-fill);
}

.network-node.selected {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 24%, transparent);
}

.network-hub {
  width: 76px;
  height: 76px;
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--accent-3) 8%, var(--surface));
}

.agents-layout {
  grid-template-columns: 300px minmax(0, 1fr);
}

.agent-roster,
.project-navigator {
  top: 78px;
}

.agent-roster-item,
.project-card,
.folder-btn,
.chat-agent,
.conversation-item {
  min-height: 50px;
}

.agent-roster-item em,
.project-card em,
.folder-btn em {
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 4px 6px;
}

.projects-layout {
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 12px;
}

.projects-layout.folders-expanded {
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
}

.project-navigator,
.project-detail {
  align-content: start;
}

.folder-btn {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  align-items: center;
  font-weight: 950;
}

.folder-btn::after {
  content: none;
}

.folder-btn.active::after {
  border-color: var(--accent);
  background: var(--accent);
}

.project-card {
  min-height: 72px;
}

.project-stats-panel {
  margin-bottom: 14px;
}

.project-action-plan,
.project-next-work {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.project-action-list {
  display: grid;
  gap: 8px;
}

.project-action-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.project-action-row::before {
  content: "";
  width: 7px;
  height: 100%;
  min-height: 30px;
  background: var(--muted);
  grid-row: 1;
}

.project-action-row {
  grid-template-columns: 7px minmax(0, 1fr) auto;
}

.project-action-row.ok::before {
  background: var(--ok);
}

.project-action-row.warn::before {
  background: var(--warn);
}

.project-action-row.danger::before {
  background: var(--danger);
}

.project-action-row > span {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.project-action-row strong,
.project-action-row small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-action-row small {
  color: var(--muted);
  font-weight: 780;
}

.project-timeline {
  grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
}

.timeline-step {
  position: relative;
  min-height: 92px;
  padding: 12px 12px 12px 34px;
}

.timeline-step::before {
  content: "";
  position: absolute;
  left: 13px;
  top: 15px;
  width: 9px;
  height: 9px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
}

.timeline-step.done::before {
  border-color: var(--ok);
  background: var(--ok);
}

.timeline-step b {
  color: var(--muted);
}

.timeline-step.done b {
  color: var(--ok);
}

.project-task {
  grid-template-columns: 88px minmax(0, 1fr) minmax(124px, auto) minmax(116px, auto) 74px;
  min-height: 54px;
}

.check-item b,
.lint-item b,
.attachment-card b {
  border: 1px solid var(--line);
  background: var(--surface);
}

.chat-layout {
  grid-template-columns: 300px minmax(0, 1fr) 320px;
  gap: 12px;
}

.chat-layout > .panel {
  overflow: auto;
}

.chat-sidebar,
.chat-agent-card {
  align-self: stretch;
}

.chat-agent-card {
  display: grid;
  align-content: start;
  gap: 12px;
  max-height: calc(100vh - 120px);
  overflow: auto;
}

.chat-agent-card-avatar {
  border: 0;
  min-height: 54px;
  padding: 0;
}

.agent-card-block {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.agent-card-block > p {
  margin: 0;
  color: var(--ink);
  font-size: 12px;
  line-height: 1.45;
}

.agent-thread-list,
.agent-card-log {
  display: grid;
  gap: 8px;
}

.agent-thread-btn {
  display: grid;
  gap: 4px;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  padding: 9px;
  text-align: left;
}

.agent-thread-btn.active {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.agent-thread-btn strong,
.agent-thread-btn span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.agent-thread-btn span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.chat-context-panel {
  display: grid;
  gap: 10px;
  margin-bottom: 10px;
}

.message-list {
  min-height: 0;
  padding: 16px;
}

.message {
  max-width: min(740px, 84%);
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 8px;
  padding: 12px;
}

.message.user {
  grid-template-columns: minmax(0, 1fr) 18px;
  background: color-mix(in srgb, var(--accent) 9%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
}

.message.agent {
  background: var(--panel-alt);
  border-color: var(--line-strong);
}

.message.user .message-body {
  grid-column: 1;
  grid-row: 1;
}

.message.user .message-reply-rail {
  grid-column: 2;
  grid-row: 1;
}

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

.message-reply-rail {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  min-height: 100%;
  border: 1px solid transparent;
  border-radius: calc(var(--radius) - 2px);
  padding: 0;
  background: transparent;
  color: var(--muted);
  cursor: copy;
  opacity: 0.38;
  touch-action: manipulation;
  transition:
    opacity 0.12s ease,
    border-color 0.12s ease,
    background 0.12s ease,
    color 0.12s ease;
}

.message-reply-rail::before {
  content: "";
  width: 7px;
  height: 7px;
  border-bottom: 2px solid currentColor;
  border-left: 2px solid currentColor;
  transform: rotate(45deg);
}

.message:hover .message-reply-rail,
.message-reply-rail:hover,
.message-reply-rail:focus-visible {
  opacity: 1;
}

.message-reply-rail:hover,
.message-reply-rail:focus-visible {
  border-color: var(--accent-line);
  background: var(--active-fill);
  color: var(--accent);
}

.composer {
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 10px;
}

.quick-prompts {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition:
    max-height 0.16s ease,
    opacity 0.16s ease;
}

.composer.is-composing .quick-prompts {
  max-height: 90px;
  opacity: 1;
}

.quick-prompts > span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.quick-prompt-btn {
  min-height: 30px;
  padding: 6px 9px;
}

.composer textarea {
  min-height: 54px;
}

.file-tray {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 8px;
  font-size: 12px;
}

.file-tray span,
.file-tray strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.scheduled-strip,
.schedule-panel {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 8px;
}

.scheduled-strip .matrix-head {
  margin-bottom: 0;
}

.scheduled-list {
  display: grid;
  gap: 6px;
}

.scheduled-item {
  display: grid;
  grid-template-columns: minmax(110px, 0.35fr) minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 8px;
}

.scheduled-item span,
.scheduled-item strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.scheduled-item span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.schedule-panel {
  grid-template-columns: minmax(130px, 0.4fr) minmax(160px, 0.5fr) minmax(0, 1fr) auto;
  align-items: end;
}

.schedule-panel.hidden {
  display: none;
}

.schedule-time-field.hidden,
.schedule-trigger-field.hidden {
  display: none;
}

.reply-preview {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.settings-panel {
  width: min(560px, calc(100vw - 28px));
  gap: 0;
  border-color: var(--line-strong);
  background: var(--surface-strong);
  padding: 0;
}

.settings-popover-head {
  top: 0;
  background: var(--surface-strong);
  padding: 14px 16px;
}

.settings-overview-card {
  display: grid;
  grid-template-columns: minmax(180px, 0.55fr) minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.settings-overview-card h3,
.settings-overview-card p {
  margin-bottom: 4px;
}

.settings-overview-grid span {
  display: grid;
  gap: 2px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 8px;
}

.settings-overview-grid b {
  color: var(--ink);
  font-size: 14px;
}

.settings-launch-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
  gap: 8px;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface-strong) 82%, var(--bg));
  padding: 12px 16px;
}

.settings-launch-btn,
.settings-nav-btn {
  display: grid;
  gap: 4px;
  min-height: 58px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.settings-launch-btn span,
.settings-launch-btn small,
.settings-nav-btn span,
.settings-nav-btn small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.settings-launch-btn span,
.settings-nav-btn span {
  font-weight: 1000;
}

.settings-launch-btn small,
.settings-nav-btn small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.settings-launch-btn:hover,
.settings-nav-btn:hover,
.settings-nav-btn.active {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.settings-quick-controls {
  display: grid;
  gap: 12px;
  padding: 14px 16px 16px;
}

.settings-quick-controls .settings-row {
  grid-template-columns: 1fr;
  align-items: start;
  min-width: 0;
}

.settings-quick-controls .language-switch,
.settings-quick-controls .theme-switch {
  display: grid;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

.settings-quick-controls .language-switch {
  grid-template-columns: repeat(7, minmax(34px, 1fr));
}

.settings-quick-controls .theme-switch {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.settings-quick-controls .lang-btn,
.settings-quick-controls .theme-btn {
  min-width: 0;
  width: 100%;
  white-space: nowrap;
}

.settings-quick-controls .lang-btn {
  padding: 0 6px;
  font-size: 11px;
}

.settings-quick-controls .lang-btn + .lang-btn,
.settings-quick-controls .theme-btn + .theme-btn {
  border-left: 1px solid var(--line);
}

.settings-page-shell {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 14px;
}

.settings-page-nav {
  position: sticky;
  top: 14px;
  align-self: start;
  display: grid;
  gap: 8px;
}

.settings-page-nav h2 {
  margin: 0 0 4px;
}

.settings-page-main {
  display: grid;
  gap: 14px;
  min-width: 0;
}

.settings-overview {
  display: grid;
  gap: 10px;
}

.settings-content {
  display: grid;
  gap: 14px;
  min-height: 260px;
}

.production-readiness {
  gap: 12px;
}

.readiness-check-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
}

.readiness-check {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 9px;
}

.readiness-check b {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border: 1px solid var(--line);
  color: var(--muted);
  font-size: 10px;
  font-weight: 1000;
}

.readiness-check.ok {
  border-color: color-mix(in srgb, var(--ok) 34%, var(--line));
}

.readiness-check.warn {
  border-color: color-mix(in srgb, var(--warn) 44%, var(--line));
}

.readiness-check.danger {
  border-color: color-mix(in srgb, var(--danger) 50%, var(--line));
}

.readiness-check.ok b {
  color: var(--ok);
}

.readiness-check.warn b {
  color: var(--warn);
}

.readiness-check.danger b {
  color: var(--danger);
}

.readiness-check span,
.readiness-check strong,
.readiness-check small {
  min-width: 0;
}

.readiness-check strong,
.readiness-check small {
  display: block;
}

.readiness-check small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.readiness-action-btn {
  min-height: 30px;
  padding: 6px 8px;
}

.docs-panel {
  display: grid;
  grid-template-columns: minmax(190px, 240px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  background: var(--surface);
}

.docs-sidebar {
  position: sticky;
  top: 84px;
  display: grid;
  gap: 14px;
  max-height: calc(100vh - 120px);
  overflow: auto;
  border-right: 1px solid var(--line);
  padding-right: 14px;
}

.docs-nav-group {
  display: grid;
  gap: 5px;
}

.docs-nav-group strong {
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.docs-nav-group a {
  border: 1px solid transparent;
  color: var(--ink);
  padding: 6px 8px;
  text-decoration: none;
  font-size: 12px;
  font-weight: 850;
}

.docs-nav-group a:hover,
.docs-nav-group a:focus-visible {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.docs-reader {
  display: grid;
  gap: 18px;
  min-width: 0;
}

.doc-article {
  display: grid;
  gap: 14px;
  min-width: 0;
  border-bottom: 1px solid var(--line);
  padding-bottom: 18px;
  scroll-margin-top: 92px;
}

.doc-article:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.doc-article-head {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.doc-article-head > span {
  display: grid;
  place-items: center;
  min-height: 34px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--accent);
  font-size: 12px;
  font-weight: 1000;
}

.doc-article-head h3,
.doc-article-head p,
.doc-section h4,
.doc-section p {
  margin: 0;
}

.doc-article-head h3 {
  color: var(--ink);
  font-size: 22px;
  line-height: 1.18;
}

.doc-article-head p {
  max-width: 860px;
  color: var(--muted);
  line-height: 1.55;
}

.doc-section {
  display: grid;
  gap: 8px;
  max-width: 900px;
  border-left: 2px solid var(--line);
  padding-left: 14px;
}

.doc-section h4 {
  color: var(--ink);
  font-size: 15px;
}

.doc-section p,
.doc-section li {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.doc-section ul,
.doc-section ol {
  display: grid;
  gap: 6px;
  margin: 0;
  padding-left: 20px;
}

.doc-section code,
.doc-section pre {
  font-family: inherit;
}

.doc-section pre {
  overflow: auto;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 12px;
  white-space: pre;
}

.budget-guardrail {
  display: grid;
  grid-template-columns: minmax(160px, 0.4fr) minmax(0, 1fr);
  gap: 10px;
  align-items: end;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.budget-guardrail.ok {
  border-color: color-mix(in srgb, var(--ok) 45%, var(--line));
}

.budget-guardrail.danger {
  border-color: color-mix(in srgb, var(--danger) 55%, var(--line));
}

.budget-guardrail span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.budget-status {
  display: grid;
  gap: 7px;
}

.budget-progress {
  height: 10px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--surface);
}

.budget-progress b {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
}

.budget-status small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.settings-preferences,
.settings-section {
  margin: 0;
  border: 0;
  border-bottom: 1px solid var(--line);
  background: transparent;
  padding: 16px;
}

.settings-section h2 {
  font-size: 18px;
}

.settings-panel .panel,
.settings-panel .metric-strip > div,
.settings-panel .forecast-grid > div {
  background: var(--surface);
}

.settings-panel .provider-grid {
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
}

.settings-preferences .settings-row {
  grid-template-columns: 1fr;
  align-items: start;
}

.settings-preferences .language-switch,
.settings-preferences .theme-switch {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(64px, 1fr));
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.settings-preferences .theme-switch {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.settings-preferences .lang-btn,
.settings-preferences .theme-btn {
  min-width: 0;
  width: 100%;
}

.settings-preferences .lang-btn + .lang-btn,
.settings-preferences .theme-btn + .theme-btn {
  border-left: 0;
}

.ops-card {
  display: grid;
  gap: 12px;
}

.ops-grid {
  margin-top: 14px;
}

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

.agent-autonomy-editor {
  display: grid;
  border: 1px solid var(--line);
  background: var(--control-bg);
  gap: 12px;
  padding: 12px;
}

.agent-autonomy-editor summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
  font-weight: 700;
}

.agent-autonomy-editor summary small {
  color: var(--muted);
  font-weight: 600;
}

.agent-autonomy-grid,
.agent-autonomy-toggles {
  display: grid;
  gap: 10px;
}

.agent-autonomy-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.agent-autonomy-toggles {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.agent-autonomy-panel {
  display: grid;
  gap: 12px;
}

.backup-policy-form,
.backup-policy-grid,
.backup-policy-status,
.backup-sync-results,
.ops-advanced {
  display: grid;
  gap: 10px;
}

.backup-policy-status {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.backup-policy-status span,
.backup-sync-results span {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 9px 10px;
}

.backup-policy-status strong,
.backup-policy-status small {
  display: block;
}

.backup-policy-status small {
  color: var(--muted);
  margin-top: 3px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.backup-policy-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  align-items: end;
}

.backup-key-field {
  grid-column: 1 / -1;
}

.backup-key-field textarea {
  min-height: 86px;
}

.ops-advanced {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.ops-advanced summary {
  cursor: pointer;
  font-weight: 700;
}

.backup-sync-results {
  grid-template-columns: 1fr;
}

.backup-sync-results strong {
  font-size: 0.85rem;
}

.ops-row,
.command-run-row {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.ops-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.ops-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.ops-actions .ghost-btn {
  min-height: 30px;
  padding: 6px 8px;
  font-size: 11px;
}

.ops-row span,
.ops-row strong,
.ops-row small,
.command-run-row strong,
.command-run-row small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ops-row span {
  display: grid;
  gap: 3px;
}

.ops-row small,
.command-run-row small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.command-run-row pre {
  max-height: 220px;
  overflow: auto;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  padding: 10px;
  font-size: 12px;
  white-space: pre-wrap;
}

.command-run-row pre.stderr {
  border-color: color-mix(in srgb, var(--danger) 38%, var(--line));
  color: var(--danger);
}

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

.section-pulse-grid,
.thread-signals,
.model-blocker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.section-pulse-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px 10px;
  min-height: 76px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.section-pulse-card strong {
  font-size: 22px;
  line-height: 1;
}

.section-pulse-card small,
.section-pulse-card em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.section-pulse-card em {
  grid-column: 1 / -1;
  text-transform: uppercase;
}

.section-pulse-card.ok {
  border-color: color-mix(in srgb, var(--ok) 36%, var(--line));
}

.section-pulse-card.warn {
  border-color: color-mix(in srgb, var(--warn) 42%, var(--line));
}

.section-pulse-card.danger {
  border-color: color-mix(in srgb, var(--danger) 50%, var(--line));
}

.project-insights,
.project-task-filter,
.message-search-form,
.thread-signals {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.project-task-filter,
.message-search-form {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: end;
}

.message-search-form label {
  flex: 1 1 240px;
}

.project-task-filter span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.project-task-filter-btn {
  min-height: 30px;
  border-color: var(--line);
  background: var(--surface);
  color: var(--ink);
}

.project-task-filter-btn.active {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.project-owner-select {
  flex: 1 1 190px;
  min-width: 180px;
}

.project-owner-select select {
  margin-top: 4px;
}

.thread-signals > div {
  display: grid;
  gap: 3px;
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 8px;
}

.thread-signals span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.thread-signals strong {
  font-size: 18px;
}

.model-blockers {
  display: grid;
  gap: 10px;
}

.model-blocker-grid > div {
  display: grid;
  align-content: start;
  gap: 8px;
}

.model-blocker-agent {
  display: grid;
  gap: 3px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 8px;
  text-align: left;
}

.model-blocker-agent-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: stretch;
}

.model-blocker-agent-row .assign-ready-model-btn {
  align-self: stretch;
  min-height: 100%;
}

.model-blocker-agent small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.operator-brief,
.autonomy-lanes,
.team-capacity,
.agent-workload,
.agent-governance,
.agent-risk-panel,
.project-health,
.project-autonomy-plan,
.project-owner-map,
.provider-health,
.ops-readiness {
  display: grid;
  gap: 10px;
}

.operator-brief,
.autonomy-lanes,
.team-capacity {
  margin-top: 14px;
}

.operator-brief-list,
.autonomy-lane-grid,
.owner-map-list,
.workload-task-list,
.agent-risk-list,
.ops-readiness-grid {
  display: grid;
  gap: 8px;
}

.autonomy-lane-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.autonomy-lane {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px 10px;
  min-height: 72px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.autonomy-lane strong {
  font-size: 24px;
  line-height: 1;
}

.autonomy-lane span,
.autonomy-lane small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.autonomy-lane span {
  font-weight: 950;
}

.autonomy-lane small {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.autonomy-lane.ok {
  border-color: color-mix(in srgb, var(--ok) 34%, var(--line));
}

.autonomy-lane.warn {
  border-color: color-mix(in srgb, var(--warn) 42%, var(--line));
}

.autonomy-lane.danger {
  border-color: color-mix(in srgb, var(--danger) 50%, var(--line));
}

.operator-brief-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.operator-brief-item span {
  min-width: 0;
  overflow: hidden;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.operator-brief-item.warn {
  border-color: color-mix(in srgb, var(--warn) 42%, var(--line));
}

.operator-brief-item.danger {
  border-color: color-mix(in srgb, var(--danger) 50%, var(--line));
}

.workload-task-list {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.workload-task {
  display: grid;
  gap: 3px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 9px;
  text-align: left;
}

.workload-task:hover {
  border-color: var(--accent);
  background: var(--surface-soft);
}

.workload-task strong,
.workload-task small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workload-task small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.project-owner-map {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.project-health,
.project-autonomy-plan {
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.provider-health {
  margin-bottom: 10px;
}

.conversation-item strong {
  display: flex;
  min-width: 0;
  align-items: center;
  gap: 7px;
}

.conversation-item strong em {
  flex: 0 0 auto;
  border: 1px solid var(--accent-line);
  background: var(--active-fill);
  color: var(--accent-2);
  padding: 2px 5px;
  font-size: 10px;
  font-style: normal;
  font-weight: 1000;
  text-transform: uppercase;
}

.owner-map-row {
  display: grid;
  grid-template-columns: minmax(0, 0.42fr) minmax(120px, 1fr);
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 9px;
}

.owner-map-row span {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.owner-map-row strong,
.owner-map-row small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.owner-map-row small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.owner-load-bar {
  height: 10px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--control-bg);
}

.owner-load-bar b {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
}

.composer-hint {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.composer-hint em {
  color: var(--accent-2);
  font-style: normal;
  font-weight: 1000;
}

.composer-hint em.hidden {
  display: none;
}

.ops-readiness {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.ops-readiness-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ops-readiness-grid span {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 2px 8px;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 9px;
}

.ops-readiness-grid b {
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border: 1px solid currentColor;
  color: var(--muted);
  font-size: 11px;
}

.ops-readiness-grid span.ok b {
  color: var(--ok);
}

.ops-readiness-grid span.warn b {
  color: var(--warn);
}

.ops-readiness-grid strong,
.ops-readiness-grid small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ops-readiness-grid small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

@media (max-width: 920px) {
  .side-nav {
    top: 0;
    height: auto;
  }

  .side-nav .tab {
    grid-template-columns: 10px minmax(0, 1fr);
  }

  .chat-layout {
    height: auto;
    grid-template-columns: 1fr;
  }

  .settings-launch-grid,
  .settings-page-shell,
  .docs-panel {
    grid-template-columns: 1fr;
  }

  .docs-sidebar {
    position: static;
    max-height: none;
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding-right: 0;
    padding-bottom: 12px;
  }

  .agent-workspace-nav,
  .org-hero,
  .org-layout,
  .agent-directory-filter,
  .template-console-grid {
    grid-template-columns: 1fr;
  }

  .agent-mode-tabs {
    justify-content: flex-start;
  }

  .agent-workspace-stats {
    min-width: 0;
  }

  .autonomy-lane-grid {
    grid-template-columns: 1fr 1fr;
  }

  .projects-layout,
  .projects-layout.folders-expanded {
    grid-template-columns: 1fr;
  }

  .project-detail {
    grid-column: auto;
  }

  .ops-readiness-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 1180px) and (min-width: 921px) {
  .projects-layout,
  .projects-layout.folders-expanded {
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  }

  .project-detail {
    grid-column: auto;
  }
}

@media (max-width: 560px) {
  #userEmail {
    display: none;
  }

  .view {
    padding: 14px;
  }

  .owner-map-row,
  .operator-brief-item,
  .handoff-candidate,
  .autonomy-lane-grid,
  .portfolio-lane-grid,
  .agent-workspace-stats,
  .summary-grid.compact,
  .ops-readiness-grid {
    grid-template-columns: 1fr;
  }

  .org-team-grid,
  .org-agent-row,
  .agent-template-grid,
  .agent-directory-grid,
  .agent-list-row,
  .team-directory-grid,
  .team-template-config-grid,
  .agent-modal-grid,
  .agent-modal-top,
  .team-template-permissions {
    grid-template-columns: 1fr;
  }

  .agent-list-row.head {
    display: none;
  }

  .agent-list-open {
    grid-column: auto;
    grid-template-columns: 1fr;
  }

  .agent-list-actions {
    justify-content: flex-start;
  }

  .org-tree-branches {
    padding-left: 8px;
  }

  .org-tree-leaves {
    padding-left: 18px;
  }

  .org-graph-canvas {
    min-height: 640px;
  }

  .org-graph-node {
    width: 154px;
  }
}

/* Agent workspace restructure: global navigation on top, local navigation on the left. */
.app-topbar {
  grid-template-columns: auto minmax(420px, 1fr) auto;
}

.top-nav {
  justify-content: center;
}

.top-nav .tab {
  display: grid;
  grid-template-rows: auto auto;
  gap: 2px;
  min-width: 118px;
  min-height: 42px;
  padding: 7px 12px;
  text-align: center;
}

.top-nav .tab span {
  color: var(--ink);
  font-size: 13px;
  font-weight: 1000;
}

.top-nav .tab small {
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
}

.top-nav .tab.active small {
  color: color-mix(in srgb, var(--accent) 74%, var(--muted));
}

.app-body {
  display: block;
}

.agent-workspace-layout {
  display: grid;
  grid-template-columns: 164px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.agent-workspace-main {
  min-width: 0;
}

.agent-workspace-nav {
  position: sticky;
  top: 82px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  align-content: start;
  margin: 0;
  padding: 10px;
}

.agent-workspace-nav > strong {
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.agent-mode-tabs {
  display: grid;
  gap: 6px;
  justify-content: stretch;
}

.agent-mode-btn {
  width: 100%;
  min-height: 38px;
  justify-content: start;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--muted);
  padding: 0 10px;
  text-align: left;
}

.agent-mode-btn.active {
  background: var(--active-fill);
  border-color: var(--accent-line);
  color: var(--ink);
}

.agent-org-view {
  display: block;
}

.agent-directory-filter {
  grid-template-columns: minmax(240px, 1fr);
}

.filter-check-group {
  display: grid;
  gap: 7px;
  min-width: 0;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--control-bg);
  padding: 9px;
}

.filter-check-group legend {
  padding: 0 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
}

.filter-check-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.filter-check {
  display: inline-flex;
  grid-template-columns: auto auto;
  gap: 6px;
  align-items: center;
  width: auto;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 5px 8px;
  font-size: 12px;
}

.filter-check input {
  width: auto;
}

.filter-footnote {
  align-self: center;
}

.agent-list-row {
  grid-template-columns: minmax(0, 1fr) auto;
}

.agent-list-row.head {
  grid-template-columns: minmax(220px, 1.25fr) minmax(130px, 0.6fr) minmax(130px, 0.55fr) minmax(150px, 0.7fr) minmax(80px, 0.3fr) auto;
}

.agent-list-row:not(.head):hover {
  background: color-mix(in srgb, var(--accent) 9%, var(--surface-strong));
}

.agent-list-open {
  grid-column: auto;
  color: var(--ink);
}

.agent-list-open:hover .agent-list-main strong {
  color: var(--ink);
}

.agent-list-open .agent-list-main small,
.agent-list-open > span {
  color: color-mix(in srgb, var(--ink) 76%, var(--muted));
}

.agent-card-modal {
  width: min(1180px, calc(100vw - 32px));
  max-height: min(90vh, 920px);
  padding: 16px;
}

.agent-modal-scroll {
  gap: 12px;
  max-height: calc(90vh - 88px);
  padding-right: 6px;
}

.agent-modal-grid.edit {
  grid-template-columns: minmax(320px, 0.95fr) minmax(360px, 1.05fr);
}

.agent-modal-grid.context {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.agent-modal-access summary {
  cursor: pointer;
  color: var(--ink);
  font-weight: 1000;
}

.agent-peer-access-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--control-bg);
  padding: 12px;
}

.agent-modal-savebar {
  position: sticky;
  bottom: -1px;
  z-index: 3;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, var(--bg));
  padding: 10px;
}

.team-member-editor {
  margin-top: 14px;
}

.team-member-edit-list {
  display: grid;
  gap: 7px;
}

.team-member-edit-row {
  display: grid;
  grid-template-columns: auto 34px minmax(0, 1fr) auto;
  gap: 9px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--control-bg);
  padding: 8px;
}

.team-member-edit-row input {
  width: auto;
}

.team-member-edit-row strong,
.team-member-edit-row small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-member-edit-row small,
.team-member-edit-row em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
}

.template-builder-page {
  display: grid;
  gap: 14px;
}

.template-builder-page .template-edit-form {
  margin: 0;
}

.org-agent-filterbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  gap: 10px;
  align-items: end;
  margin-bottom: 14px;
  padding: 10px;
}

.org-filter-search {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 10px;
  align-items: end;
  min-width: 0;
}

.org-filter-search label {
  margin: 0;
}

.org-filter-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
  justify-content: flex-end;
}

.org-filter-popover {
  position: relative;
  min-width: 136px;
}

.org-filter-popover summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--control-bg);
  color: var(--ink);
  cursor: pointer;
  list-style: none;
  padding: 0 10px;
}

.org-filter-popover summary::-webkit-details-marker {
  display: none;
}

.org-filter-popover summary em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
}

.org-filter-popover[open] summary {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.org-filter-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 30;
  display: grid;
  gap: 6px;
  width: min(280px, calc(100vw - 40px));
  max-height: 320px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
  padding: 8px;
}

.org-filter-menu .filter-check {
  justify-content: flex-start;
  width: 100%;
  border-radius: calc(var(--radius) - 2px);
  padding: 7px 8px;
}

.team-tree-leaf {
  grid-template-columns: 34px minmax(0, 1fr) auto 34px 34px;
}

.team-remove-agent-btn {
  font-size: 18px;
  line-height: 1;
}

.team-add-modal {
  width: min(620px, calc(100vw - 32px));
}

.team-add-modal select[multiple] {
  min-height: 220px;
}

.agent-card-like {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 5%, transparent), transparent 52%),
    var(--control-bg);
}

.agent-template-card-head {
  display: grid;
  gap: 8px;
}

.agent-modal-summary.compact {
  gap: 5px;
}

.template-card-goal {
  min-height: 42px;
  margin: 0;
  color: var(--ink);
}

.agent-template-editor-card,
.team-template-editor-card {
  display: grid;
  gap: 12px;
  max-width: 1180px;
}

.team-template-member-preview-list {
  display: grid;
  gap: 7px;
}

.team-template-member-preview {
  display: grid;
  grid-template-columns: 28px 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--control-bg);
  padding: 8px;
}

.team-template-member-preview strong,
.team-template-member-preview small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-template-member-preview small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.app-topbar {
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-rows: auto auto;
  gap: 10px 16px;
  padding: 10px 18px 0;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 92%, var(--bg));
}

.top-nav {
  grid-column: 1 / -1;
  grid-row: 2;
  display: flex;
  align-items: flex-end;
  width: 100%;
  min-height: 45px;
  gap: 0;
  justify-content: flex-start;
  border: 0;
  border-top: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
  padding: 8px 0 0;
  overflow-x: auto;
}

.top-nav .tab {
  position: relative;
  display: inline-grid;
  grid-template-columns: auto;
  min-width: 148px;
  min-height: 44px;
  border: 1px solid var(--line);
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  background: color-mix(in srgb, var(--control-bg) 88%, var(--surface));
  padding: 8px 14px 10px;
  text-align: left;
}

.top-nav .tab::before {
  display: none;
}

.top-nav .tab::after {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 3px;
  background: transparent;
}

.top-nav .tab.active {
  z-index: 1;
  background: var(--bg);
  border-color: var(--accent-line);
  box-shadow: 0 -1px 0 var(--accent-line);
}

.top-nav .tab.active::after {
  background: var(--accent);
}

.team-profile-card,
.team-create-form {
  display: grid;
  gap: 12px;
}

.team-profile-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.86fr) minmax(320px, 1.14fr);
  gap: 12px;
  align-items: start;
}

.team-create-modal {
  width: min(980px, calc(100vw - 32px));
}

.team-picker-panel {
  display: grid;
  gap: 10px;
}

.team-agent-picker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 8px;
  max-height: 340px;
  overflow: auto;
  padding-right: 4px;
}

.team-agent-option {
  display: grid;
  grid-template-columns: auto 34px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--control-bg);
  padding: 8px;
}

.team-agent-option:hover,
.team-agent-option:has(input:checked) {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.team-agent-option input {
  width: auto;
}

.team-agent-option strong,
.team-agent-option small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-agent-option small,
.team-agent-option em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
}

.team-template-member-edit {
  display: grid;
  gap: 9px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--control-bg);
  padding: 10px;
}

.team-template-member-main {
  display: grid;
  grid-template-columns: 28px 34px minmax(0, 1fr) 34px;
  gap: 8px;
  align-items: center;
}

.team-template-member-main strong,
.team-template-member-main small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.team-template-member-main small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.team-template-member-fields {
  display: grid;
  grid-template-columns: minmax(140px, 0.7fr) minmax(180px, 1fr) minmax(140px, 0.7fr) minmax(140px, 0.7fr);
  gap: 8px;
}

.team-template-member-fields .wide {
  grid-column: 1 / -1;
}

.team-template-member-fields select[multiple] {
  min-height: 84px;
}

.team-template-member-details {
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: color-mix(in srgb, var(--surface) 70%, var(--control-bg));
  padding: 8px;
}

.team-template-member-details summary {
  cursor: pointer;
  color: var(--ink);
  font-size: 12px;
  font-weight: 1000;
}

.team-template-member-fields.expanded {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 8px;
}

.team-template-member-compact {
  display: grid;
  grid-template-columns: minmax(130px, 0.65fr) minmax(190px, 1fr) minmax(160px, 0.9fr);
  gap: 8px;
}

.team-template-member-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.template-member-picker-modal {
  width: min(1040px, calc(100vw - 32px));
  max-height: 90vh;
  overflow: auto;
}

.template-member-picker-layout {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(320px, 1.1fr);
  gap: 12px;
  min-height: 460px;
}

.template-picker-list {
  display: grid;
  align-content: start;
  gap: 8px;
  max-height: 58vh;
  overflow: auto;
  padding-right: 4px;
}

.template-picker-card {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 9px;
  align-items: center;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--control-bg);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.template-picker-card:hover,
.template-picker-card.active {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.template-picker-card strong,
.template-picker-card small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.template-picker-card small,
.template-picker-card em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.template-picker-card.active em {
  color: var(--accent);
}

.template-picker-preview,
.quick-agent-template-form {
  display: grid;
  align-content: start;
  gap: 12px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 72%, var(--control-bg));
  padding: 12px;
}

.template-picker-preview p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.agent-chat-archive-modal {
  width: min(1120px, calc(100vw - 28px));
  max-height: 92vh;
}

.agent-chat-archive-layout {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 12px;
  min-height: 620px;
}

.agent-chat-archive-sidebar,
.agent-chat-archive-thread {
  min-height: 0;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 10px;
}

.agent-chat-archive-sidebar {
  overflow: auto;
}

.agent-chat-archive-thread {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 10px;
}

.message-list.readonly {
  min-height: 0;
  max-height: 58vh;
  overflow: auto;
  background: var(--surface);
}

.message.readonly {
  grid-template-columns: minmax(0, 1fr);
  max-width: min(760px, 86%);
}

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

.show-older-messages-btn {
  justify-self: center;
  width: fit-content;
  margin: 2px auto 8px;
  padding: 7px 10px;
}

.message.readonly.user {
  margin-left: auto;
}

.chat-context-panel.light {
  margin: 0;
  border: 0;
  background: transparent;
  padding: 0;
}

#projectsTab .project-search-form,
#chatTab .message-search-form {
  border-color: color-mix(in srgb, var(--line) 76%, transparent);
  background: color-mix(in srgb, var(--surface) 82%, var(--control-bg));
  box-shadow: none;
}

#projectsTab .portfolio-lanes,
#chatTab .thread-signals,
#chatTab .chat-context-panel {
  opacity: 0.92;
}

#projectsTab .portfolio-lane,
#projectsTab .project-detail-hero,
#projectsTab .project-timeline-panel,
#projectsTab .project-work-block,
#chatTab .chat-agent-card,
#chatTab .chat-sidebar,
#chatTab .composer,
#chatTab .agent-card-block {
  box-shadow: none;
}

#chatTab .chat-agent-card {
  gap: 10px;
}

#chatTab .agent-card-block {
  background: color-mix(in srgb, var(--surface) 80%, var(--control-bg));
}

#chatTab .chat-layout.compact-chat-layout {
  grid-template-columns: minmax(260px, 310px) minmax(0, 1fr);
}

#chatTab .chat-layout.compact-chat-layout.with-thread-pane {
  grid-template-columns: minmax(230px, 290px) minmax(0, 1fr) minmax(300px, 380px);
}

#chatTab .chat-panel {
  grid-template-rows: auto minmax(320px, 1fr) auto;
  gap: 10px;
}

#chatTab .chat-panel.has-tool-panel {
  grid-template-rows: auto auto minmax(320px, 1fr) auto;
}

.chat-thread-header {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 82%, var(--control-bg));
  padding: 9px;
}

.chat-header-agent {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  min-width: 0;
  border: 1px solid transparent;
  background: transparent;
  color: var(--ink);
  padding: 5px;
  text-align: left;
}

.chat-header-agent:hover,
.chat-header-agent:focus-visible {
  border-color: var(--accent-line);
  background: var(--active-fill);
}

.chat-header-agent strong,
.chat-header-agent small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-header-agent small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.chat-header-status,
.chat-header-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  justify-content: flex-end;
}

.compact-action {
  min-height: 32px;
  padding: 6px 9px;
}

.compact-action.active,
.chat-thread-filter-btn.active {
  border-color: var(--accent-line);
  background: var(--active-fill);
  color: var(--accent);
}

.chat-tool-panel {
  display: grid;
  gap: 10px;
  border: 1px solid var(--accent-line);
  background: color-mix(in srgb, var(--surface) 88%, var(--control-bg));
  padding: 10px;
}

.chat-tool-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.chat-thread-panel-body,
.chat-files-panel,
.chat-info-panel {
  display: grid;
  gap: 10px;
}

.segmented-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.chat-thread-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 8px;
}

.chat-file-row {
  display: grid;
  gap: 4px;
}

.chat-file-row > small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.chat-info-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.chat-info-grid > div {
  display: grid;
  gap: 3px;
  border: 1px solid var(--line);
  background: var(--control-bg);
  padding: 8px;
}

.chat-info-grid span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 1000;
  text-transform: uppercase;
}

.chat-info-grid strong {
  min-width: 0;
  overflow: hidden;
  color: var(--ink);
  font-size: 13px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.agent-card-block.flat {
  border-color: var(--line);
  background: var(--control-bg);
}

.message-thread-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin-top: 8px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 78%, var(--control-bg));
  color: var(--ink);
  padding: 5px 8px;
  font-size: 11px;
  font-weight: 950;
}

.message-thread-link:hover,
.message-thread-link:focus-visible {
  border-color: var(--accent-line);
  background: var(--active-fill);
  color: var(--accent);
}

.message-thread-link em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  text-transform: uppercase;
}

.chat-thread-pane {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  gap: 10px;
  min-height: 0;
  max-height: calc(100vh - 138px);
  border: 1px solid var(--accent-line);
  background: color-mix(in srgb, var(--surface) 86%, var(--control-bg));
  padding: 10px;
  overflow: hidden;
}

.chat-thread-pane.archive-thread-pane {
  max-height: none;
}

.chat-thread-pane-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: start;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
}

.chat-thread-pane-head h3,
.chat-thread-pane-head p {
  margin: 0;
}

.thread-root-message {
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
}

.thread-reply-list {
  display: grid;
  align-content: start;
  gap: 9px;
  min-height: 0;
  overflow: auto;
  padding-right: 2px;
}

.thread-composer {
  padding: 8px;
}

.thread-composer textarea {
  min-height: 48px;
}

.chat-thread-pane .message {
  max-width: 100%;
  margin: 0;
  padding: 9px;
}

.agent-chat-archive-layout.with-thread-pane {
  grid-template-columns: 260px minmax(0, 1fr) minmax(300px, 380px);
}

#chatTab .thread-signals {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  border: 0;
  background: transparent;
  padding: 0;
}

#chatTab .thread-signals > div {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  min-height: 28px;
  border-color: color-mix(in srgb, var(--line) 72%, transparent);
  background: color-mix(in srgb, var(--surface) 72%, transparent);
  padding: 5px 8px;
}

#chatTab .thread-signals span {
  font-size: 10px;
}

#chatTab .thread-signals strong {
  font-size: 14px;
}

#chatTab .message-search-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
  padding: 8px;
}

#chatTab .message-list {
  min-height: 260px;
}

@media (max-width: 1120px) {
  .app-topbar {
    grid-template-columns: 1fr;
  }

  .top-nav {
    justify-content: start;
    overflow-x: auto;
  }

  .agent-workspace-layout {
    grid-template-columns: 1fr;
  }

  .agent-workspace-nav {
    position: static;
  }

  .agent-mode-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .org-agent-filterbar {
    grid-template-columns: 1fr;
  }

  .team-profile-grid {
    grid-template-columns: 1fr;
  }

  .org-filter-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 760px) {
  .top-nav .tab {
    min-width: 104px;
  }

  .agent-modal-grid.edit,
  .agent-modal-grid.context,
  .agent-modal-grid,
  .team-member-edit-row,
  .agent-list-open,
  .org-filter-search,
  .team-tree-leaf,
  .team-template-member-preview,
  .team-agent-option,
  .team-template-member-main,
  .team-template-member-fields,
  .team-template-member-compact,
  .template-member-picker-layout,
  .agent-chat-archive-layout {
    grid-template-columns: 1fr;
  }

  .agent-card-modal {
    width: calc(100vw - 20px);
    max-height: 92vh;
  }

  .chat-thread-header,
  .chat-tool-form,
  .chat-info-grid,
  #chatTab .chat-layout.compact-chat-layout.with-thread-pane,
  .agent-chat-archive-layout.with-thread-pane {
    grid-template-columns: 1fr;
  }

  .chat-header-status,
  .chat-header-actions {
    justify-content: flex-start;
  }

  .agent-modal-actions,
  .agent-modal-savebar {
    justify-content: flex-start;
  }
}
