/* ===== Deal Cockpit — 4-zone layout ===== */

.cockpit {
  display: grid;
  grid-template-columns: var(--rail-left-w) 1fr var(--rail-right-w);
  grid-template-rows: auto 1fr auto;
  grid-template-areas:
    "header header header"
    "rail-l center rail-r"
    "memo memo memo";
  gap: 0;
  height: calc(100vh - var(--header-h));
  min-height: 0;
  background: var(--cream);
}

.cockpit-header {
  grid-area: header;
  padding: 12px 20px;
  border-bottom: 1px solid var(--rule);
  background: var(--cream-2);
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.cockpit-header .target-block { display: flex; flex-direction: column; gap: 2px; }
.cockpit-header .target-name {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--navy);
  font-weight: 500;
  line-height: 1.1;
}
.cockpit-header .target-meta {
  font-family: var(--font-sc);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--gold);
  text-transform: uppercase;
}
.cockpit-header .deal-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0 14px;
  border-left: 1px solid var(--rule-light);
}
.cockpit-header .deal-stat:first-of-type { border-left: none; padding-left: 0; }
.cockpit-header .deal-stat .stat-label {
  font-family: var(--font-sc);
  font-size: 8px;
  letter-spacing: 0.22em;
  color: var(--ink-faint);
  text-transform: uppercase;
}
.cockpit-header .deal-stat .stat-value {
  font-family: var(--font-display);
  font-size: 16px;
  color: var(--navy);
  font-weight: 500;
}
.cockpit-header .header-actions { margin-left: auto; display: flex; gap: 8px; align-items: center; }

/* ==== Left rail — phase navigation ==== */
.left-rail {
  grid-area: rail-l;
  background: var(--cream-2);
  border-right: 1px solid var(--rule-light);
  overflow-y: auto;
  padding: 12px 0;
  font-size: 12px;
}
.phase-block {
  border-bottom: 1px solid var(--rule-light);
  padding: 6px 0;
}
.phase-block:last-child { border-bottom: none; }
.phase-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  cursor: pointer;
  user-select: none;
  color: var(--navy);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 13px;
}
.phase-header:hover { background: var(--cream-3); }
.phase-header .phase-caret {
  font-size: 9px;
  color: var(--ink-faint);
  transition: transform 0.12s;
}
.phase-header.collapsed .phase-caret { transform: rotate(-90deg); }
.phase-header .phase-num {
  font-family: var(--font-sc);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--gold);
}
.phase-header .phase-progress {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
}
.phase-progress.complete { color: var(--positive); }

.phase-agents { padding: 4px 0; }
.phase-block.collapsed .phase-agents { display: none; }

.agent-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 14px 5px 28px;
  cursor: pointer;
  user-select: none;
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--ink-mid);
  border-left: 2px solid transparent;
  transition: background 0.08s, border-color 0.08s;
}
.agent-row:hover { background: var(--cream-3); color: var(--navy); }
.agent-row.active {
  background: var(--gold-08);
  border-left-color: var(--gold);
  color: var(--navy);
  font-weight: 500;
}
.agent-row .agent-name {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.agent-row .agent-num {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
  min-width: 24px;
}
.agent-row .agent-cost {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--gold-dk);
}

/* ==== Center panel — focus pane ==== */
.focus-panel {
  grid-area: center;
  overflow-y: auto;
  padding: 18px 24px;
  background: var(--cream);
  min-width: 0;
}
.focus-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 40px;
  color: var(--ink-faint);
  text-align: center;
}
.focus-empty .empty-icon {
  font-size: 48px;
  font-family: var(--font-display);
  color: var(--gold-30);
  margin-bottom: 12px;
}

.agent-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule);
  gap: 14px;
}
.agent-detail-header .agent-title {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--navy);
  font-weight: 500;
}
.agent-detail-header .agent-mission {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 13px;
  color: var(--ink-faint);
  margin-top: 4px;
}
.agent-detail-header .agent-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  font-family: var(--font-sc);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--gold-dk);
  text-transform: uppercase;
  margin-top: 8px;
}

.section-block {
  margin-bottom: 22px;
  background: var(--cream-2);
  border: 1px solid var(--gold-15);
  padding: 14px 18px;
}
.section-block .section-title {
  font-family: var(--font-sc);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--gold-dk);
  text-transform: uppercase;
  margin-bottom: 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--rule-light);
}
.section-block pre {
  font-family: var(--font-mono);
  font-size: 11px;
  background: var(--cream);
  border: 1px solid var(--rule-light);
  padding: 10px 12px;
  overflow-x: auto;
  margin: 0;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--navy);
  line-height: 1.5;
}

.scratchpad {
  font-family: var(--font-mono);
  font-size: 10.5px;
  max-height: 280px;
  overflow-y: auto;
  background: var(--navy-dk);
  color: #C9D5E1;
  padding: 12px 14px;
  border: 1px solid var(--navy);
}
.scratchpad .scratch-line { padding: 1px 0; }
.scratchpad .scratch-line.thinking { color: #C9AA72; font-style: italic; }
.scratchpad .scratch-line.tool { color: #7AB5C9; }
.scratchpad .scratch-line.error { color: #E89090; }

.citation-list { display: flex; flex-direction: column; gap: 6px; }
.citation-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  background: var(--cream);
  border: 1px solid var(--gold-30);
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--gold-dk);
  cursor: pointer;
  transition: all 0.12s;
}
.citation-chip:hover {
  background: var(--gold-08);
  border-color: var(--gold);
  color: var(--navy);
}
.citation-chip .chip-icon { font-family: var(--font-sc); font-size: 9px; letter-spacing: 0.1em; }
.citation-chip .chip-source { font-family: var(--font-mono); color: var(--ink-faint); font-size: 10px; }

.retry-history {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-soft);
}
.retry-history .retry-entry {
  display: flex;
  gap: 12px;
  padding: 5px 0;
  border-bottom: 1px dashed var(--rule-light);
}
.retry-history .retry-time { color: var(--ink-faint); min-width: 80px; }
.retry-history .retry-status { min-width: 80px; }
.retry-history .retry-cost { color: var(--gold-dk); }

/* ==== Right rail — activity ==== */
.right-rail {
  grid-area: rail-r;
  background: var(--cream-2);
  border-left: 1px solid var(--rule-light);
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
}
.rail-tabs {
  display: flex;
  border-bottom: 1px solid var(--rule);
  background: var(--cream);
}
.rail-tab {
  flex: 1;
  padding: 9px 8px;
  font-family: var(--font-sc);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--ink-faint);
  cursor: pointer;
  border: none;
  background: transparent;
  border-bottom: 2px solid transparent;
  text-transform: uppercase;
}
.rail-tab:hover { color: var(--ink-mid); }
.rail-tab.active { color: var(--gold-dk); border-bottom-color: var(--gold); }
.rail-tab .tab-count {
  margin-left: 4px;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-faint);
}
.rail-tab.active .tab-count { color: var(--gold); }

.rail-content {
  flex: 1;
  overflow-y: auto;
  padding: 10px 14px;
}

.feed-item {
  display: flex;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--rule-light);
  font-family: var(--font-ui);
  font-size: 12px;
}
.feed-item .feed-icon {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sc);
  font-size: 9px;
  background: var(--cream-3);
  color: var(--gold-dk);
}
.feed-item.event-agent .feed-icon { background: var(--status-running-bg); color: var(--status-running); }
.feed-item.event-citation .feed-icon { background: var(--gold-08); color: var(--gold-dk); }
.feed-item.event-comment .feed-icon { background: var(--positive-bg); color: var(--positive); }
.feed-item.event-action .feed-icon { background: var(--warning-bg); color: var(--neutral); }
.feed-item.event-error .feed-icon { background: var(--negative-bg); color: var(--negative); }
.feed-item .feed-body { flex: 1; min-width: 0; color: var(--ink-mid); line-height: 1.4; }
.feed-item .feed-body strong { color: var(--navy); font-weight: 600; }
.feed-item .feed-time {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
  flex-shrink: 0;
}

.comment-thread {
  background: var(--cream);
  border: 1px solid var(--gold-15);
  padding: 10px 12px;
  margin-bottom: 10px;
}
.comment {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--ink-mid);
  margin-bottom: 6px;
  line-height: 1.5;
}
.comment-meta {
  font-family: var(--font-ui);
  font-size: 10px;
  color: var(--ink-faint);
  display: flex;
  gap: 6px;
  align-items: center;
  margin-bottom: 4px;
}
.comment-meta .author {
  font-weight: 600;
  color: var(--navy);
  font-size: 11px;
}
.comment-mention { color: var(--gold-dk); font-weight: 500; }
.comment-reply {
  margin-top: 6px;
  padding-left: 12px;
  border-left: 2px solid var(--gold-15);
}
.comment-input {
  width: 100%;
  min-height: 60px;
  padding: 8px 10px;
  border: 1px solid var(--gold-15);
  background: var(--cream);
  font-family: var(--font-body);
  font-size: 13px;
  resize: vertical;
}
.comment-input:focus { outline: none; border-color: var(--gold); }
.comment-actions {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-top: 6px;
}
.comment-actions .voice-btn {
  background: transparent;
  border: 1px solid var(--gold-15);
  color: var(--gold-dk);
  padding: 4px 8px;
  font-size: 14px;
  cursor: pointer;
}
.comment-actions .voice-btn.recording { background: var(--negative-bg); color: var(--negative); border-color: var(--negative); animation: pulse 1s infinite; }

.action-item {
  display: flex;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--rule-light);
}
.action-item input[type="checkbox"] { margin-top: 3px; }
.action-item .action-body {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--ink-mid);
  line-height: 1.4;
  flex: 1;
}
.action-item.done .action-body { color: var(--ink-faint); text-decoration: line-through; }
.action-item .action-meta {
  font-family: var(--font-ui);
  font-size: 10px;
  color: var(--ink-faint);
  margin-top: 3px;
}

/* ==== Bottom memo zone ==== */
.memo-zone {
  grid-area: memo;
  background: var(--cream-2);
  border-top: 1px solid var(--rule);
  padding: 12px 24px;
  max-height: 32vh;
  overflow-y: auto;
}
.memo-zone .memo-zone-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.memo-zone .memo-zone-title {
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--navy);
  font-weight: 500;
}
.memo-zone .memo-zone-title em { color: var(--gold-dk); font-style: italic; }
.memo-zone .memo-zone-sub {
  font-family: var(--font-sc);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--gold);
}
.memo-zone .memo-draft {
  font-family: var(--font-body);
  font-size: 13.5px;
  color: var(--ink-mid);
  line-height: 1.55;
  background: var(--cream);
  border: 1px solid var(--rule-light);
  padding: 12px 18px;
  max-height: 200px;
  overflow-y: auto;
}
.memo-zone .memo-draft h3 {
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--navy);
  margin: 10px 0 4px;
  font-weight: 600;
}
.memo-zone .memo-draft p { margin: 0 0 8px; }

/* ==== Citation drawer ==== */
.drawer-header {
  display: flex;
  align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid var(--rule);
  background: var(--cream-2);
  gap: 12px;
}
.drawer-header .drawer-title {
  font-family: var(--font-display);
  font-size: 16px;
  color: var(--navy);
  font-weight: 500;
  flex: 1;
}
.drawer-header .drawer-sub {
  font-family: var(--font-sc);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--gold);
}
.drawer-close {
  background: transparent;
  border: 1px solid var(--rule);
  width: 28px;
  height: 28px;
  font-size: 18px;
  line-height: 1;
  color: var(--ink-faint);
  cursor: pointer;
}
.drawer-close:hover { background: var(--negative-bg); color: var(--negative); border-color: var(--negative); }

.drawer-body {
  flex: 1;
  overflow: auto;
  background: var(--navy-faint);
  position: relative;
}
.pdf-viewer {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  padding: 14px;
}
.pdf-viewer canvas {
  box-shadow: var(--shadow-soft);
  background: white;
  max-width: 100%;
}
.pdf-highlight-layer {
  position: absolute;
  pointer-events: none;
}
.pdf-highlight {
  position: absolute;
  background: rgba(168, 136, 74, 0.30);
  border: 1px solid var(--gold);
}

.xlsx-viewer {
  padding: 14px;
  overflow: auto;
}
.xlsx-viewer table {
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 11px;
  background: white;
}
.xlsx-viewer th, .xlsx-viewer td {
  padding: 4px 8px;
  border: 1px solid #DDD;
  text-align: right;
  min-width: 60px;
}
.xlsx-viewer th { background: var(--cream-3); color: var(--navy); font-weight: 600; text-align: center; }
.xlsx-viewer td.highlighted { background: var(--gold-08); outline: 2px solid var(--gold); outline-offset: -2px; }

.drawer-footer {
  display: flex;
  gap: 8px;
  padding: 14px 18px;
  border-top: 1px solid var(--rule);
  background: var(--cream-2);
  justify-content: space-between;
  align-items: center;
}
.drawer-footer .footer-info {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-soft);
}
.drawer-footer .footer-actions { display: flex; gap: 8px; }

/* ==== Override modal ==== */
.override-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 14px 0 18px;
}
.override-option {
  display: flex;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--gold-15);
  background: var(--cream-2);
  cursor: pointer;
  transition: all 0.12s;
}
.override-option:hover { border-color: var(--gold); background: var(--gold-08); }
.override-option.selected { border-color: var(--gold); background: var(--gold-08); }
.override-option input[type="radio"] { margin-top: 2px; }
.override-option .option-label {
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--navy);
  font-weight: 500;
}
.override-option .option-desc {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--ink-soft);
  font-style: italic;
  margin-top: 2px;
}

/* ==== Kanban (pipeline) ==== */
.kanban {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 12px;
  align-items: flex-start;
}
.kanban-col {
  min-width: 260px;
  max-width: 280px;
  background: var(--cream-2);
  border: 1px solid var(--gold-15);
  flex-shrink: 0;
}
.kanban-col-header {
  padding: 10px 14px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.kanban-col-title {
  font-family: var(--font-sc);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--gold-dk);
  text-transform: uppercase;
}
.kanban-col-count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-faint);
}
.kanban-col-body { padding: 8px; min-height: 200px; }
.kanban-card {
  background: var(--cream);
  border: 1px solid var(--gold-15);
  padding: 10px 12px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
}
.kanban-card:hover { border-color: var(--gold); }
.kanban-card .card-target {
  font-family: var(--font-display);
  font-size: 15px;
  color: var(--navy);
  font-weight: 500;
  margin-bottom: 3px;
}
.kanban-card .card-meta {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-faint);
}
.kanban-card .card-meta .ev { font-family: var(--font-mono); color: var(--gold-dk); }

/* ==== Kbd help overlay ==== */
.kbd-overlay {
  position: fixed;
  inset: 0;
  background: rgba(26, 44, 61, 0.65);
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.kbd-help {
  background: var(--cream);
  border: 1px solid var(--gold);
  padding: 26px 30px;
  width: 560px;
  max-width: 92vw;
  max-height: 86vh;
  overflow-y: auto;
}
.kbd-help h3 {
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--navy);
  margin-bottom: 14px;
}
.kbd-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  border-bottom: 1px dashed var(--rule-light);
}
.kbd-row .kbd-desc {
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--ink-mid);
}
.kbd-row .kbd-keys { display: flex; gap: 4px; }
.kbd {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  background: var(--cream-3);
  border: 1px solid var(--gold-30);
  padding: 2px 7px;
  border-radius: 3px;
  color: var(--navy);
  box-shadow: 0 1px 0 var(--gold-15);
}
