/* IGNUS Design System */
/* Colours, typography and layout per ignus-ui-builder.md */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');

*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  --bg: #0C0C0C;
  --sidebar: #141414;
  --card: #1A1A1A;
  --card-raised: #1E1E1E;
  --border: #2A2A2A;
  --border-subtle: #222222;
  --text-primary: #ECECEC;
  --text-secondary: #7A7A7A;
  --text-heading: #FFFFFF;
  --accent: #F5F5F5;
  --input-bg: #111111;
  --radius-card: 10px;
  --radius-input: 8px;
  --radius-btn: 6px;
}

html, body {
  height: 100%;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--text-primary);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Scrollbar ── */

* {
  scrollbar-width: thin;
  scrollbar-color: #2A2A2A transparent;
}

::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: #2A2A2A;
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: #3A3A3A;
}

::-webkit-scrollbar-corner {
  background: transparent;
}

/* ── App Shell Grid ── */

.app-shell {
  display: grid;
  grid-template-columns: 240px 1fr 340px;
  height: 100vh;
}

/* ── Sidebar ── */

.sidebar {
  background: var(--sidebar);
  border-right: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  padding: 24px 0;
  overflow-y: auto;
}

.sidebar-brand {
  padding: 0 20px 28px;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--text-heading);
}

.sidebar-brand span {
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 400;
  display: block;
  margin-top: 6px;
  letter-spacing: 0.02em;
}

/* Role selector */

.role-selector {
  margin: 0 16px 24px;
  padding: 9px 12px;
  background: var(--input-bg);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  appearance: none;
  cursor: pointer;
  outline: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%236B6B6B' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  transition: border-color 0.15s;
}

.role-selector:hover {
  border-color: #444;
}

/* When the sidebar role selector is upgraded to IgnusDropdown, the
   wrapper sits where the native <select> was. Match the original
   margin so the layout doesn't shift. */
.sidebar > .ignus-dd {
  margin: 0 16px 24px;
  width: calc(100% - 32px);
}

/* Nav items */

.sidebar-nav {
  list-style: none;
  flex: 1;
}

.sidebar-nav li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 20px;
  margin: 1px 0;
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 13px;
  font-weight: 400;
  transition: background 0.15s, color 0.15s;
}

.sidebar-nav li a:hover {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-primary);
}

.sidebar-nav li a.active {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-heading);
  font-weight: 500;
  border-left: 2px solid var(--text-heading);
  padding-left: 18px;
}

.sidebar-nav li a .nav-icon {
  width: 16px;
  height: 16px;
  opacity: 0.45;
  flex-shrink: 0;
}

.sidebar-nav li a:hover .nav-icon {
  opacity: 0.7;
}

.sidebar-nav li a.active .nav-icon {
  opacity: 0.9;
}

.sidebar-footer {
  padding: 16px 20px;
  border-top: 1px solid var(--border-subtle);
  margin-top: auto;
}

.sidebar-footer .user-info {
  font-size: 13px;
  color: var(--text-secondary);
}

.sidebar-footer .user-info strong {
  color: var(--text-primary);
  font-weight: 500;
  display: block;
  margin-bottom: 2px;
}

.btn-logout {
  margin-top: 10px;
  width: 100%;
  padding: 8px 12px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-btn);
  color: var(--text-secondary);
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s;
}

.btn-logout:hover {
  color: var(--text-primary);
  border-color: var(--text-secondary);
}

/* ── Main Workspace ── */

.workspace {
  display: flex;
  flex-direction: column;
  padding: 32px 36px;
  overflow-y: auto;
  gap: 20px;
}

.workspace-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.workspace-header h1 {
  font-size: 28px;
  font-weight: 600;
}

.workspace-actions {
  display: flex;
  gap: 10px;
}

/* Buttons */

.btn-primary {
  background: var(--accent);
  color: #0C0C0C;
  border: none;
  padding: 8px 16px;
  border-radius: var(--radius-btn);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, box-shadow 0.15s;
  letter-spacing: 0.01em;
}

.btn-primary:hover {
  background: #FFFFFF;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1);
}
.btn-primary:focus-visible { box-shadow: 0 0 0 2px rgba(96,165,250,0.6); }

.btn-secondary {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-primary);
  border: 1px solid var(--border);
  padding: 8px 16px;
  border-radius: var(--radius-btn);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  letter-spacing: 0.01em;
}

.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: #444;
}
.btn-secondary:focus-visible { box-shadow: 0 0 0 2px rgba(96,165,250,0.5);
}

/* Cards */

.card {
  background: var(--card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-card);
  padding: 20px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2), 0 0 0 1px rgba(255, 255, 255, 0.02) inset;
}

.card-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-heading);
  margin-bottom: 12px;
  letter-spacing: 0.01em;
}

.card-label {
  font-size: 11px;
  color: var(--text-secondary);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Tight card variant (query input) */

.card-tight {
  padding: 12px 16px;
}

/* Query input */

.query-input-wrap {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.query-input {
  flex: 1;
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-input);
  padding: 10px 14px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  outline: none;
  resize: none;
  min-height: 40px;
  max-height: 120px;
  transition: border-color 0.15s;
}

.query-input::placeholder {
  color: var(--text-secondary);
}

.query-input:focus {
  border-color: var(--text-secondary);
}

.query-inline-btn {
  flex-shrink: 0;
  align-self: flex-end;
  padding: 10px 16px;
}

/* Answer panel */

.answer-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.answer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.answer-header .card-title {
  margin-bottom: 0;
}

.answer-status {
  font-size: 11px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.answer-divider {
  height: 1px;
  background: var(--border-subtle);
  margin: 12px 0 16px;
}

.answer-panel .answer-body {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.7;
  flex: 1;
}

/* ── Context Panel (right side) ── */

.context-panel {
  background: #161616;
  border-left: 1px solid rgba(255, 255, 255, 0.08);
  padding: 28px 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
}

.panel-section-label {
  font-size: 11px;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 4px;
}

.placeholder-box {
  background: var(--card);
  border: 1px dashed var(--border);
  border-radius: var(--radius-card);
  padding: 40px 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  font-size: 13px;
  text-align: center;
  min-height: 160px;
}

.placeholder-compact {
  padding: 24px 16px;
  min-height: 100px;
  font-size: 12px;
}

/* Compact card (context panel) */

.card-compact {
  padding: 12px;
}

/* Action button list */

.action-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.btn-action {
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
  padding: 7px 10px;
  border-radius: 5px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 400;
  text-align: left;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.btn-action:hover {
  color: var(--text-primary);
  border-color: #444;
  background: rgba(255, 255, 255, 0.06);
}

/* ── Dashboard ── */

/* Welcome */

.welcome-section {
  margin-bottom: 4px;
}

.welcome-section h1 {
  font-size: 24px;
  font-weight: 600;
  color: var(--text-heading);
}

.welcome-role {
  font-size: 12px;
  color: var(--text-secondary);
  margin-top: 5px;
  letter-spacing: 0.02em;
}

/* Summary cards row */

.summary-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.summary-card {
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: var(--card-raised);
}

.summary-value {
  font-size: 28px;
  font-weight: 600;
  line-height: 1;
  color: var(--text-heading);
}

.summary-label {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 6px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.summary-card-clickable {
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.1s;
}
.summary-card-clickable:hover {
  border-color: #3A3A3A;
  background: var(--card-raised-hover, #1E1E1E);
}
.summary-card-clickable:active {
  transform: scale(0.99);
}

/* Quick actions */

.quick-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.quick-actions-row {
  display: flex;
  gap: 10px;
}

/* Activity feed */

.activity-card {
  flex: 1;
}

.activity-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.activity-header .card-title {
  margin-bottom: 0;
}

.activity-list {
  list-style: none;
}

.activity-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 11px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.activity-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.activity-item:first-child {
  padding-top: 0;
}

.activity-badge {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 4px 8px;
  border-radius: 4px;
  margin-top: 1px;
}

.badge-query {
  background: rgba(255, 255, 255, 0.07);
  color: var(--text-primary);
}

.badge-rfi {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border);
}

/* Task status badges */
.badge-open { background: rgba(59,130,246,0.12); color: #3B82F6; }
.badge-in-progress { background: rgba(245,158,11,0.12); color: #F59E0B; }
.badge-waiting { background: rgba(168,162,158,0.12); color: #A8A29E; }
.badge-done { background: rgba(34,197,94,0.12); color: #22C55E; }
.badge-cancelled { background: rgba(120,113,108,0.08); color: #78716C; text-decoration: line-through; }

/* Task priority — shared color tokens */
.badge-priority-low { background: rgba(148,163,184,0.10); color: #94A3B8; }
.badge-priority-medium { background: rgba(59,130,246,0.10); color: #3B82F6; }
.badge-priority-high { background: rgba(245,158,11,0.12); color: #F59E0B; }
.badge-priority-critical { background: rgba(239,68,68,0.14); color: #EF4444; font-weight: 600; }

/* Priority-tinted selects (drawer / modal) */
.priority-tint-low { color: #94A3B8; }
.priority-tint-medium { color: #3B82F6; }
.priority-tint-high { color: #F59E0B; }
.priority-tint-critical { color: #EF4444; }

/* Task table — readability tightening */
.task-title-text {
  display: inline-block; max-width: 280px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  vertical-align: middle;
}
.task-cell-assignee {
  max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.task-cell-source {
  max-width: 180px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.task-source-text {
  display: inline; vertical-align: middle;
}
.task-due-overdue {
  color: #EF4444; font-weight: 600;
}
.task-drawer-due-overdue {
  border-color: rgba(239,68,68,0.4) !important;
  color: #EF4444 !important;
}

/* Tasks empty state */
.empty-state { padding: 48px 24px; text-align: center; }
.empty-state-title { font-size: 15px; font-weight: 600; color: var(--text-primary); margin-bottom: 6px; }
.empty-state-text { font-size: 13px; color: var(--text-secondary); }

/* Task drawer */
/* ── Task Detail Drawer ── */

.task-drawer-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0, 0, 0, 0.55);
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease;
}
.task-drawer-overlay.open { opacity: 1; pointer-events: auto; }

.task-drawer {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: 480px; max-width: 90vw;
  background: var(--card);
  border-left: 1px solid var(--border);
  box-shadow: -8px 0 24px rgba(0, 0, 0, 0.4);
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
}
.task-drawer-overlay.open .task-drawer { transform: translateX(0); }

/* Header */
.task-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}
.task-drawer-title {
  font-size: 13px; font-weight: 500; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.05em;
  margin: 0;
}

/* Body */
.task-drawer-body {
  flex: 1; overflow-y: auto;
  padding: 20px 24px 0;
}

/* Sections + rows */
.task-drawer-section { margin-bottom: 16px; }
.task-drawer-row {
  display: flex; gap: 16px; margin-bottom: 16px;
}
.task-drawer-field { flex: 1; min-width: 0; }
.task-drawer-select { width: 100%; }

/* Labels — match builder pattern */
.task-drawer-body .builder-label {
  font-size: 11px; font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 6px; display: block;
}

/* Inputs — inherit builder dark styling */
.task-drawer-body .builder-input,
.task-drawer-body .builder-select,
.task-drawer-body .builder-textarea {
  background: var(--input-bg);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-input);
  padding: 10px 12px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
}
.task-drawer-body .builder-input:focus,
.task-drawer-body .builder-select:focus,
.task-drawer-body .builder-textarea:focus {
  border-color: #444;
}

/* Title input — larger, bolder, feels like anchor */
.task-drawer-body #taskDrawerTitleInput {
  font-size: 15px; font-weight: 600;
  color: var(--text-heading);
  padding: 10px 12px;
}

/* Meta row */
.task-drawer-meta {
  font-size: 11px; color: var(--text-secondary); margin: 0;
  line-height: 1.5;
}
.task-drawer-meta-row {
  margin-bottom: 12px;
  padding-top: 2px;
}

/* Status + priority row */
.task-drawer-status-row { margin-bottom: 20px; }
.task-status-actions {
  display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px;
}
.task-status-btn {
  font-size: 11px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 5px 12px; border-radius: var(--radius-btn);
  border: 1px solid var(--border-subtle);
  background: transparent; color: var(--text-secondary);
  cursor: pointer; transition: all 0.15s ease;
}
.task-status-btn:hover {
  border-color: #444; color: var(--text-primary);
  background: rgba(255, 255, 255, 0.03);
}
.task-status-btn.active {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-heading);
  border-color: rgba(255, 255, 255, 0.2);
}
.task-status-btn:disabled {
  opacity: 0.3; cursor: not-allowed;
}

/* Description — tighter in drawer */
.task-drawer-body .builder-textarea {
  min-height: 72px;
}

/* Action area — sticky at bottom */
.task-drawer-actions {
  display: flex; gap: 10px; align-items: center;
  margin: 0; padding: 16px 24px;
  border-top: 1px solid var(--border-subtle);
  background: var(--card);
  flex-shrink: 0;
}

.btn-danger {
  font-size: 12px; font-weight: 500;
  padding: 7px 14px; border-radius: var(--radius-btn);
  border: 1px solid rgba(239, 68, 68, 0.2);
  background: transparent; color: #EF4444;
  cursor: pointer; transition: all 0.15s ease;
  letter-spacing: 0.01em;
}
.btn-danger:hover {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(239, 68, 68, 0.35);
}

/* Activity timeline */
.task-drawer-activity {
  border-top: 1px solid var(--border-subtle);
  padding-top: 20px;
  margin-top: 4px;
}
.task-drawer-activity h4 {
  font-size: 11px; font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 12px;
}

.task-activity-list {
  list-style: none; padding: 0; margin: 0;
}
.task-activity-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 7px 0; font-size: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}
.task-activity-item:last-child { border-bottom: none; }
.task-activity-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--text-secondary);
  margin-top: 6px; flex-shrink: 0;
  opacity: 0.6;
}
.task-activity-text {
  color: var(--text-primary); flex: 1;
  line-height: 1.45; font-size: 12px;
}
.task-activity-time {
  color: var(--text-secondary); white-space: nowrap;
  flex-shrink: 0; font-size: 11px;
  opacity: 0.7;
}

/* Task source context banner */
.task-source-banner {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 12px; margin-bottom: 16px;
  background: rgba(59, 130, 246, 0.06);
  border: 1px solid rgba(59, 130, 246, 0.12);
  border-radius: var(--radius-input); font-size: 12px;
  color: var(--text-primary);
}
.task-source-banner svg { color: #3b82f6; flex-shrink: 0; }

/* Source type badge in task table */
.badge-source-type {
  background: rgba(59,130,246,0.08); color: #3b82f6;
  font-size: 10px; padding: 1px 5px; border-radius: 3px;
  font-weight: 600; letter-spacing: 0.02em; text-transform: uppercase;
}

/* Source link in task drawer */
.task-source-link {
  color: #3b82f6; text-decoration: none; font-size: 12px;
  display: inline-flex; align-items: center;
}
.task-source-link:hover { text-decoration: underline; }

/* Query / RFI drawer inner styles */
.query-drawer-status { margin-bottom: 12px; }
.query-drawer-title {
  font-size: 15px; font-weight: 600; color: var(--text-heading);
  line-height: 1.4; margin: 0;
}
.query-drawer-meta-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 12px; margin-bottom: 16px;
}
.query-drawer-meta-item {
  display: flex; flex-direction: column; gap: 4px;
}
.query-drawer-meta-value {
  font-size: 13px; color: var(--text-primary);
}
.query-drawer-description {
  font-size: 13px; line-height: 1.55; color: var(--text-primary);
  margin-top: 4px;
}
.query-response-block {
  border-top: 1px solid var(--border-subtle);
  padding-top: 16px; margin-top: 8px;
}
.query-response-header {
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 8px;
}
.query-response-header svg { color: var(--text-secondary); flex-shrink: 0; }
.query-response-label {
  font-size: 12px; font-weight: 600; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.04em;
}
.query-response-meta {
  font-size: 11px; color: var(--text-secondary); opacity: 0.7;
  margin-bottom: 10px;
}
.query-response-text {
  font-size: 13px; line-height: 1.55; color: var(--text-primary);
}
.query-reply-composer textarea {
  width: 100%; min-height: 80px; max-height: 200px;
  background: var(--input-bg); color: var(--text-primary);
  border: 1px solid var(--border-subtle); border-radius: var(--radius-input);
  padding: 10px 12px; font-size: 13px; line-height: 1.5;
  font-family: inherit; resize: vertical;
  transition: border-color 0.15s;
}
.query-reply-composer textarea:focus {
  outline: none; border-color: rgba(255,255,255,0.2);
}
.query-reply-composer textarea::placeholder {
  color: var(--text-secondary); opacity: 0.6;
}
.send-reply-preview {
  background: var(--input-bg); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-input); padding: 10px 12px;
  font-size: 13px; line-height: 1.5; color: var(--text-primary);
  max-height: 120px; overflow-y: auto;
}
.query-sent-trail {
  display: flex; align-items: center; gap: 6px;
  margin-top: 10px; padding: 8px 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-btn); font-size: 11px;
  color: var(--text-secondary);
}
.query-sent-trail svg { flex-shrink: 0; opacity: 0.6; }
#sendReplyModal { z-index: 1050; }
.send-reply-status {
  padding: 10px 12px; border-radius: var(--radius-btn);
  font-size: 12px; line-height: 1.4;
}
.send-reply-status.status-sending {
  background: rgba(59,130,246,0.08); color: #60a5fa;
  border: 1px solid rgba(59,130,246,0.15);
}
.send-reply-status.status-success {
  background: rgba(34,197,94,0.08); color: #4ade80;
  border: 1px solid rgba(34,197,94,0.15);
}
.send-reply-status.status-error {
  background: rgba(239,68,68,0.08); color: #f87171;
  border: 1px solid rgba(239,68,68,0.15);
}
.rfi-drawer-subject {
  font-size: 15px; font-weight: 600; color: var(--text-heading);
  line-height: 1.4; margin: 0;
}
.rfi-drawer-number {
  font-size: 12px; color: var(--text-secondary); margin-top: 2px;
}
.rfi-drawer-section-label {
  font-size: 12px; font-weight: 600; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 6px;
}
.rfi-drawer-text {
  font-size: 13px; line-height: 1.55; color: var(--text-primary);
}
.query-drawer-meta-grid.note-meta-4 {
  grid-template-columns: 1fr 1fr;
}
#noteDrawerActions {
  display: flex; gap: 8px; padding: 16px 24px;
  border-top: 1px solid var(--border-subtle);
  flex-shrink: 0; background: var(--card);
}

/* Create task from source button */
.btn-create-task-from-source {
  display: inline-flex; align-items: center; justify-content: center;
}

.activity-content {
  min-width: 0;
}

.activity-text {
  font-size: 13px;
  color: var(--text-primary);
  line-height: 1.4;
}

.activity-meta {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 2px;
}

/* ── Dashboard Layout (no right panel) ── */

.app-shell-dashboard {
  grid-template-columns: 240px 1fr;
}

.dash-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.dash-section-label {
  font-size: 11px;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Continue Working cards */

.dash-continue-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.dash-continue-card {
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-decoration: none;
  transition: border-color 0.15s, background 0.15s;
}

.dash-continue-card:hover {
  border-color: rgba(255, 255, 255, 0.15);
  background: rgba(255, 255, 255, 0.03);
}

.dash-continue-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-heading);
  line-height: 1.3;
}

.dash-continue-meta {
  font-size: 11px;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.dash-continue-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 4px;
}

.dash-continue-stat {
  font-size: 11px;
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.05);
  padding: 2px 8px;
  border-radius: 3px;
}

.dash-continue-time {
  font-size: 10px;
  color: var(--text-secondary);
  margin-top: 4px;
}

/* Two-column dashboard layout */

.dash-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.dash-actions-card {
  flex: 1;
}

/* Action links inside activity items */

.dash-action-link {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  text-decoration: none;
  color: inherit;
  flex: 1;
}

.dash-action-link:hover .activity-text {
  color: var(--text-heading);
}

.dash-action-overdue {
  border-left: 2px solid rgba(255, 120, 100, 0.5);
  padding-left: 10px;
}

.dash-overdue-label {
  color: rgba(255, 120, 100, 0.8);
  font-weight: 500;
}

/* Sidebar notification indicator */
.sidebar-notifications {
  padding: 4px 16px 8px;
}
.sidebar-notif-link {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: 6px;
  text-decoration: none; color: var(--text-primary);
  font-size: 13px; font-weight: 500;
  background: rgba(59,130,246,0.06);
  border: 1px solid rgba(59,130,246,0.12);
  transition: background 0.15s ease;
}
.sidebar-notif-link:hover { background: rgba(59,130,246,0.12); }
.sidebar-notif-link .nav-icon {
  width: 16px; height: 16px; flex-shrink: 0;
  color: #3b82f6;
}
.sidebar-notif-label { flex: 1; }
.sidebar-notif-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 20px; height: 20px; padding: 0 5px;
  border-radius: 10px; font-size: 11px; font-weight: 700;
  background: #3b82f6; color: #fff;
  line-height: 1;
}

/* Dashboard attention card */
.dash-attention-card {
  margin-bottom: 24px;
  border: 1px solid rgba(59,130,246,0.15);
}
.dash-attention-card .card-title {
  display: flex; align-items: center;
}
.dash-attention-card .card-title svg { color: #3b82f6; }
.dash-dismiss-all {
  background: none; border: none; cursor: pointer;
  font-size: 12px; color: var(--text-secondary);
  padding: 2px 8px; border-radius: 4px;
  transition: background 0.15s ease;
}
.dash-dismiss-all:hover { background: rgba(0,0,0,0.05); }

/* Notification type badges — text labels */
.notif-badge-overdue { background: rgba(239,68,68,0.12); color: #EF4444; font-weight: 600; min-width: 56px; text-align: center; }
.notif-badge-due { background: rgba(245,158,11,0.12); color: #F59E0B; min-width: 56px; text-align: center; }
.notif-badge-assigned { background: rgba(59,130,246,0.12); color: #3b82f6; min-width: 56px; text-align: center; }
.notif-badge-status { background: rgba(34,197,94,0.12); color: #22C55E; min-width: 56px; text-align: center; }
.notif-badge-waiting { background: rgba(168,162,158,0.12); color: #A8A29E; min-width: 56px; text-align: center; }

/* Notification attention item */
.notif-attention-item {
  position: relative;
}
.notif-message-text {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 420px;
}
.notif-dismiss-btn {
  position: absolute; top: 8px; right: 4px;
  background: none; border: none; cursor: pointer;
  color: var(--text-secondary); font-size: 16px;
  width: 24px; height: 24px; display: flex;
  align-items: center; justify-content: center;
  border-radius: 4px; opacity: 0;
  transition: opacity 0.15s ease, background 0.15s ease;
}
.notif-attention-item:hover .notif-dismiss-btn { opacity: 1; }
.notif-dismiss-btn:hover { background: rgba(0,0,0,0.06); }

/* Dashboard task widgets */
.badge-task {
  background: rgba(59,130,246,0.08);
  color: #3b82f6;
}
.dash-task-section-label {
  border-bottom: none !important;
  padding-bottom: 0 !important;
}
.dash-task-section-label .activity-meta strong {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em;
  color: var(--text-secondary); opacity: 0.7;
}
.dash-task-priority-tag {
  font-size: 10px; padding: 2px 6px; flex-shrink: 0; align-self: center;
}
.dash-task-more {
  font-size: 12px; opacity: 0.6; padding: 4px 0;
}
.dash-task-activity-card {
  margin-bottom: 24px;
}

/* View all link */

.dash-view-all {
  font-size: 11px;
  color: var(--text-secondary);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  transition: color 0.15s;
}

.dash-view-all:hover {
  color: var(--text-primary);
}

@media (max-width: 1024px) {
  .app-shell-dashboard {
    grid-template-columns: 220px 1fr;
  }
  .dash-continue-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .dash-two-col {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .dash-continue-grid {
    grid-template-columns: 1fr;
  }
}

/* ── Context Panel Lists ── */

.project-list,
.rfi-list {
  list-style: none;
}

.project-item,
.rfi-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.project-item:last-child,
.rfi-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.project-item:first-child,
.rfi-item:first-child {
  padding-top: 0;
}

.project-name {
  font-size: 12px;
  color: var(--text-primary);
}

a.project-name {
  cursor: pointer;
}

a.project-name:hover {
  color: var(--text-heading);
}

.project-stat {
  font-size: 10px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}

.rfi-number {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  flex-shrink: 0;
  width: 56px;
}

.rfi-subject {
  font-size: 12px;
  color: var(--text-primary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Section titles */

.section-title {
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 4px;
}

/* Small labels */

.label {
  font-size: 12px;
  color: var(--text-secondary);
}

/* ── Page Header (shared) ── */

.page-title {
  font-size: 24px;
  font-weight: 600;
  color: var(--text-heading);
}

.page-subtitle {
  font-size: 12px;
  color: var(--text-secondary);
  margin-top: 4px;
  letter-spacing: 0.02em;
}

/* ── Projects Table ── */

.table-card {
  padding: 0;
  overflow: hidden;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.data-table thead tr {
  border-bottom: 1px solid var(--border);
}

.data-table th {
  padding: 12px 16px;
  text-align: left;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: var(--card-raised);
}

.data-table td {
  padding: 14px 16px;
  color: var(--text-primary);
  border-bottom: 1px solid var(--border-subtle);
}

.data-table tbody tr:last-child td {
  border-bottom: none;
}

.table-row {
  cursor: pointer;
  transition: background 0.12s;
}

.table-row:hover {
  background: rgba(255, 255, 255, 0.03);
}

.table-row.selected {
  background: rgba(255, 255, 255, 0.05);
}

.col-name {
  min-width: 180px;
}

.col-num {
  text-align: center !important;
  width: 80px;
}

.col-date {
  width: 120px;
  color: var(--text-secondary) !important;
  font-size: 12px;
}

.col-location {
  color: var(--text-secondary);
  font-size: 12px;
}

.project-name-cell {
  font-weight: 500;
  color: var(--text-heading);
}

.project-link {
  text-decoration: none;
  color: var(--text-heading);
  transition: opacity 0.15s;
}

.project-link:hover {
  opacity: 0.8;
}

/* Status badges */

.status-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  border-radius: 4px;
}

.status-active {
  background: rgba(255, 255, 255, 0.07);
  color: var(--text-primary);
}

.status-review {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border);
}

/* ── Project Detail Panel (context panel) ── */

.detail-heading {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-heading);
}

.detail-meta {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 3px;
}

.detail-divider {
  height: 1px;
  background: var(--border-subtle);
  margin: 12px 0;
}

.detail-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.detail-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.detail-stat-value {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-heading);
}

.detail-stat-label {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Panel activity list (compact) */

.panel-activity-list {
  list-style: none;
}

.panel-activity-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 7px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.panel-activity-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.panel-activity-item:first-child {
  padding-top: 0;
}

.panel-activity-text {
  font-size: 11px;
  color: var(--text-primary);
  line-height: 1.4;
}

/* Panel detail blocks */

.panel-detail-block {
  padding: 12px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.panel-detail-block:first-child {
  padding-top: 0;
}

.panel-detail-block:last-child {
  border-bottom: none;
}

.panel-detail-text {
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.5;
  margin: 0;
}

/* ── Project Workspace ── */

.workspace-project {
  gap: 0;
}

/* Project header */

.project-header {
  margin-bottom: 16px;
}

.back-link {
  display: inline-block;
  font-size: 12px;
  color: var(--text-secondary);
  text-decoration: none;
  margin-bottom: 12px;
  transition: color 0.15s;
  letter-spacing: 0.01em;
}

.back-link:hover {
  color: var(--text-primary);
}

/* Tab bar */

.tab-bar {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: 20px;
}

.tab {
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 10px 14px;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 400;
  color: var(--text-secondary);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  letter-spacing: 0.01em;
}

.tab:hover {
  color: var(--text-primary);
}

.tab.active {
  color: var(--text-heading);
  font-weight: 500;
  border-bottom-color: var(--text-heading);
}

/* Tab content */

.tab-content {
  display: none;
  flex-direction: column;
  gap: 16px;
  flex: 1;
}

.tab-content.active {
  display: flex;
}

/* 4-column summary row */

.summary-row-4 {
  grid-template-columns: repeat(4, 1fr);
}

/* Placeholder for future tab content */

.placeholder-page {
  min-height: 240px;
  font-size: 13px;
}

/* Stacked query input (context panel) */

.query-input-stacked {
  flex-direction: column;
  gap: 8px;
}

.query-stacked-btn {
  align-self: flex-end;
}

/* Team list (context panel) */

.team-list {
  list-style: none;
}

.team-member {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.team-member:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.team-member:first-child {
  padding-top: 0;
}

.team-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 500;
  color: var(--text-secondary);
  flex-shrink: 0;
  letter-spacing: 0.02em;
}

.team-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.team-name {
  font-size: 12px;
  color: var(--text-primary);
}

.team-role {
  font-size: 10px;
  color: var(--text-secondary);
  margin-top: 1px;
}

/* ── Project Overview ── */

.overview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.overview-col {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Detail list (key-value pairs) */

.detail-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.detail-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 9px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.detail-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.detail-row:first-child {
  padding-top: 0;
}

.detail-row dt {
  font-size: 12px;
  color: var(--text-secondary);
  flex-shrink: 0;
  min-width: 100px;
}

.detail-row dd {
  font-size: 12px;
  color: var(--text-primary);
  text-align: right;
}

/* Drawing list */

.drawing-list {
  list-style: none;
}

.drawing-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-subtle);
  gap: 12px;
}

.drawing-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.drawing-item:first-child {
  padding-top: 0;
}

.drawing-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.drawing-number {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-heading);
}

.drawing-title {
  font-size: 11px;
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.drawing-rev {
  font-size: 10px;
  font-weight: 500;
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-subtle);
  padding: 2px 7px;
  border-radius: 3px;
  flex-shrink: 0;
  letter-spacing: 0.03em;
}

/* Open items list */

.open-items-list {
  list-style: none;
}

.open-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.open-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.open-item:first-child {
  padding-top: 0;
}

.open-item-content {
  min-width: 0;
}

.open-item-text {
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.4;
}

.open-item-meta {
  font-size: 10px;
  color: var(--text-secondary);
  margin-top: 3px;
}

/* ── Drawings Workspace ── */

.drawings-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.toolbar-left {
  display: flex;
  gap: 10px;
  flex: 1;
}

.toolbar-right {
  flex-shrink: 0;
}

/* Search input */

.search-input-wrap {
  position: relative;
  flex: 1;
  max-width: 280px;
}

.search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  color: var(--text-secondary);
  pointer-events: none;
}

.search-input {
  width: 100%;
  background: var(--input-bg);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 8px 12px 8px 30px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  outline: none;
  transition: border-color 0.15s;
}

.search-input::placeholder {
  color: var(--text-secondary);
}

.search-input:focus {
  border-color: #444;
}

/* Filter select */

.filter-select {
  background: var(--input-bg);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 8px 28px 8px 10px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  appearance: none;
  cursor: pointer;
  outline: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%236B6B6B' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  transition: border-color 0.15s;
}

.filter-select:hover {
  border-color: #444;
}

/* ── Ignus Custom Dropdown ── */

.ignus-dd {
  position: relative;
  display: inline-flex;
  width: 100%;
}

.ignus-dd-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--input-bg);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-btn);
  padding: 9px 12px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  cursor: pointer;
  outline: none;
  transition: border-color 0.15s, background 0.15s;
  white-space: nowrap;
  min-width: 0;
  width: 100%;
  text-align: left;
}
.ignus-dd-trigger:hover { border-color: #444; }
.ignus-dd-trigger:focus-visible {
  border-color: #555;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.05);
}

.ignus-dd-label {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.ignus-dd-chev {
  flex-shrink: 0;
  color: var(--text-secondary);
  line-height: 0;
  transition: transform 0.15s ease;
}
.ignus-dd--open .ignus-dd-chev {
  transform: rotate(180deg);
}

/* ── Menu ── */
.ignus-dd-menu {
  display: none;
  position: fixed;
  z-index: 9999;
  background: #1C1C1C;
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(255, 255, 255, 0.03) inset;
  padding: 4px;
  overflow-y: auto;
  overscroll-behavior: contain;
}
.ignus-dd-menu.ignus-dd-menu--open {
  display: block;
}

/* ── Menu Items ── */
.ignus-dd-item {
  padding: 7px 10px;
  font-size: 13px;
  color: var(--text-primary);
  border-radius: 5px;
  cursor: pointer;
  transition: background 0.1s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ignus-dd-item:hover,
.ignus-dd-item.focused {
  background: rgba(255, 255, 255, 0.06);
}
.ignus-dd-item.selected {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-heading);
  font-weight: 500;
}
.ignus-dd-item.selected.focused {
  background: rgba(255, 255, 255, 0.10);
}

/* ── Size: sm (filter toolbar) ── */
.ignus-dd--sm {
  width: auto;
}
.ignus-dd--sm .ignus-dd-trigger {
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 6px;
}
.ignus-dd--sm .ignus-dd-menu {
  min-width: 100%;
  width: auto;
}
.ignus-dd--sm .ignus-dd-item {
  font-size: 12px;
  padding: 6px 10px;
}

/* ── Inline variant (source mode bar) ── */
.ignus-dd--inline {
  flex: 1;
  width: auto;
}
.ignus-dd--inline .ignus-dd-trigger {
  background: transparent;
  border: none;
  padding: 2px 0;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
}
.ignus-dd--inline .ignus-dd-trigger:hover {
  color: var(--text-heading);
}
.ignus-dd--inline .ignus-dd-menu {
  min-width: 140px;
  left: -8px;
  right: auto;
}
.ignus-dd--inline .ignus-dd-item {
  font-size: 11px;
  padding: 6px 10px;
}

/* ── Drawer/form context — match builder-input radius ── */
.task-drawer-body .ignus-dd-trigger,
.modal-body .ignus-dd-trigger {
  border-radius: var(--radius-input);
  padding: 10px 12px;
}

/* ── Disabled state ── */
.ignus-dd--disabled .ignus-dd-trigger {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ── Priority tint inheritance ── */
.ignus-dd.priority-tint-low .ignus-dd-label { color: #94A3B8; }
.ignus-dd.priority-tint-medium .ignus-dd-label { color: #3B82F6; }
.ignus-dd.priority-tint-high .ignus-dd-label { color: #F59E0B; }
.ignus-dd.priority-tint-critical .ignus-dd-label { color: #EF4444; }

/* Drawing number column */

.col-dwg-num {
  width: 100px;
}

.col-discipline {
  width: 120px;
}

/* Discipline tags */

.discipline-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 7px;
  border-radius: 3px;
}

.tag-arch {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
}

.tag-mech {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-secondary);
  border: 1px solid var(--border);
}

.tag-fire {
  background: rgba(255, 200, 150, 0.08);
  color: #D4A574;
}

.tag-elec {
  background: rgba(150, 200, 255, 0.06);
  color: #8AAFCC;
}

.tag-struct {
  background: rgba(200, 200, 200, 0.06);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}

/* Drawing split layout */

.drawings-split {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 16px;
  flex: 1;
  min-height: 0;
}

/* Drawing list panel (left) */

.drawings-list-panel {
  overflow-y: auto;
  min-height: 0;
}

.drawings-table-compact {
  overflow: hidden;
}

.data-table-compact th {
  padding: 10px 12px;
  font-size: 10px;
}

.data-table-compact td {
  padding: 10px 12px;
  font-size: 12px;
}

.compact-title {
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  color: var(--text-secondary);
}

/* Drawing viewer (right) */

.drawing-viewer {
  display: flex;
  flex-direction: column;
  min-height: 0;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-card);
  overflow: hidden;
  background: var(--card);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2), 0 0 0 1px rgba(255, 255, 255, 0.02) inset;
}

/* Viewer header */

.viewer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--card-raised);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.viewer-header-info {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.viewer-dwg-number {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-heading);
  flex-shrink: 0;
}

.viewer-dwg-title {
  font-size: 11px;
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.viewer-controls {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.viewer-btn {
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 4px;
  padding: 5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, border-color 0.15s;
}

.viewer-btn svg {
  width: 14px;
  height: 14px;
  color: var(--text-secondary);
}

.viewer-btn:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: #444;
}

.viewer-btn:hover svg {
  color: var(--text-primary);
}

.viewer-zoom-level {
  font-size: 10px;
  color: var(--text-secondary);
  min-width: 32px;
  text-align: center;
  letter-spacing: 0.02em;
}

/* Viewer canvas */

.viewer-canvas {
  flex: 1;
  overflow: auto;
  background: #0A0A0A;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  min-height: 0;
}

.viewer-grid {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Simulated drawing sheet */

.viewer-sheet {
  width: 100%;
  max-width: 580px;
  aspect-ratio: 1.414 / 1;
  background: #111111;
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 6px;
}

.sheet-border {
  width: 100%;
  height: 100%;
  border: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  position: relative;
}

.sheet-content-area {
  flex: 1;
  position: relative;
  overflow: hidden;
}

.sheet-grid-lines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: 40px 40px;
}

.sheet-title-block {
  padding: 8px 12px;
  border-top: 1px solid var(--border-subtle);
  background: rgba(255, 255, 255, 0.02);
  margin-top: auto;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
}

.sheet-project {
  font-size: 9px;
  color: var(--text-secondary);
  letter-spacing: 0.03em;
}

.sheet-dwg-title {
  font-size: 11px;
  color: var(--text-primary);
  font-weight: 500;
  margin-top: 2px;
}

.sheet-meta {
  display: flex;
  gap: 14px;
  margin-top: 4px;
}

.sheet-meta span {
  font-size: 9px;
  color: var(--text-secondary);
  letter-spacing: 0.04em;
}

/* Viewer toolbar (bottom) */

.viewer-toolbar {
  display: flex;
  gap: 6px;
  padding: 8px 14px;
  background: var(--card-raised);
  border-top: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.viewer-action-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 5px;
  padding: 6px 10px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.viewer-action-btn svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
}

.viewer-action-btn:hover {
  color: var(--text-primary);
  border-color: #444;
  background: rgba(255, 255, 255, 0.04);
}

/* ── Pin filter bar (above the drawing canvas) ── */

.viewer-pin-filters {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px 14px;
  background: var(--card-raised, #1A1A1A);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.pin-filter-label {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-right: 4px;
}

.pin-filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 12px;
  padding: 4px 10px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: #5A5A5A;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
  white-space: nowrap;
}

.pin-filter-pill:hover {
  color: var(--text-primary);
  border-color: #3A3A3A;
}

/* Active state — the filter is currently exerting force.
   For type pills this means "show pins of this type" (default on).
   For secondary pills this means "secondary criterion is enforced". */
.pin-filter-pill.pin-filter-on {
  color: var(--text-heading);
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.18);
}

.pin-filter-pill.pin-filter-on:hover {
  border-color: rgba(255, 255, 255, 0.28);
}

.pin-filter-pill-all {
  color: var(--text-secondary);
  border-color: var(--border-subtle);
  font-weight: 500;
}

.pin-filter-pill-all:hover {
  color: var(--text-primary);
  border-color: #444;
}

.pin-filter-count {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  color: inherit;
  opacity: 0.7;
  min-width: 12px;
  text-align: center;
}

.pin-filter-pill.pin-filter-on .pin-filter-count {
  opacity: 1;
}

.pin-filter-divider {
  display: inline-block;
  width: 1px;
  height: 16px;
  background: var(--border-subtle);
  margin: 0 4px;
  flex-shrink: 0;
}

/* ── Drawing-wide photo gallery (workspace drawing viewer) ── */

/* Toolbar button count badge — also used by the Photos toolbar
   button. Sized to slot inline with the existing viewer-action
   icon + label without breaking the row. */
.viewer-action-btn-count {
  font-size: 10px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  padding: 1px 6px;
  margin-left: 4px;
  color: var(--text-primary);
  font-weight: 500;
}

.drawing-photo-gallery {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  max-height: 55%;
  background: var(--card, #1A1A1A);
  border-top: 1px solid var(--border-subtle);
  box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.4);
  display: none;
  flex-direction: column;
  z-index: 8;
}

.drawing-photo-gallery.open {
  display: flex;
}

.drawing-photo-gallery-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.drawing-photo-gallery-eyebrow {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 3px;
}

.drawing-photo-gallery-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-heading);
  margin: 0;
}

.drawing-photo-gallery-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 18px 18px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
  align-content: start;
  min-height: 0;
}

.drawing-photo-tile {
  display: flex;
  flex-direction: column;
  background: var(--card-raised, #1E1E1E);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.15s, transform 0.1s;
}

.drawing-photo-tile:hover {
  border-color: #3A3A3A;
}

.drawing-photo-tile:active {
  transform: scale(0.99);
}

.drawing-photo-tile-image {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #0E0E0E;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.drawing-photo-tile-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.drawing-photo-tile-meta {
  padding: 9px 11px 11px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.drawing-photo-tile-caption {
  font-size: 12px;
  color: var(--text-primary);
  margin: 0;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}

.drawing-photo-tile-meta-row {
  font-size: 10px;
  color: var(--text-secondary);
  display: flex;
  justify-content: space-between;
  gap: 6px;
}

.drawing-photo-tile-pin-link {
  font-size: 10px;
  color: var(--text-secondary);
  background: none;
  border: none;
  padding: 2px 0 0;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.drawing-photo-tile-pin-link:hover {
  color: var(--text-primary);
  text-decoration: underline;
}

.drawing-photo-gallery-empty {
  grid-column: 1 / -1;
  text-align: center;
  color: var(--text-secondary);
  font-size: 12px;
  padding: 32px 16px;
  background: var(--card-raised, #1E1E1E);
  border: 1px dashed var(--border-subtle);
  border-radius: 6px;
}

/* ── Drawing pin overlay (workspace drawings tab) ── */

.drawing-pin-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
}

.drawing-pin {
  position: absolute;
  width: 22px;
  height: 22px;
  margin-left: -11px;
  margin-top: -22px;
  pointer-events: auto;
  cursor: pointer;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.5));
  transition: transform 0.12s ease, filter 0.12s ease;
}

.drawing-pin:hover {
  transform: translateY(-1px) scale(1.08);
  filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.6));
  z-index: 5;
}

.drawing-pin.selected {
  transform: translateY(-1px) scale(1.12);
  z-index: 6;
}

.drawing-pin-shape {
  width: 18px;
  height: 18px;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  border: 1.5px solid rgba(0, 0, 0, 0.6);
  box-shadow: 0 0 0 1.5px rgba(255, 255, 255, 0.18) inset;
}

.drawing-pin-dot {
  position: absolute;
  top: 5px;
  left: 50%;
  margin-left: -2px;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.55);
}

/* Subtle region preview drawn under a hovered/selected pin */
.drawing-pin-region-preview {
  position: absolute;
  display: none;
  border: 1px dashed rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.04);
  border-radius: 2px;
  pointer-events: none;
  z-index: 3;
}
.drawing-pin-region-preview.visible {
  display: block;
}

/* ── Pin photo lightbox (workspace photo pin click) ── */

.pin-photo-lightbox-main {
  width: 100%;
  min-height: 240px;
  max-height: 50vh;
  background: #0E0E0E;
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.pin-photo-lightbox-main img {
  max-width: 100%;
  max-height: 50vh;
  object-fit: contain;
  display: block;
}

.pin-photo-lightbox-empty {
  font-size: 12px;
  color: var(--text-secondary);
  padding: 24px;
  text-align: center;
}

.pin-photo-lightbox-strip {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.pin-photo-lightbox-thumb {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  border-radius: 4px;
  border: 1px solid var(--border-subtle);
  background: #0E0E0E;
  cursor: pointer;
  overflow: hidden;
  transition: border-color 0.15s, transform 0.1s;
}

.pin-photo-lightbox-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.pin-photo-lightbox-thumb:hover { border-color: #444; }
.pin-photo-lightbox-thumb.active {
  border-color: rgba(255, 180, 100, 0.55);
  box-shadow: 0 0 0 1px rgba(255, 180, 100, 0.25) inset;
}

.pin-photo-lightbox-caption {
  font-size: 12px;
  color: var(--text-secondary);
  margin: 0;
  min-height: 16px;
}

/* ── Pending pin overlay (point-first interaction) ──
   Shown after the user clicks a precise point on the drawing in
   Place Pin mode. Acts as a temporary anchor for Pin Issue / Add
   Photo / Add Region until the action commits or is cancelled. */

.pending-pin-overlay {
  position: absolute;
  inset: 0;
  display: none;
  pointer-events: none;
  z-index: 6;
}

.pending-pin-overlay.visible {
  display: block;
}

.pending-pin-marker {
  position: absolute;
  width: 22px;
  height: 22px;
  margin-left: -11px;
  margin-top: -22px;
  pointer-events: none;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.5));
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.pending-pin-popover {
  position: absolute;
  display: flex;
  gap: 4px;
  background: var(--card-raised);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 5px;
  pointer-events: auto;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5);
  white-space: nowrap;
  transform: translate(-50%, 8px);
}

.pending-pin-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 4px;
  padding: 5px 9px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.pending-pin-btn svg {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}

.pending-pin-btn:hover {
  color: var(--text-primary);
  border-color: #3A3A3A;
  background: rgba(255, 255, 255, 0.05);
}

.pending-pin-btn-close {
  padding: 5px 7px;
}

.pending-pin-btn.active {
  color: var(--text-heading);
  border-color: rgba(255, 180, 100, 0.5);
  background: rgba(255, 180, 100, 0.06);
}

/* Optional context region attached to the pending pin */
.pending-pin-region {
  position: absolute;
  display: none;
  border: 1px dashed rgba(255, 180, 100, 0.55);
  background: rgba(255, 180, 100, 0.05);
  border-radius: 3px;
  pointer-events: none;
}
.pending-pin-region.visible {
  display: block;
}

/* Place Pin mode — when the user has armed the toolbar button,
   the cursor turns into a crosshair and a faint instructional tint
   sits over the sheet so the mode is obvious. */
.viewer-sheet.pin-place-mode {
  cursor: crosshair;
}

.viewer-sheet.pin-place-mode .sheet-content-area::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 180, 100, 0.03);
  border: 1px dashed rgba(255, 180, 100, 0.25);
  pointer-events: none;
}

/* ── Selected pin detail panel ──
   Right-edge drawer sitting inside .drawing-viewer. Because the
   parent .drawing-viewer is the same element that the fullscreen
   class lifts to position:fixed, the panel automatically renders
   correctly in both embedded and fullscreen views with no extra
   layout work. */

.pin-detail-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 320px;
  max-width: 92vw;
  background: var(--card, #1A1A1A);
  border-left: 1px solid var(--border-subtle);
  box-shadow: -8px 0 24px rgba(0, 0, 0, 0.35);
  display: none;
  flex-direction: column;
  z-index: 7;
  overflow: hidden;
}

.pin-detail-panel.open {
  display: flex;
}

.pin-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  padding: 16px 18px 14px;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.pin-detail-header-main {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  min-width: 0;
}

.pin-detail-swatch {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  margin-top: 4px;
  flex-shrink: 0;
  border: 1px solid rgba(0, 0, 0, 0.5);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08) inset;
  background: #E5A545;
}

.pin-detail-header-text {
  min-width: 0;
}

.pin-detail-eyebrow {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 3px;
}

.pin-detail-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-heading);
  margin: 0;
  word-break: break-word;
}

.pin-detail-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 16px 18px 8px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-height: 0;
}

.pin-detail-meta {
  display: grid;
  grid-template-columns: 96px 1fr;
  row-gap: 6px;
  column-gap: 12px;
  margin: 0;
  font-size: 11px;
}

.pin-detail-meta dt {
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 10px;
  padding-top: 1px;
}

.pin-detail-meta dd {
  color: var(--text-primary);
  margin: 0;
  word-break: break-word;
}

.pin-detail-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pin-detail-section-label,
.pin-detail-section-label-row {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0;
}

.pin-detail-section-label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.pin-detail-photo-count {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: none;
  letter-spacing: 0;
}

.pin-detail-linked {
  background: var(--card-raised, #1E1E1E);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 10px 12px;
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.45;
}

.pin-detail-linked-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 6px;
  font-size: 11px;
  color: var(--text-secondary);
}

.pin-detail-linked-row span:last-child {
  color: var(--text-primary);
}

.pin-detail-photos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}

.pin-detail-photo-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  background: #0E0E0E;
  border: 1px solid var(--border-subtle);
  border-radius: 5px;
  overflow: hidden;
  cursor: pointer;
  padding: 0;
  transition: border-color 0.15s;
}

.pin-detail-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.pin-detail-photo-thumb:hover { border-color: #444; }

.pin-detail-photos-empty {
  grid-column: 1 / -1;
  font-size: 11px;
  color: var(--text-secondary);
  padding: 14px 12px;
  text-align: center;
  background: var(--card-raised, #1E1E1E);
  border: 1px dashed var(--border-subtle);
  border-radius: 6px;
}

.pin-detail-photo-status {
  font-size: 11px;
  color: var(--text-secondary);
  min-height: 14px;
}

.pin-detail-footer {
  display: flex;
  gap: 8px;
  padding: 12px 18px 14px;
  border-top: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.pin-detail-footer .btn-secondary,
.pin-detail-footer .btn-primary {
  flex: 1;
}

/* Fullscreen — pin detail panel widens slightly so it has room */
.drawing-viewer.drawing-viewer-fullscreen .pin-detail-panel {
  width: 380px;
}

/* Fullscreen drawing viewer — same DOM, lifted to viewport.
   The point-first overlay/event logic keeps working unchanged
   because the markers are still children of .sheet-content-area. */
.drawing-viewer.drawing-viewer-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 950;
  background: var(--bg, #0C0C0C);
  display: flex;
  flex-direction: column;
}

.drawing-viewer.drawing-viewer-fullscreen .viewer-canvas {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.drawing-viewer.drawing-viewer-fullscreen .viewer-sheet {
  max-width: min(92vw, 1400px);
  width: 100%;
}

.drawing-viewer.drawing-viewer-fullscreen .icon-fullscreen-enter { display: none; }
.drawing-viewer.drawing-viewer-fullscreen .icon-fullscreen-exit { display: inline-block; }

/* ── Pin Issue chooser grid (workspace highlight → pin issue modal) ── */
.pin-issue-chooser-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.pin-issue-chooser-btn {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: 14px 14px 12px;
  background: var(--card-raised);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  text-align: left;
  color: var(--text-primary);
  transition: border-color 0.15s, background 0.15s, transform 0.1s;
}

.pin-issue-chooser-btn svg {
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
}

.pin-issue-chooser-btn:hover {
  border-color: #444;
  background: rgba(255, 255, 255, 0.04);
}
.pin-issue-chooser-btn:hover svg {
  color: var(--text-primary);
}
.pin-issue-chooser-btn:active { transform: scale(0.99); }

.pin-issue-chooser-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-heading);
}

.pin-issue-chooser-sub {
  font-size: 11px;
  color: var(--text-secondary);
  line-height: 1.35;
}

/* Active toolbar button state */

.viewer-action-btn.active {
  color: var(--text-heading);
  border-color: rgba(255, 180, 100, 0.4);
  background: rgba(255, 180, 100, 0.08);
}

.viewer-action-btn.active svg {
  color: #D4A574;
}

/* ── Queries / RFIs Table ── */

.col-id {
  width: 70px;
}

.id-cell {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-heading);
}

.col-dwg-ref {
  width: 80px;
  font-size: 12px;
  color: var(--text-secondary);
}

.col-raised-by {
  width: 140px;
  font-size: 12px;
  color: var(--text-secondary);
}

.status-open {
  background: rgba(255, 255, 255, 0.07);
  color: var(--text-primary);
}

.status-answered {
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}

.status-draft {
  background: transparent;
  color: var(--text-secondary);
  border: 1px dashed var(--border);
}

.status-responded {
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}

.status-closed {
  background: transparent;
  color: var(--text-secondary);
  opacity: 0.6;
  border: 1px solid var(--border-subtle);
}

.col-sent-to {
  width: 130px;
  font-size: 12px;
  color: var(--text-secondary);
}

/* ── Documents Table ── */

.doc-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-heading);
}

.col-doc-type {
  width: 110px;
}

.col-doc-source {
  width: 160px;
  font-size: 12px;
  color: var(--text-secondary);
}

.doc-type-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 7px;
  border-radius: 3px;
}

.tag-fire-strategy {
  background: rgba(255, 180, 130, 0.08);
  color: #D4A574;
}

.tag-specification {
  background: rgba(150, 200, 255, 0.06);
  color: #8AAFCC;
}

.tag-submittal {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
}

.tag-report {
  background: rgba(200, 200, 200, 0.06);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}

/* ── Reports ── */

.col-report-project {
  width: 180px;
  font-size: 12px;
  color: var(--text-secondary);
}

.status-in-progress {
  background: rgba(255, 255, 255, 0.07);
  color: var(--text-primary);
}

.status-complete {
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}

.report-items-list {
  list-style: none;
}

.report-included-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 7px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.report-included-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.report-included-item:first-child {
  padding-top: 0;
}

.badge-note {
  background: rgba(200, 200, 200, 0.06);
  color: var(--text-secondary);
  border: 1px dashed var(--border);
}

/* ── Report Builder ── */

.builder-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
  overflow: hidden;
}

.builder-form-row {
  display: flex;
  gap: 14px;
  min-width: 0;
}

.builder-field {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.builder-field-full {
  flex: 1 1 100%;
}

.builder-label {
  font-size: 11px;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.builder-input,
.builder-select,
.builder-textarea {
  background: var(--input-bg);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 9px 12px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  outline: none;
  transition: border-color 0.15s;
  width: 100%;
  box-sizing: border-box;
}

.builder-input:focus,
.builder-select:focus,
.builder-textarea:focus {
  border-color: #444;
}

/* Force dark styling on browser autofill */
.builder-input:-webkit-autofill,
.builder-input:-webkit-autofill:hover,
.builder-input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 40px var(--input-bg) inset !important;
  -webkit-text-fill-color: var(--text-primary) !important;
  caret-color: var(--text-primary);
  transition: background-color 5000s ease-in-out 0s;
}

.builder-select {
  appearance: none;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%236B6B6B' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}

.builder-textarea {
  resize: vertical;
  min-height: 120px;
  white-space: pre-wrap;
  word-break: break-word;
  overflow-wrap: break-word;
  line-height: 1.5;
}

/* Builder sections */

.builder-section {
  padding: 0;
  overflow: hidden;
}

.builder-section-header {
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--border-subtle);
}

.builder-section-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.builder-section-title-row .card-title {
  margin-bottom: 0;
}

.builder-section-count {
  font-size: 11px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}

.builder-section-desc {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 3px;
}

/* Selectable item rows */

.builder-items-list {
  display: flex;
  flex-direction: column;
}

.builder-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  transition: background 0.12s;
}

.builder-item:last-child {
  border-bottom: none;
}

.builder-item:hover {
  background: rgba(255, 255, 255, 0.03);
}

.builder-item.selected {
  background: rgba(255, 255, 255, 0.04);
}

.builder-checkbox {
  flex-shrink: 0;
  width: 15px;
  height: 15px;
  margin-top: 2px;
  accent-color: var(--text-primary);
  cursor: pointer;
}

.builder-item-content {
  min-width: 0;
  flex: 1;
}

.builder-item-text {
  font-size: 13px;
  color: var(--text-primary);
  line-height: 1.4;
}

.builder-item-meta {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 2px;
}

/* Photo items in builder */

.photo-thumb {
  width: 44px;
  height: 44px;
  border-radius: 5px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.photo-thumb svg {
  width: 20px;
  height: 20px;
  color: var(--text-secondary);
  opacity: 0.5;
}

.photo-link-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 5px;
  border-radius: 3px;
  margin-right: 4px;
  vertical-align: middle;
}

.badge-general {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}

.badge-photo {
  background: rgba(180, 160, 255, 0.08);
  color: #A99BCC;
}

/* 4 / 5 column stat grids */

.detail-stats-4 {
  grid-template-columns: repeat(4, 1fr);
}

.detail-stats-5 {
  grid-template-columns: repeat(5, 1fr);
}

.detail-stats-6 {
  grid-template-columns: repeat(6, 1fr);
}

/* Pin icon for drawing annotations */

.pin-icon-wrap {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255, 180, 100, 0.08);
  border: 1px solid rgba(255, 180, 100, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}

.pin-icon-wrap svg {
  width: 15px;
  height: 15px;
  color: #D4A574;
}

.pin-dwg-ref {
  font-weight: 500;
  color: var(--text-primary);
  letter-spacing: 0.02em;
}

.pin-photo-count {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 3px;
}

.pin-photo-icon {
  width: 11px;
  height: 11px;
  flex-shrink: 0;
  opacity: 0.5;
}

.badge-pin {
  background: rgba(255, 180, 100, 0.08);
  color: #D4A574;
}

/* ── Report Preview (live preview in builder panel) ── */

.rpt-preview-wrap {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.rpt-preview-page {
  background: #fff;
  color: #1a1a1a;
  border-radius: var(--radius-card);
  padding: 20px 18px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  line-height: 1.55;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.45);
}

.rpt-preview-header {
  border-bottom: 2px solid #1a1a1a;
  padding-bottom: 12px;
  margin-bottom: 14px;
}

.rpt-preview-title {
  font-size: 15px;
  font-weight: 600;
  color: #111;
  margin-bottom: 4px;
  line-height: 1.3;
}

.rpt-preview-meta {
  font-size: 10px;
  color: #666;
  line-height: 1.6;
}

.rpt-preview-meta span {
  display: block;
}

.rpt-preview-status {
  display: inline-block;
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 6px;
  border-radius: 3px;
  margin-top: 4px;
}

.rpt-preview-status.st-draft { background: #f0f0f0; color: #888; }
.rpt-preview-status.st-in-progress { background: #FFF3E0; color: #E65100; }
.rpt-preview-status.st-ready { background: #E3F2FD; color: #1565C0; }
.rpt-preview-status.st-issued { background: #E8F5E9; color: #2E7D32; }

.rpt-preview-section {
  margin-bottom: 12px;
}

.rpt-preview-section:last-child {
  margin-bottom: 0;
}

.rpt-preview-section-title {
  font-size: 11px;
  font-weight: 600;
  color: #222;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  border-bottom: 1px solid #ddd;
  padding-bottom: 4px;
  margin-bottom: 8px;
}

.rpt-preview-section-count {
  font-weight: 400;
  color: #999;
  font-size: 10px;
  margin-left: 4px;
}

.rpt-preview-empty {
  font-size: 10px;
  color: #aaa;
  font-style: italic;
  padding: 4px 0;
}

.rpt-preview-summary-text {
  font-size: 11px;
  color: #444;
  line-height: 1.6;
  white-space: pre-wrap;
}

/* Table-style items */
.rpt-preview-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 10px;
}

.rpt-preview-table th {
  text-align: left;
  font-weight: 600;
  color: #555;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 3px 4px;
  border-bottom: 1px solid #ddd;
}

.rpt-preview-table td {
  padding: 4px 4px;
  border-bottom: 1px solid #f0f0f0;
  color: #333;
  vertical-align: top;
}

.rpt-preview-table tr:last-child td {
  border-bottom: none;
}

.rpt-preview-table .col-status {
  width: 60px;
}

.rpt-preview-table .col-ref {
  width: 70px;
  white-space: nowrap;
}

.rpt-preview-status-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}

.rpt-preview-status-dot.s-open { background: #E53935; }
.rpt-preview-status-dot.s-in-progress { background: #FB8C00; }
.rpt-preview-status-dot.s-sent { background: #FB8C00; }
.rpt-preview-status-dot.s-closed { background: #43A047; }
.rpt-preview-status-dot.s-resolved { background: #43A047; }
.rpt-preview-status-dot.s-default { background: #999; }

/* List-style items (notes) */
.rpt-preview-list-item {
  padding: 5px 0;
  border-bottom: 1px solid #f0f0f0;
}

.rpt-preview-list-item:last-child {
  border-bottom: none;
}

.rpt-preview-list-title {
  font-size: 11px;
  font-weight: 500;
  color: #222;
}

.rpt-preview-list-body {
  font-size: 10px;
  color: #666;
  margin-top: 2px;
  line-height: 1.5;
}

/* Photo grid */
.rpt-preview-photo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}

.rpt-preview-photo-thumb {
  aspect-ratio: 1;
  background: #f0f0f0;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}

.rpt-preview-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.rpt-preview-photo-thumb svg {
  width: 20px;
  height: 20px;
  color: #bbb;
}

.rpt-preview-photo-caption {
  font-size: 8px;
  color: #999;
  text-align: center;
  margin-top: 2px;
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Pin items */
.rpt-preview-pin {
  padding: 5px 0;
  border-bottom: 1px solid #f0f0f0;
  display: flex;
  gap: 6px;
  align-items: flex-start;
}

.rpt-preview-pin:last-child {
  border-bottom: none;
}

.rpt-preview-pin-colour {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 3px;
}

.rpt-preview-pin-content {
  flex: 1;
  min-width: 0;
}

.rpt-preview-pin-title {
  font-size: 10px;
  font-weight: 500;
  color: #222;
}

.rpt-preview-pin-detail {
  font-size: 9px;
  color: #888;
  margin-top: 1px;
}

.rpt-preview-pin-photos {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.rpt-preview-pin-photo {
  width: 90px;
  flex-shrink: 0;
}

.rpt-preview-pin-photo img {
  width: 90px;
  height: 68px;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}

.rpt-preview-pin-photo .rpt-preview-photo-caption {
  margin-top: 2px;
  width: 90px;
}

.rpt-preview-issue-number {
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #999;
  margin-bottom: 1px;
}

.rpt-preview-pin-desc {
  font-size: 10px;
  color: #555;
  margin-top: 3px;
  line-height: 1.5;
}

.rpt-preview-pin-link {
  color: #1565C0;
  text-decoration: none;
}

.rpt-preview-pin-link:hover {
  text-decoration: underline;
}

/* Stats bar */
.rpt-preview-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #eee;
}

.rpt-preview-stat {
  text-align: center;
}

.rpt-preview-stat-value {
  font-size: 14px;
  font-weight: 600;
  color: #222;
}

.rpt-preview-stat-label {
  font-size: 8px;
  color: #999;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

/* ── Contacts Table ── */

.contact-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-heading);
}

.col-contact-role {
  width: 160px;
  font-size: 12px;
  color: var(--text-secondary);
}

.col-contact-company {
  width: 190px;
  font-size: 12px;
  color: var(--text-secondary);
}

.col-contact-email {
  font-size: 12px;
  color: var(--text-secondary);
}

.col-contact-phone {
  width: 120px;
  font-size: 12px;
  color: var(--text-secondary);
}

/* ── Ignus AI Panel ── */

.ai-panel {
  gap: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

/* AI Panel Header */

.ai-panel-header {
  padding: 16px 16px 14px;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.ai-brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ai-brand-icon {
  width: 20px;
  height: 20px;
  color: var(--text-heading);
  opacity: 0.8;
  flex-shrink: 0;
}

.ai-brand-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-heading);
  display: block;
  letter-spacing: 0.02em;
}

.ai-brand-role {
  font-size: 10px;
  color: var(--text-secondary);
  display: block;
  margin-top: 1px;
}

/* Conversation */

.ai-conversation {
  flex: 1;
  overflow-y: auto;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
}

.ai-msg {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ai-msg-header {
  display: flex;
  align-items: center;
  gap: 8px;
}

.ai-msg-author {
  font-size: 11px;
  font-weight: 500;
  color: var(--text-heading);
}

.ai-msg-timestamp {
  font-size: 10px;
  color: var(--text-secondary);
}

/* User message */

.ai-msg-user .ai-msg-body {
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.5;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 10px 12px;
}

/* AI response */

.ai-msg-ai .ai-msg-body {
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.6;
}

.ai-msg-ai .ai-msg-body p {
  margin-bottom: 8px;
}

.ai-msg-ai .ai-msg-body p:last-child {
  margin-bottom: 0;
}

.ai-msg-ai .ai-msg-body strong {
  color: var(--text-heading);
  font-weight: 600;
}

/* AI loading state */
.ai-loading-text {
  color: var(--text-secondary);
  font-style: italic;
  animation: ai-pulse 1.5s ease-in-out infinite;
}

@keyframes ai-pulse {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

/* Sources */

.ai-sources {
  margin-top: 6px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
}

.ai-sources-label {
  font-size: 9px;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 6px;
}

.ai-source-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ai-source-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--text-secondary);
}

.ai-source-icon {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
  opacity: 0.5;
}

/* Suggested prompts */

.ai-suggestions {
  padding: 10px 16px;
  border-top: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.ai-suggestions .panel-section-label {
  margin-top: 0;
  margin-bottom: 8px;
}

.ai-suggestion-list {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.ai-suggestion-btn {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 7px 10px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: var(--text-secondary);
  text-align: left;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
  line-height: 1.35;
}

.ai-suggestion-btn:hover {
  color: var(--text-primary);
  border-color: #444;
  background: rgba(255, 255, 255, 0.05);
}

/* Actions section */

.ai-panel-actions {
  padding: 10px 16px;
  border-top: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.ai-panel-actions .panel-section-label {
  margin-top: 0;
  margin-bottom: 8px;
}

/* Input area (pinned bottom) */

.ai-input-area {
  padding: 12px 16px;
  border-top: 1px solid var(--border-subtle);
  flex-shrink: 0;
  background: var(--sidebar);
}

/* ── Team Page ── */

.team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.team-card {
  padding: 16px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}

.team-card:hover {
  border-color: #444;
}

.team-card.selected {
  border-color: var(--text-secondary);
  background: var(--card-raised);
}

.team-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
}

.team-card-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  flex-shrink: 0;
  letter-spacing: 0.02em;
}

.team-avatar-lg {
  width: 40px;
  height: 40px;
  font-size: 13px;
}

.team-card-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.team-card-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-heading);
}

.team-card-title {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 1px;
}

.team-card-divider {
  height: 1px;
  background: var(--border-subtle);
  margin: 12px 0;
}

.team-card-details {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.team-card-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.team-card-label {
  font-size: 11px;
  color: var(--text-secondary);
}

.team-card-value {
  font-size: 11px;
  color: var(--text-primary);
}

.team-detail-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 4px;
}

/* ── Generate Query / RFI Modal ── */

.gen-form-modal {
  width: 580px;
  max-width: 90vw;
  box-sizing: border-box;
}

.gen-form-sources {
  padding-top: 4px;
}

.gen-form-attachments {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.rfi-attachment-area {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 20px;
  border: 1px dashed var(--border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.02);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}

.rfi-attachment-area:hover {
  border-color: #444;
  background: rgba(255, 255, 255, 0.04);
}

.rfi-attachment-icon {
  width: 20px;
  height: 20px;
  color: var(--text-secondary);
  opacity: 0.5;
  flex-shrink: 0;
}

.rfi-attachment-text {
  font-size: 12px;
  color: var(--text-secondary);
}

/* ── Ask Ignus Modal ── */

.ask-ignus-context {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 24px;
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid var(--border-subtle);
}

.ask-ignus-context-icon {
  width: 28px;
  height: 28px;
  border-radius: 5px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.ask-ignus-context-icon svg {
  width: 14px;
  height: 14px;
  color: var(--text-secondary);
}

.ask-ignus-context-info {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
}

.ask-ignus-context-dwg {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-heading);
  flex-shrink: 0;
}

.ask-ignus-context-title {
  font-size: 11px;
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ask-ignus-context-tag {
  flex-shrink: 0;
  font-size: 9px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 7px;
  border-radius: 3px;
  background: rgba(255, 180, 100, 0.08);
  color: #D4A574;
  border: 1px solid rgba(255, 180, 100, 0.15);
}

/* ── Streaming cursor ── */
.ignus-stream-body {
  min-height: 24px;
  line-height: 1.65;
}

.ignus-stream-cursor {
  display: inline-block;
  width: 2px;
  height: 1em;
  background: var(--text-primary, #333);
  margin-left: 1px;
  vertical-align: text-bottom;
  animation: ignus-blink 1s ease-in-out infinite;
}

@keyframes ignus-blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.15; }
}

/* ── Citation chips ── */

.ai-citation-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.ai-citation-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: rgba(69, 137, 229, 0.08);
  border: 1px solid rgba(69, 137, 229, 0.2);
  border-radius: 5px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: #7EB3F0;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.ai-citation-chip:hover {
  background: rgba(69, 137, 229, 0.14);
  border-color: rgba(69, 137, 229, 0.35);
}

.ai-citation-chip svg,
.ai-citation-chip .ai-source-icon {
  opacity: 0.7;
  flex-shrink: 0;
}

/* ── Source Viewer Modal ── */

.source-viewer-modal {
  width: 860px;
  max-width: 95vw;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  transition: width 0.2s ease, max-width 0.2s ease, max-height 0.2s ease, border-radius 0.2s ease;
}
.source-viewer-modal.source-viewer-fullscreen {
  width: 100vw;
  max-width: 100vw;
  max-height: 100vh;
  height: 100vh;
  border-radius: 0;
}

.source-viewer-modal .modal-header {
  padding: 14px 20px 12px;
  flex-shrink: 0;
}

.source-viewer-title {
  display: flex;
  align-items: center;
  gap: 10px;
}

.source-viewer-icon {
  width: 20px;
  height: 20px;
  color: var(--text-secondary);
  flex-shrink: 0;
}

.source-viewer-doc-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-heading);
}

.source-viewer-page-label {
  font-size: 11px;
  color: var(--text-secondary);
  margin-left: 4px;
}

.source-viewer-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* Snippet evidence panel */
.source-viewer-snippet-panel {
  padding: 10px 20px;
  background: rgba(69, 137, 229, 0.05);
  border-bottom: 1px solid rgba(69, 137, 229, 0.15);
  flex-shrink: 0;
  max-height: 120px;
  overflow-y: auto;
}

.source-viewer-snippet-header {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #7EB3F0;
  margin-bottom: 8px;
}

.source-viewer-snippet-header svg {
  color: #7EB3F0;
  opacity: 0.7;
}

.source-viewer-snippet-text {
  font-size: 12px;
  line-height: 1.55;
  color: var(--text-primary);
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border-subtle);
  border-left: 3px solid rgba(69, 137, 229, 0.4);
  border-radius: 4px;
}

/* Highlight status badge */
.source-viewer-highlight-status {
  margin-left: auto;
  font-size: 9px;
  font-weight: 500;
  padding: 2px 6px;
  border-radius: 3px;
  background: rgba(69, 181, 117, 0.12);
  color: #5DC98E;
  letter-spacing: 0.03em;
}

.source-viewer-highlight-status:empty {
  display: none;
}

/* Page navigation bar */
.source-viewer-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 8px 20px;
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.source-viewer-nav-btn {
  background: none;
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 4px 8px;
  display: flex;
  align-items: center;
  transition: color 0.15s, border-color 0.15s;
}

.source-viewer-nav-btn:hover {
  color: var(--text-primary);
  border-color: #444;
}

.source-viewer-nav-label {
  font-size: 12px;
  color: var(--text-secondary);
  min-width: 80px;
  text-align: center;
}

/* Zoom controls */
.sv-zoom-divider {
  width: 1px;
  height: 18px;
  background: var(--border-subtle);
  margin: 0 4px;
}

.sv-zoom-label {
  font-size: 11px;
  color: var(--text-secondary);
  min-width: 40px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* PDF.js canvas viewer area */
.source-viewer-pdf-wrap {
  flex: 1;
  min-height: 450px;
  position: relative;
  background: #0E0E0E;
  overflow: auto;
  padding: 8px 0;
  /* Drag-to-pan: cursor set dynamically via JS (grab/grabbing) */
  -webkit-overflow-scrolling: touch;
}

.source-viewer-pdf-wrap[style*="grabbing"] {
  user-select: none;
  -webkit-user-select: none;
}

.source-viewer-canvas-container {
  position: relative;
  margin: 0 auto;
}

.source-viewer-canvas-container canvas {
  display: block;
}

/* Text layer — invisible text overlay for selection */
.sv-text-layer {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  opacity: 0.25;
  line-height: 1.0;
  z-index: 1;
}

.sv-text-layer > span {
  color: transparent;
  position: absolute;
  white-space: pre;
  cursor: text;
  transform-origin: 0% 0%;
}

.sv-text-layer ::selection {
  background: rgba(69, 137, 229, 0.4);
}

/* Highlight overlay layer */
.sv-highlight-layer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}

.sv-highlight-rect {
  position: absolute;
  background: rgba(235, 175, 55, 0.35);
  border: 1.5px solid rgba(220, 160, 40, 0.6);
  border-radius: 2px;
  pointer-events: none;
  box-shadow: 0 0 6px rgba(230, 170, 50, 0.18);
}

/* Loading / fallback states */
.source-viewer-loading {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  color: var(--text-secondary);
  font-size: 13px;
  z-index: 2;
}

.source-viewer-spinner {
  width: 32px;
  height: 32px;
  border: 2.5px solid var(--border);
  border-top-color: #888;
  border-radius: 50%;
  animation: sv-spin 0.7s linear infinite;
}

.sv-loading-status {
  color: var(--text-secondary);
  font-size: 12px;
  opacity: 0.8;
  transition: opacity 0.2s;
}

@keyframes sv-spin {
  to { transform: rotate(360deg); }
}

/* Fade-in for rendered canvas */
.source-viewer-canvas-container {
  transition: opacity 0.25s ease;
}

.source-viewer-fallback {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: var(--text-secondary);
}

.source-viewer-fallback svg {
  opacity: 0.3;
}

.source-viewer-fallback p {
  font-size: 13px;
}

.source-viewer-fallback-sub {
  font-size: 11px;
  opacity: 0.6;
}

/* ── Modal ── */

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
}

.modal-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

.modal {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 480px;
  max-width: 90vw;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-sizing: border-box;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.03) inset;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.modal-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-heading);
}

.modal-close {
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 20px;
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
}

.modal-close:hover {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.06);
}

.modal-body {
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  overflow-x: hidden;
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;
  word-break: break-word;
  overflow-wrap: break-word;
}

.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 24px;
  border-top: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

/* ── Inspect Document Modal ─────────────────── */

.inspect-meta-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.inspect-meta-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.inspect-label {
  width: 80px;
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.inspect-meta-row > span:last-child {
  font-size: 13px;
  color: var(--text-primary);
}

.inspect-chunks-section {
  border-top: 1px solid var(--border-subtle);
  padding-top: 14px;
}

.inspect-chunk {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 0;
  font-size: 12px;
  color: var(--text-secondary);
  border-bottom: 1px solid rgba(255,255,255,0.03);
}

.inspect-chunk-id {
  width: 32px;
  flex-shrink: 0;
  font-weight: 600;
  color: var(--text-primary);
}

.inspect-chunk-heading {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.inspect-chunk-chars {
  flex-shrink: 0;
  font-size: 11px;
  opacity: 0.6;
}

.inspect-chunk-emb {
  color: var(--accent-green);
  font-size: 13px;
}

.inspect-chunk-noemb {
  color: var(--accent-red);
  font-size: 13px;
}

/* ── Scope label for citations ─────────────── */

.scope-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 3px;
  letter-spacing: 0.03em;
  vertical-align: middle;
  margin-left: 4px;
}

.scope-tag-project {
  background: rgba(59, 130, 246, 0.15);
  color: #60a5fa;
}

.scope-tag-library {
  background: rgba(251, 191, 36, 0.15);
  color: #fbbf24;
}

/* ── Retrieval Mode Selector ────────────────── */

/* Export format cards */

.export-format-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.export-format-option {
  cursor: pointer;
}

.export-radio {
  display: none;
}

.export-format-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 18px 14px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  transition: border-color 0.15s, background 0.15s;
}

.export-format-option:hover .export-format-card {
  border-color: #444;
  background: rgba(255, 255, 255, 0.04);
}

.export-format-option.selected .export-format-card {
  border-color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.05);
}

.export-format-icon {
  width: 28px;
  height: 28px;
  color: var(--text-secondary);
}

.export-format-option.selected .export-format-icon {
  color: var(--text-heading);
}

.export-format-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
}

.export-format-desc {
  font-size: 10px;
  color: var(--text-secondary);
  text-align: center;
}

/* Export options */

.export-options {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.export-option-row {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  padding: 6px 0;
}

.export-option-text {
  font-size: 13px;
  color: var(--text-primary);
}

/* Export summary */

.export-summary {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.export-summary-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
}

.export-summary-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 10px 4px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
}

.export-summary-value {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-heading);
}

.export-summary-label {
  font-size: 9px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ── Settings Page ── */

.settings-toggles {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 4px;
}

.settings-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
}

.settings-toggle-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.settings-toggle-row:first-child {
  padding-top: 0;
}

.settings-toggle-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.settings-toggle-label {
  font-size: 13px;
  color: var(--text-primary);
}

.settings-toggle-desc {
  font-size: 11px;
  color: var(--text-secondary);
}

/* Toggle switch */

.toggle-switch {
  width: 36px;
  height: 20px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid var(--border);
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s;
}

.toggle-knob {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--text-secondary);
  position: absolute;
  top: 2px;
  left: 2px;
  transition: transform 0.2s, background 0.2s;
}

.toggle-switch.on {
  background: rgba(255, 255, 255, 0.15);
  border-color: var(--text-secondary);
}

.toggle-switch.on .toggle-knob {
  transform: translateX(16px);
  background: var(--text-heading);
}

/* Subscription plan row */

.settings-plan-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.settings-plan-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.settings-plan-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-heading);
}

.settings-plan-meta {
  font-size: 11px;
  color: var(--text-secondary);
}

/* ── Roles & Permissions ── */

.settings-section-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 16px 16px 12px;
}

.settings-section-header .card-title {
  margin-bottom: 2px;
}

.role-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-heading);
  display: block;
}

.role-desc {
  font-size: 11px;
  color: var(--text-secondary);
  display: block;
  margin-top: 2px;
}

.col-perm {
  width: 100px;
  text-align: center !important;
}

.col-perm-members {
  width: 70px;
  text-align: center !important;
  font-size: 12px;
  color: var(--text-secondary);
}

.perm-check {
  display: inline-block;
  font-size: 14px;
  width: 22px;
  height: 22px;
  line-height: 22px;
  text-align: center;
  border-radius: 4px;
}

.perm-check.granted {
  color: var(--text-heading);
  background: rgba(255, 255, 255, 0.07);
}

.perm-check.denied {
  color: var(--text-secondary);
  opacity: 0.4;
}

/* ── Create Project Team ── */

.create-project-team {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  overflow-x: hidden;
  overflow-y: auto;
  max-height: 180px;
}

.create-project-member {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  transition: background 0.12s;
}

.create-project-member:last-child {
  border-bottom: none;
}

.create-project-member:hover {
  background: rgba(255, 255, 255, 0.03);
}

.create-project-member-name {
  font-size: 13px;
  color: var(--text-primary);
  flex: 1;
}

.create-project-member-role {
  font-size: 11px;
  color: var(--text-secondary);
}

/* ── Responsive collapse (optional future) ── */

@media (max-width: 1024px) {
  .app-shell {
    grid-template-columns: 220px 1fr;
  }
  .context-panel {
    display: none;
  }
}

@media (max-width: 768px) {
  .app-shell {
    grid-template-columns: 1fr;
  }
  .sidebar {
    display: none;
  }
}

/* ================================================================
   DRAWINGS MODULE — Full-Screen Workspace
   ================================================================ */

/* ── Layout: three-panel workspace ── */
.dwg-workspace {
  display: grid;
  grid-template-columns: 320px 1fr 0;
  grid-template-rows: auto 1fr;
  height: 100vh;
  overflow: hidden;
  background: var(--bg);
  transition: grid-template-columns 0.3s ease;
}

.dwg-workspace.panel-open {
  grid-template-columns: 320px 1fr 380px;
}

.dwg-workspace.browser-collapsed {
  grid-template-columns: 0 1fr 0;
}

.dwg-workspace.browser-collapsed.panel-open {
  grid-template-columns: 0 1fr 380px;
}

/* ── Top Header ── */
.dwg-header {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 20px;
  background: var(--sidebar);
  border-bottom: 1px solid var(--border);
  z-index: 10;
  min-height: 52px;
}

.dwg-header-back {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 13px;
  transition: color 0.15s;
  white-space: nowrap;
}

.dwg-header-back:hover { color: var(--text-primary); }

.dwg-header-back svg { width: 16px; height: 16px; }

.dwg-header-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-heading);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dwg-header-subtitle {
  font-size: 12px;
  color: var(--text-secondary);
  white-space: nowrap;
}

.dwg-header-sep {
  width: 1px;
  height: 24px;
  background: var(--border);
  flex-shrink: 0;
}

.dwg-header-spacer { flex: 1; }

.dwg-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* ── Left Browser Panel ── */
.dwg-browser {
  background: var(--sidebar);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: width 0.3s ease, opacity 0.2s ease;
}

.browser-collapsed .dwg-browser {
  opacity: 0;
  pointer-events: none;
  overflow: hidden;
}

.dwg-browser-header {
  padding: 16px 16px 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.dwg-browser-search {
  position: relative;
}

.dwg-browser-search input {
  width: 100%;
  box-sizing: border-box;
  background: var(--input-bg);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 8px 10px 8px 32px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  outline: none;
  transition: border-color 0.15s;
}

.dwg-browser-search input:focus { border-color: #444; }

.dwg-browser-search svg {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  color: var(--text-secondary);
  pointer-events: none;
}

.dwg-browser-filters {
  display: flex;
  gap: 6px;
}

.dwg-filter-btn {
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 5px;
  padding: 4px 10px;
  font-size: 11px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s;
  font-family: 'Inter', sans-serif;
  white-space: nowrap;
}

.dwg-filter-btn:hover,
.dwg-filter-btn.active {
  color: var(--text-primary);
  border-color: #444;
  background: rgba(255,255,255,0.04);
}

.dwg-browser-list {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 8px 0;
}

/* ── Drawing Group ── */
.dwg-group {
  margin-bottom: 4px;
}

.dwg-group-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px 6px;
  cursor: pointer;
  user-select: none;
}

.dwg-group-chevron {
  width: 12px;
  height: 12px;
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}

.dwg-group.collapsed .dwg-group-chevron {
  transform: rotate(-90deg);
}

.dwg-group-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
}

.dwg-group-count {
  font-size: 10px;
  color: var(--text-secondary);
  opacity: 0.6;
  margin-left: auto;
}

.dwg-group.collapsed .dwg-group-items {
  display: none;
}

/* ── Drawing Item ── */
.dwg-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 8px 16px 8px 28px;
  cursor: pointer;
  transition: background 0.12s;
  border-left: 2px solid transparent;
}

.dwg-item:hover {
  background: rgba(255,255,255,0.03);
}

.dwg-item.selected {
  background: rgba(255,255,255,0.06);
  border-left-color: var(--text-heading);
}

.dwg-item-info {
  flex: 1;
  min-width: 0;
}

.dwg-item-ref {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-heading);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dwg-item-name {
  font-size: 11px;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 2px;
}

.dwg-item-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
}

.dwg-rev-badge {
  font-size: 9px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
  letter-spacing: 0.03em;
}

.dwg-rev-badge.superseded {
  background: rgba(229,165,69,0.15);
  color: #E5A545;
}

.dwg-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #45B575;
  flex-shrink: 0;
}

.dwg-status-dot.superseded {
  background: #E5A545;
}

.dwg-pin-count {
  font-size: 9px;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 3px;
}

.dwg-pin-count svg {
  width: 10px;
  height: 10px;
}

/* ── Center Viewer ── */
.dwg-viewer {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: #080808;
  position: relative;
}

.dwg-viewer-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: var(--card);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  z-index: 5;
}

.dwg-viewer-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-heading);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dwg-viewer-rev {
  font-size: 11px;
  color: var(--text-secondary);
  white-space: nowrap;
}

.dwg-toolbar-sep {
  width: 1px;
  height: 20px;
  background: var(--border);
  flex-shrink: 0;
}

.dwg-toolbar-spacer { flex: 1; }

.dwg-toolbar-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s;
  flex-shrink: 0;
}

.dwg-toolbar-btn:hover {
  color: var(--text-primary);
  border-color: #444;
  background: rgba(255,255,255,0.04);
}

.dwg-toolbar-btn.active {
  color: var(--text-heading);
  background: rgba(255,255,255,0.08);
  border-color: #555;
}

.dwg-toolbar-btn svg { width: 16px; height: 16px; }

.dwg-toolbar-label-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  color: var(--text-secondary);
  cursor: pointer;
  font-size: 12px;
  font-family: 'Inter', sans-serif;
  transition: all 0.15s;
  white-space: nowrap;
}

.dwg-toolbar-label-btn:hover {
  color: var(--text-primary);
  border-color: #444;
  background: rgba(255,255,255,0.04);
}

.dwg-toolbar-label-btn svg { width: 14px; height: 14px; }

/* ── Canvas Area ── */
.dwg-canvas-wrap {
  flex: 1;
  position: relative;
  overflow: hidden;
  cursor: grab;
}

.dwg-canvas-wrap.panning { cursor: grabbing; }
.dwg-canvas-wrap.pin-mode { cursor: crosshair; }

.dwg-canvas {
  position: absolute;
  transform-origin: 0 0;
  transition: transform 0.1s ease-out;
}

.dwg-canvas-wrap.panning .dwg-canvas {
  transition: none;
}

/* Simulated drawing sheet */
.dwg-sheet {
  background: #FAFAFA;
  box-shadow: 0 4px 40px rgba(0,0,0,0.5);
  position: relative;
  width: 1200px;
  height: 848px; /* A1 ratio */
}

.dwg-sheet-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,0,0,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,0.04) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}

.dwg-sheet-border {
  position: absolute;
  inset: 20px;
  border: 1.5px solid #333;
  pointer-events: none;
}

.dwg-title-block {
  position: absolute;
  bottom: 20px;
  right: 20px;
  width: 280px;
  height: 100px;
  border: 1.5px solid #333;
  display: flex;
  flex-direction: column;
  pointer-events: none;
}

.dwg-title-block-row {
  display: flex;
  flex: 1;
  border-bottom: 1px solid #999;
}

.dwg-title-block-row:last-child { border-bottom: none; }

.dwg-title-block-cell {
  flex: 1;
  display: flex;
  align-items: center;
  padding: 0 6px;
  font-size: 8px;
  font-family: 'Inter', sans-serif;
  color: #333;
  border-right: 1px solid #999;
}

.dwg-title-block-cell:last-child { border-right: none; }

.dwg-title-block-cell.title-cell {
  font-size: 10px;
  font-weight: 600;
}

/* Superseded warning banner */
.dwg-superseded-banner {
  display: none;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: rgba(229,165,69,0.12);
  border-bottom: 1px solid rgba(229,165,69,0.25);
  color: #E5A545;
  font-size: 12px;
  flex-shrink: 0;
}

.dwg-superseded-banner.visible { display: flex; }

.dwg-superseded-banner svg { width: 16px; height: 16px; flex-shrink: 0; }

.dwg-superseded-banner a {
  color: #E5A545;
  text-decoration: underline;
  cursor: pointer;
  font-weight: 500;
}

/* ── Pin System ── */
.dwg-pin {
  position: absolute;
  z-index: 20;
  cursor: pointer;
  transition: transform 0.15s ease, z-index 0s;
}

.dwg-pin.selected { z-index: 30; }

.dwg-pin:not(.selected):not(:hover) {
  opacity: 1;
}

.dwg-pin-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.9);
  box-shadow: 0 0 8px rgba(0,0,0,0.4), 0 0 0 1px rgba(0,0,0,0.1);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  position: relative;
}

.dwg-pin:hover .dwg-pin-dot {
  transform: scale(1.25);
  box-shadow: 0 0 16px rgba(0,0,0,0.3), 0 0 12px currentColor;
}

.dwg-pin.selected .dwg-pin-dot {
  transform: scale(1.35);
  box-shadow: 0 0 20px rgba(0,0,0,0.3), 0 0 16px currentColor;
}

/* Pin glow ring */
.dwg-pin-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 1.5px solid currentColor;
  opacity: 0;
  transition: opacity 0.2s;
}

.dwg-pin.selected .dwg-pin-dot::after,
.dwg-pin:hover .dwg-pin-dot::after {
  opacity: 0.4;
}

/* Pin capsule (first-click preview) */
.dwg-pin-capsule {
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  background: #1E1E1E;
  border: 1px solid #333;
  border-radius: 10px;
  padding: 8px 12px;
  min-width: 180px;
  max-width: 260px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-50%) scale(0.92);
  transition: opacity 0.2s ease, transform 0.2s ease;
  box-shadow: 0 4px 20px rgba(0,0,0,0.6);
  white-space: normal;
}

.dwg-pin.expanded .dwg-pin-capsule {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(-50%) scale(1);
}

.dwg-pin-capsule-cat {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
}

.dwg-pin-capsule-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.dwg-pin-capsule-label {
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-secondary);
}

.dwg-pin-capsule-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-heading);
  line-height: 1.35;
  margin-bottom: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.dwg-pin-capsule-status {
  font-size: 10px;
  color: var(--text-secondary);
}

.dwg-pin-capsule-arrow {
  font-size: 10px;
  color: var(--text-secondary);
  margin-top: 4px;
  opacity: 0.6;
}

/* Dim other pins when one is selected */
.dwg-pins-layer.has-selection .dwg-pin:not(.selected):not(.expanded) {
  opacity: 0.45;
}

/* ── Right Context Panel ── */
.dwg-panel {
  background: var(--sidebar);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: opacity 0.2s ease;
}

.dwg-workspace:not(.panel-open) .dwg-panel {
  opacity: 0;
  pointer-events: none;
}

.dwg-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.dwg-panel-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-heading);
}

.dwg-panel-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: transparent;
  border: none;
  border-radius: 6px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s;
}

.dwg-panel-close:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.06);
}

.dwg-panel-close svg { width: 16px; height: 16px; }

.dwg-panel-body {
  flex: 1;
  overflow-y: auto;
  padding: 0;
}

.dwg-panel-section {
  padding: 16px;
  border-bottom: 1px solid var(--border-subtle);
}

.dwg-panel-section:last-child { border-bottom: none; }

.dwg-panel-section-title {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
  margin-bottom: 10px;
}

.dwg-detail-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 6px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.dwg-detail-row:last-child { border-bottom: none; }

.dwg-detail-label {
  font-size: 12px;
  color: var(--text-secondary);
  flex-shrink: 0;
  width: 100px;
}

.dwg-detail-value {
  font-size: 12px;
  color: var(--text-primary);
  text-align: right;
  word-break: break-word;
}

/* Pin detail in panel */
.dwg-pin-detail-header {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
}

.dwg-pin-detail-colour {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 3px;
}

.dwg-pin-detail-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-heading);
  line-height: 1.4;
}

.dwg-pin-detail-desc {
  font-size: 13px;
  color: var(--text-primary);
  line-height: 1.5;
  margin-bottom: 12px;
}

.dwg-pin-detail-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

/* ── Linked items list in panel ── */
.dwg-linked-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  transition: opacity 0.15s;
}

.dwg-linked-item:hover { opacity: 0.8; }
.dwg-linked-item:last-child { border-bottom: none; }

.dwg-linked-badge {
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 3px;
  flex-shrink: 0;
}

.dwg-linked-badge.badge-query { background: rgba(229,165,69,0.15); color: #E5A545; }
.dwg-linked-badge.badge-rfi { background: rgba(133,163,204,0.15); color: #8AAFCC; }
.dwg-linked-badge.badge-note { background: rgba(255,255,255,0.06); color: var(--text-secondary); }
.dwg-linked-badge.badge-pin { background: rgba(229,69,69,0.15); color: #E54545; }

.dwg-linked-text {
  font-size: 12px;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Revision history in panel ── */
.dwg-rev-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.dwg-rev-item:last-child { border-bottom: none; }

.dwg-rev-item-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 3px;
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
  flex-shrink: 0;
}

.dwg-rev-item-badge.current {
  background: rgba(69,181,117,0.15);
  color: #45B575;
}

.dwg-rev-item-info {
  flex: 1;
  min-width: 0;
}

.dwg-rev-item-date {
  font-size: 11px;
  color: var(--text-primary);
}

.dwg-rev-item-by {
  font-size: 10px;
  color: var(--text-secondary);
}

/* ── Empty states ── */
.dwg-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  text-align: center;
  padding: 40px;
}

.dwg-empty-icon {
  width: 48px;
  height: 48px;
  color: var(--text-secondary);
  opacity: 0.4;
  margin-bottom: 16px;
}

.dwg-empty-title {
  font-size: 15px;
  font-weight: 500;
  color: var(--text-heading);
  margin-bottom: 6px;
}

.dwg-empty-text {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
  max-width: 280px;
  margin-bottom: 16px;
}

/* ── Upload modal ── */
.dwg-upload-fields {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.dwg-upload-row {
  display: flex;
  gap: 12px;
}

.dwg-upload-row .builder-field { flex: 1; min-width: 0; }

.dwg-upload-dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 32px 20px;
  border: 1.5px dashed var(--border);
  border-radius: 10px;
  background: rgba(255,255,255,0.015);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  text-align: center;
}

.dwg-upload-dropzone:hover {
  border-color: #444;
  background: rgba(255,255,255,0.03);
}

.dwg-upload-dropzone svg {
  width: 32px;
  height: 32px;
  color: var(--text-secondary);
  opacity: 0.5;
}

.dwg-upload-dropzone-text {
  font-size: 13px;
  color: var(--text-secondary);
}

.dwg-upload-dropzone-hint {
  font-size: 11px;
  color: var(--text-secondary);
  opacity: 0.6;
}

/* ── Pin creation modal ── */
.dwg-pin-form .builder-form-row {
  flex-wrap: wrap;
}

/* ── Pin colour swatches in form ── */
.dwg-colour-options {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.dwg-colour-swatches {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.dwg-colour-swatch {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s;
  position: relative;
}

.dwg-colour-swatch:hover {
  transform: scale(1.1);
}

.dwg-colour-swatch.selected {
  border-color: var(--text-heading);
  box-shadow: 0 0 0 2px var(--bg), 0 0 12px currentColor;
  transform: scale(1.1);
}

.dwg-colour-active-label {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 10px;
  min-height: 16px;
  transition: color 0.15s;
}

/* ── Zoom indicator ── */
.dwg-zoom-indicator {
  position: absolute;
  bottom: 16px;
  left: 16px;
  background: rgba(20,20,20,0.85);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 11px;
  color: var(--text-secondary);
  z-index: 10;
  pointer-events: none;
}

/* ── Mini Map Navigator ── */
.dwg-minimap {
  position: absolute;
  bottom: 16px;
  right: 16px;
  width: 180px;
  height: 127px; /* 1200:848 ratio */
  background: rgba(12,12,12,0.88);
  border: 1px solid var(--border);
  border-radius: 8px;
  z-index: 10;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(0,0,0,0.5);
  display: none; /* hidden until a drawing is selected */
}

.dwg-minimap.visible {
  display: block;
}

.dwg-minimap-sheet {
  position: absolute;
  inset: 6px;
  background: rgba(250,250,250,0.08);
  border-radius: 3px;
  border: 1px solid rgba(255,255,255,0.06);
}

.dwg-minimap-viewport {
  position: absolute;
  border: 1.5px solid rgba(255,255,255,0.7);
  border-radius: 2px;
  background: rgba(255,255,255,0.06);
  transition: all 0.1s ease-out;
  box-shadow: 0 0 8px rgba(255,255,255,0.1);
  pointer-events: none;
}

.dwg-minimap-pins {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.dwg-minimap-pin {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

/* ── Pin Comments ── */
.dwg-comment {
  padding: 10px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.dwg-comment:last-child { border-bottom: none; }

.dwg-comment-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}

.dwg-comment-author {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-heading);
}

.dwg-comment-date {
  font-size: 10px;
  color: var(--text-secondary);
}

.dwg-comment-body {
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.5;
}

.dwg-comment-input-wrap {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}

.dwg-comment-input {
  flex: 1;
  background: var(--input-bg);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 8px 10px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  outline: none;
  transition: border-color 0.15s;
  min-width: 0;
  box-sizing: border-box;
}

.dwg-comment-input:focus { border-color: #444; }

.dwg-comment-send {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s;
  flex-shrink: 0;
}

.dwg-comment-send:hover {
  color: var(--text-primary);
  border-color: #444;
  background: rgba(255,255,255,0.04);
}

.dwg-comment-send svg { width: 14px; height: 14px; }

/* ── Pin Photos ── */
.dwg-photos-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dwg-photo-thumb {
  width: 72px;
  height: 72px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--border);
  cursor: pointer;
  transition: border-color 0.15s, transform 0.15s;
  position: relative;
  background: var(--input-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.dwg-photo-thumb:hover {
  border-color: #444;
  transform: scale(1.04);
}

.dwg-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dwg-photo-thumb-placeholder {
  font-size: 9px;
  color: var(--text-secondary);
  text-align: center;
  padding: 4px;
}

.dwg-photo-upload-btn {
  width: 72px;
  height: 72px;
  border-radius: 6px;
  border: 1.5px dashed var(--border);
  background: transparent;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  color: var(--text-secondary);
}

.dwg-photo-upload-btn:hover {
  border-color: #444;
  background: rgba(255,255,255,0.03);
}

.dwg-photo-upload-btn svg { width: 18px; height: 18px; }

.dwg-photo-upload-btn span { font-size: 8px; text-transform: uppercase; letter-spacing: 0.04em; }

/* Photo lightbox */
.dwg-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
}

.dwg-lightbox.open {
  opacity: 1;
  pointer-events: auto;
}

.dwg-lightbox img {
  max-width: 90vw;
  max-height: 90vh;
  border-radius: 8px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.6);
}

.dwg-lightbox-caption {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  color: var(--text-primary);
  font-size: 13px;
  background: rgba(20,20,20,0.8);
  padding: 6px 16px;
  border-radius: 6px;
}

/* ── Activity Timeline ── */
.dwg-activity-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 6px 0;
}

.dwg-activity-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 4px;
}

.dwg-activity-dot.act-created { background: #45B575; }
.dwg-activity-dot.act-comment { background: #4589E5; }
.dwg-activity-dot.act-photo { background: #9B59B6; }
.dwg-activity-dot.act-status { background: #E5A545; }
.dwg-activity-dot.act-assignment { background: #D4A574; }

.dwg-activity-info {
  flex: 1;
  min-width: 0;
}

.dwg-activity-msg {
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.4;
}

.dwg-activity-date {
  font-size: 10px;
  color: var(--text-secondary);
}

/* ================================================================
   IGNUS AI — Right-Panel Sidecar
   ================================================================ */

/* ── Panel Header ── */

.ignus-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 0 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  margin-bottom: 2px;
}

.ignus-panel-brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ignus-panel-icon {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.10);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.ignus-panel-icon svg {
  width: 16px;
  height: 16px;
  color: var(--text-primary);
}

.ignus-panel-title {
  font-size: 14px;
  font-weight: 600;
  color: #FFFFFF;
  letter-spacing: 0.03em;
  line-height: 1.2;
}

.ignus-panel-role {
  font-size: 11px;
  color: #787878;
  margin-top: 2px;
}

.ignus-panel-status {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #5A9A5A;
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(90, 154, 90, 0.1);
  border: 1px solid rgba(90, 154, 90, 0.15);
}

/* ── Source Mode Bar (panel) ── */

.ignus-source-mode-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-bottom: 1px solid var(--border-subtle);
  background: rgba(255, 255, 255, 0.015);
}

.ignus-source-mode-icon {
  width: 14px;
  height: 14px;
  color: var(--text-secondary);
  flex-shrink: 0;
  opacity: 0.7;
}


/* ── Section Labels ── */

.ignus-panel-section-label {
  font-size: 10px;
  font-weight: 600;
  color: #808080;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  margin-bottom: 10px;
}

/* ── Context Block ── */

.ignus-panel-context {
  padding: 12px 0 10px;
  border-bottom: none;
}

.ignus-context-items {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ignus-context-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
}

.ignus-context-key {
  font-size: 12px;
  color: #707070;
}

.ignus-context-val {
  font-size: 12px;
  font-weight: 500;
  color: #E0E0E0;
}

/* ── Ask Ignus Chat ── */

.ignus-chat {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  margin-top: 8px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  overflow: hidden;
}

.ignus-chat-thread {
  flex: 1;
  overflow-y: auto;
  padding: 16px 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ignus-chat-welcome {
  padding: 10px 0 6px;
}

.ignus-chat-welcome p {
  font-size: 12.5px;
  color: #888;
  line-height: 1.6;
  margin: 0;
}

/* Message bubbles */
.ignus-msg {
  font-size: 13px;
  line-height: 1.6;
  padding: 12px 14px;
  border-radius: 10px;
  max-width: 96%;
  word-wrap: break-word;
}

.ignus-msg p {
  margin: 0 0 0.65em 0;
}

.ignus-msg p:last-child {
  margin-bottom: 0;
}

.ignus-msg-user {
  align-self: flex-end;
  background: rgba(255, 255, 255, 0.07);
  color: #E0E0E0;
  border-bottom-right-radius: 3px;
}

.ignus-msg-ignus {
  align-self: flex-start;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: #D8D8D8;
  border-bottom-left-radius: 3px;
  line-height: 1.75;
  max-width: 100%;
}

.ignus-msg-error {
  background: rgba(200, 60, 60, 0.08);
  border-color: rgba(200, 60, 60, 0.2);
  color: #D4786E;
}

.ignus-msg-loading p {
  color: var(--text-secondary);
}

@keyframes ignus-pulse {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

.ignus-msg-loading .ignus-msg-loading {
  animation: ignus-pulse 1.5s ease-in-out infinite;
}

/* Answer and sources inside assistant bubble */
.ignus-response-answer {
  margin-bottom: 12px;
}

/* ── Context summary strip ── */
.ignus-context-strip {
  font-size: 11px;
  color: var(--text-secondary);
  opacity: 0.6;
  padding: 6px 0 8px;
  line-height: 1.4;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: 10px;
}
.ignus-context-dot {
  margin: 0 4px;
  opacity: 0.4;
}

/* ── Ask Ignus button on drawings panel ── */
.dwg-ask-ignus-btn {
  display: block;
  width: 100%;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 500;
  text-align: center;
  text-decoration: none;
  color: var(--text-secondary);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-btn);
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.dwg-ask-ignus-btn:hover {
  color: var(--text-primary);
  border-color: var(--border);
  background: rgba(255,255,255,0.05);
}

/* ── Structured answer title ── */
.ignus-answer-title {
  font-size: 13px;
  font-weight: 600;
  color: #EFEFEF;
  margin: 0 0 10px;
  line-height: 1.35;
  letter-spacing: 0.01em;
}

/* ── Section headings (Conclusion, Technical basis, etc.) ── */
.ignus-answer-section-heading {
  font-size: 11px;
  font-weight: 600;
  color: #999;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 14px 0 6px;
  padding-bottom: 4px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.ignus-answer-section-heading:first-child {
  margin-top: 0;
}

/* ── Section body text ── */
.ignus-response-answer p {
  font-size: 13px;
  line-height: 1.75;
  color: #D0D0D0;
  margin: 0 0 0.7em;
}

.ignus-response-answer p:last-child {
  margin-bottom: 0;
}

.ignus-response-answer ul,
.ignus-response-answer ol {
  margin: 0.5em 0 0.8em;
  padding-left: 1.2em;
}

.ignus-response-answer li {
  margin-bottom: 0.45em;
  font-size: 13px;
  line-height: 1.7;
  color: #C8C8C8;
}

.ignus-response-answer li:last-child {
  margin-bottom: 0;
}

.ignus-response-answer strong {
  color: #E8E8E8;
  font-weight: 600;
}

/* ── Important callout ── */
.ignus-answer-callout {
  margin: 10px 0 8px;
  padding: 10px 12px;
  border-radius: 6px;
  background: rgba(255, 200, 60, 0.04);
  border-left: 2px solid rgba(255, 200, 60, 0.25);
  font-size: 12.5px;
  line-height: 1.65;
  color: #C8B87A;
}

.ignus-answer-callout strong {
  color: #D4C88A;
}

/* ── Option comparison block ── */
.ignus-answer-options {
  margin: 10px 0 8px;
  padding: 10px 12px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.ignus-answer-options ul {
  margin: 0;
  padding-left: 1.2em;
}

.ignus-answer-options li {
  color: #BCBCBC;
}

/* ── Inline citation anchors ── */
.ignus-cite-anchor {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Inter', sans-serif;
  font-size: 9.5px;
  font-weight: 600;
  color: #888;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 4px;
  padding: 0 4.5px;
  min-width: 18px;
  height: 17px;
  margin-left: 3px;
  cursor: pointer;
  vertical-align: baseline;
  position: relative;
  top: -1px;
  transition: color 0.15s, background 0.15s, border-color 0.15s;
  line-height: 1;
}

.ignus-cite-anchor:hover {
  color: #C0C0C0;
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.16);
}

.ignus-cite-anchor-active,
.ignus-cite-anchor-active:hover {
  color: #E0E0E0;
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.22);
}

/* Source chip number badge (matches inline anchor styling) */
.ignus-source-chip-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  color: #888;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  min-width: 15px;
  height: 15px;
  padding: 0 3px;
  margin-right: 1px;
}

.ignus-source-chip-active .ignus-source-chip-num {
  color: #C0C0C0;
  background: rgba(255, 255, 255, 0.10);
}

.ignus-response-sources {
  padding-top: 10px;
  margin-top: 4px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.ignus-response-sources-label {
  font-size: 10px;
  font-weight: 600;
  color: #777;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}

.ignus-response-source {
  display: inline-block;
  font-size: 11px;
  color: var(--text-secondary);
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-subtle);
  margin: 0 4px 4px 0;
}

/* Clickable source chips */
.ignus-source-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: var(--text-secondary);
  padding: 5px 10px;
  border-radius: 5px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-subtle);
  margin: 0 4px 4px 0;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.ignus-source-chip:hover {
  color: var(--text-primary);
  border-color: #555;
  background: rgba(255, 255, 255, 0.07);
}

.ignus-source-chip-active {
  color: var(--text-primary);
  border-color: rgba(255, 255, 255, 0.25);
  background: rgba(255, 255, 255, 0.08);
}

.ignus-source-chip svg {
  flex-shrink: 0;
  opacity: 0.5;
}

/* Source detail expansion */
.ignus-source-detail {
  margin: 6px 0 8px;
  padding: 0;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border-subtle);
  overflow: hidden;
}

/* Evidence header — metadata + view-source action */
.ignus-evidence-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(255, 255, 255, 0.015);
}

.ignus-evidence-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  flex: 1;
}

.ignus-evidence-doc {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.ignus-evidence-icon {
  flex-shrink: 0;
  color: rgba(255, 255, 255, 0.4);
}

.ignus-evidence-docname {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ignus-evidence-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.ignus-evidence-tag {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.55);
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  padding: 2px 6px;
  line-height: 1;
}

.ignus-evidence-tag-section {
  color: rgba(255, 255, 255, 0.45);
  font-weight: 500;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ignus-evidence-tag-type {
  font-size: 9px;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.35);
}

.ignus-evidence-tag-figure {
  color: #7ecfff;
  font-weight: 500;
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ignus-evidence-tag-table {
  color: #a8d8a0;
  font-weight: 500;
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Drawing evidence tags */
.ignus-evidence-tag-drawing {
  color: #f0a55a;
  font-size: 9px;
  letter-spacing: 0.06em;
  font-weight: 600;
  text-transform: uppercase;
}

.ignus-evidence-tag-sheet {
  color: #60a5fa;
  font-weight: 600;
}

.ignus-evidence-tag-region {
  color: rgba(255, 255, 255, 0.45);
  font-weight: 500;
  text-transform: capitalize;
}

.ignus-evidence-tag-revision {
  color: rgba(255, 255, 255, 0.4);
  font-size: 9px;
  font-weight: 500;
}

/* Drawing source chip accent */
.ignus-source-chip-drawing {
  border-color: rgba(240, 165, 90, 0.2);
}

.ignus-source-chip-drawing:hover {
  border-color: rgba(240, 165, 90, 0.4);
  background: rgba(240, 165, 90, 0.06);
}

.ignus-source-chip-drawing.ignus-source-chip-active {
  border-color: rgba(240, 165, 90, 0.5);
  background: rgba(240, 165, 90, 0.1);
}

/* Drawing source detail panel accent */
.ignus-source-detail-drawing {
  border-left: 2px solid rgba(240, 165, 90, 0.3);
}

/* Overload notice */
.ignus-overload-notice {
  background: rgba(240, 165, 90, 0.08);
  border: 1px solid rgba(240, 165, 90, 0.2);
  border-radius: 6px;
  padding: 14px 18px;
  margin: 4px 0;
}
.ignus-overload-notice p {
  margin: 0 0 6px 0;
  color: rgba(255, 255, 255, 0.75);
  font-size: 13px;
  line-height: 1.5;
}
.ignus-overload-notice p:last-child { margin-bottom: 0; }
.ignus-overload-notice strong { color: #f0a55a; }

/* View source page action */
.ignus-evidence-view-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.5);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 4px;
  padding: 5px 10px;
  cursor: pointer;
  transition: all 0.15s ease;
  white-space: nowrap;
}
.ignus-evidence-view-btn:hover {
  color: rgba(255, 255, 255, 0.8);
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.16);
}
.ignus-evidence-view-btn:disabled {
  opacity: 0.6;
  cursor: default;
}

@keyframes ignus-spin {
  to { transform: rotate(360deg); }
}
.ignus-evidence-spinner {
  animation: ignus-spin 0.8s linear infinite;
}

/* Source detail — legacy label (kept for compatibility) */
.ignus-source-detail-label {
  display: none;
}

/* Source extract text */
.ignus-source-detail-snippet {
  font-size: 12px;
  line-height: 1.55;
  color: var(--text-primary);
  margin: 0;
  padding: 10px 12px;
  opacity: 0.85;
}

/* Snippet highlight — amber tint for cited passage */
.ignus-snippet-highlight {
  background: rgba(255, 180, 50, 0.18);
  color: #F5E4C0;
  border-radius: 3px;
  padding: 2px 4px;
  border-left: 2px solid rgba(255, 180, 50, 0.45);
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

/* Composer dock */
.ignus-chat-composer {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  padding: 10px 12px 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.15);
}

/* Input field */
.ignus-chat-input {
  flex: 1;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  padding: 10px 14px;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  line-height: 1.4;
  outline: none;
  resize: none;
  overflow-y: hidden;
  min-height: 38px;
  max-height: 120px;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.ignus-chat-input::placeholder {
  color: #606060;
  font-weight: 400;
}

.ignus-chat-input:hover {
  border-color: rgba(255, 255, 255, 0.16);
}

.ignus-chat-input:focus {
  border-color: rgba(255, 255, 255, 0.24);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.04);
}

/* Send button */
.ignus-chat-send {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  margin-bottom: 1px;
}

.ignus-chat-send:hover {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.2);
  color: var(--text-heading);
}

.ignus-chat-send:active {
  background: rgba(255, 255, 255, 0.18);
}

.ignus-chat-send:disabled {
  opacity: 0.25;
  cursor: default;
}

.ignus-chat-send svg {
  width: 15px;
  height: 15px;
  stroke-width: 2.2;
}

/* ── Suggestion Chips (inside thread) ── */

.ignus-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 2px;
}

.ignus-chip {
  font-size: 11px;
  font-family: 'Inter', sans-serif;
  color: #888;
  padding: 6px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: rgba(255, 255, 255, 0.02);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
  line-height: 1.35;
}

.ignus-chip:hover {
  color: #D0D0D0;
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.05);
}

/* ── Secondary Action Buttons ── */

.ignus-panel-actions {
  padding: 12px 0 0;
  opacity: 0.55;
  transition: opacity 0.2s;
}

.ignus-panel-actions:hover {
  opacity: 0.9;
}

.ignus-action-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ignus-action-btn {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 10px;
  border-radius: 5px;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  color: #666;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
}

.ignus-action-btn:hover {
  color: #B0B0B0;
  background: rgba(255, 255, 255, 0.03);
}

.ignus-action-btn svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  stroke: currentColor;
}

/* ── Floating Ask Ignus Trigger ── */

.ignus-fab {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 1000;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: var(--accent);
  color: #0C0C0C;
  border: none;
  border-radius: 28px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(255, 255, 255, 0.05);
  transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
  text-decoration: none;
}

.ignus-fab:hover {
  background: #FFFFFF;
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.ignus-fab:active {
  transform: translateY(0);
}

.ignus-fab svg {
  width: 16px;
  height: 16px;
}

@media (max-width: 1024px) {
  .ignus-fab {
    bottom: 16px;
    right: 16px;
    padding: 10px 16px;
    font-size: 12px;
  }
}

/* ── Toast notification ── */
.ignus-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  padding: 10px 20px;
  border-radius: var(--radius-input);
  font-size: 13px;
  font-family: 'Inter', sans-serif;
  z-index: 10000;
  pointer-events: none;
  max-width: 480px;
}
.ignus-toast--success {
  background: rgba(34, 197, 94, 0.12);
  color: #4ade80;
  border: 1px solid rgba(34, 197, 94, 0.2);
}
.ignus-toast--error {
  background: rgba(239, 68, 68, 0.12);
  color: #f87171;
  border: 1px solid rgba(239, 68, 68, 0.2);
}

/* ── Invitation status badges ── */
.inv-status {
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: capitalize;
}
.inv-status--pending {
  background: rgba(59, 130, 246, 0.1);
  color: #60a5fa;
}
.inv-status--accepted {
  background: rgba(34, 197, 94, 0.1);
  color: #4ade80;
}
.inv-status--expired,
.inv-status--revoked {
  background: rgba(122, 122, 122, 0.1);
  color: var(--text-secondary);
}
.inv-status--declined {
  background: rgba(239, 68, 68, 0.08);
  color: #f87171;
}
.inv-action--cancel {
  color: #f87171 !important;
  border-color: rgba(239, 68, 68, 0.2) !important;
}
.inv-action--cancel:hover {
  background: rgba(239, 68, 68, 0.08) !important;
}

/* ── Project Documents: inline action buttons ── */
.btn-sm {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
  padding: 3px 8px;
  border-radius: var(--radius-btn);
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  letter-spacing: 0.01em;
}
.btn-sm:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: #444;
  color: var(--text-primary);
}
.btn-archive-doc:hover {
  border-color: var(--danger, #e74c3c);
  color: var(--danger, #e74c3c);
}

/* ── Task Intelligence: Suggestion Banners ── */
.suggestion-banner {
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-radius: 8px;
  padding: 10px 12px;
  margin: 8px 16px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.suggestion-banner.suggestion-urgent {
  background: rgba(245, 158, 11, 0.1);
  border-color: rgba(245, 158, 11, 0.3);
}
.suggestion-reason {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  font-size: 12px;
  color: #93A3B8;
  line-height: 1.4;
}
.suggestion-urgent .suggestion-reason {
  color: #F59E0B;
}
.suggestion-reason svg {
  color: #3B82F6;
  margin-top: 1px;
}
.suggestion-urgent .suggestion-reason svg {
  color: #F59E0B;
}
.btn-suggestion {
  background: rgba(59, 130, 246, 0.15);
  color: #60A5FA;
  border: 1px solid rgba(59, 130, 246, 0.3);
  border-radius: 6px;
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  width: 100%;
  text-align: center;
}
.btn-suggestion:hover {
  background: rgba(59, 130, 246, 0.25);
  border-color: rgba(59, 130, 246, 0.5);
}
.suggestion-urgent .btn-suggestion {
  background: rgba(245, 158, 11, 0.15);
  color: #F59E0B;
  border-color: rgba(245, 158, 11, 0.3);
}
.suggestion-urgent .btn-suggestion:hover {
  background: rgba(245, 158, 11, 0.25);
  border-color: rgba(245, 158, 11, 0.5);
}
.btn-suggestion-inline {
  background: rgba(59, 130, 246, 0.12);
  color: #60A5FA;
  border: 1px solid rgba(59, 130, 246, 0.25);
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  margin-left: auto;
  flex-shrink: 0;
  transition: background 0.15s;
}
.btn-suggestion-inline:hover {
  background: rgba(59, 130, 246, 0.25);
}

/* ── Phase 7: Planning/Control Foundation ── */
.task-workstream-badge {
  display: inline-block;
  background: rgba(139, 92, 246, 0.12);
  color: #A78BFA;
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 4px;
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
}
.task-cell-workstream {
  max-width: 160px;
}
.task-blocked-badge {
  display: inline-block;
  background: rgba(239, 68, 68, 0.15);
  color: #EF4444;
  font-size: 10px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 3px;
  margin-right: 4px;
  vertical-align: middle;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.summary-card-blocked {
  border-color: rgba(239, 68, 68, 0.3);
}
.summary-card-blocked .stat-number {
  color: #EF4444;
}
.summary-card-blocked .stat-label {
  color: #EF4444;
  opacity: 0.8;
}
.blocked-toggle-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  padding: 6px 0;
}
.blocked-toggle-input {
  accent-color: #EF4444;
  width: 16px;
  height: 16px;
  cursor: pointer;
}
.blocked-toggle-text {
  font-size: 13px;
  color: var(--text-secondary);
}


/* ═══════════════════════════════════════════════
   Organisation Settings
   ═══════════════════════════════════════════════ */

/* ── Completion bar ── */
.org-completion {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 20px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  margin-bottom: 8px;
}
.org-completion-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.org-completion-track {
  flex: 1;
  height: 6px;
  background: var(--border);
  border-radius: 3px;
  overflow: hidden;
}
.org-completion-fill {
  height: 100%;
  background: #45B575;
  border-radius: 3px;
  transition: width 0.4s ease;
}
.org-completion-pct {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  min-width: 38px;
  text-align: right;
}

/* ── Section card ── */
.org-section {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  margin-bottom: 10px;
  overflow: hidden;
  flex-shrink: 0;
}
.org-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  cursor: pointer;
  user-select: none;
  border-bottom: 1px solid transparent;
}
.org-section.expanded .org-section-header {
  border-bottom-color: var(--border-subtle);
}
.org-section-header:hover {
  background: rgba(255,255,255,0.03);
}
.org-section-left {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.org-section-icon {
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
  flex-shrink: 0;
}
.org-section-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-heading);
}
.org-section-chevron {
  width: 16px;
  height: 16px;
  color: var(--text-secondary);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}
.org-section.expanded .org-section-chevron {
  transform: rotate(180deg);
}

.org-section-body {
  display: none;
  padding: 0 22px 22px;
}
.org-section.expanded .org-section-body {
  display: block;
}

.org-section-guidance {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 20px;
}

/* ── Form layout within sections ── */
.org-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.org-form-row {
  display: flex;
  gap: 16px;
}
.org-form-row > .builder-field {
  flex: 1;
  min-width: 0;
}
/* Org settings — labels */
.org-section .builder-label {
  color: var(--text-primary);
  opacity: 0.7;
}

/* ── Team member rows ── */
.org-team-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}
.org-team-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-card);
  background: var(--bg);
  transition: border-color 0.15s;
}
.org-team-row:hover {
  border-color: var(--border);
}
.org-team-fields {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  min-width: 0;
}
.org-team-fields .builder-input,
.org-team-fields .builder-select {
  font-size: 13px;
}
/* 3-across row for name · email · phone */
.org-team-row-top {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr 0.8fr;
  gap: 8px;
}
.org-team-remove {
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-btn);
  color: var(--text-secondary);
  width: 32px;
  height: 32px;
  cursor: pointer;
  flex-shrink: 0;
  opacity: 0.3;
  margin-top: 1px;
  transition: opacity 0.15s, color 0.15s, border-color 0.15s;
}
.org-team-remove:hover {
  opacity: 1;
  color: #E54545;
  border-color: rgba(229, 69, 69, 0.2);
}
.org-team-remove svg { pointer-events: none; }
.org-add-member-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 24px;
}

/* ── Primary Contacts ── */
.org-responsibilities {
  border-top: 1px solid var(--border-subtle);
  padding-top: 22px;
  margin-top: 8px;
}
.org-responsibilities-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 10px;
}
.org-resp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 28px;
  margin-bottom: 10px;
}
.org-resp-row {
  display: flex;
  align-items: center;
  gap: 14px;
}
.org-resp-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  white-space: nowrap;
  min-width: 160px;
}

/* ── Required marker ── */
.field-required::after {
  content: ' *';
  color: #E54545;
  font-weight: 400;
}

/* ── Field validation error ── */
.builder-input.field-error,
.builder-select.field-error {
  border-color: #E54545;
}
.field-error-msg {
  font-size: 11px;
  color: #E54545;
  margin-top: 2px;
}

/* ── Section footer ── */
.org-section-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding-top: 18px;
  margin-top: 6px;
  border-top: 1px solid var(--border-subtle);
}
.org-save-status {
  font-size: 12px;
  color: var(--text-secondary);
  transition: opacity 0.3s;
}
.org-save-status.success {
  color: #45B575;
}
.org-save-status.error {
  color: #E54545;
}

/* ── Address sub-heading ── */
.org-address-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
  margin-top: 4px;
}
.org-address-label:first-child {
  margin-top: 0;
}

/* ── Admin-only banner ── */
.org-admin-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  background: rgba(229, 165, 69, 0.08);
  border: 1px solid rgba(229, 165, 69, 0.25);
  border-radius: var(--radius-card);
  color: #E5A545;
  font-size: 13px;
  margin-bottom: 8px;
}
.org-admin-banner svg {
  flex-shrink: 0;
  color: #E5A545;
}

/* ── Read-only / disabled field state ── */
.builder-input:disabled,
.builder-select:disabled,
.builder-textarea:disabled,
.builder-input.field-readonly,
.builder-select.field-readonly,
.builder-textarea.field-readonly {
  opacity: 0.5;
  cursor: not-allowed;
}
.org-section-footer .btn-primary:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ── Logo upload ── */
.org-logo-upload {
  border: 1px dashed var(--border);
  border-radius: var(--radius-card);
  cursor: pointer;
  position: relative;
  transition: border-color 0.15s;
}
.org-logo-upload:hover,
.org-logo-upload.drag-over {
  border-color: var(--text-secondary);
}
.org-logo-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 28px 20px;
  color: var(--text-secondary);
  font-size: 13px;
}
.org-logo-placeholder svg {
  opacity: 0.5;
}
.org-logo-hint {
  font-size: 11px;
  opacity: 0.6;
}
.org-logo-preview {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  position: relative;
  min-height: 80px;
}
.org-logo-preview img {
  max-width: 220px;
  max-height: 80px;
  object-fit: contain;
}
.org-logo-remove {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--card-raised);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  width: 24px;
  height: 24px;
  border-radius: 50%;
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.org-logo-remove:hover {
  color: #E54545;
  border-color: #E54545;
}
.org-logo-status {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 4px;
  display: block;
  min-height: 16px;
}
.org-logo-status.error {
  color: #E54545;
}

/* ── Section badge (optional indicator) ── */
.org-section-badge {
  font-size: 10px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(69, 181, 117, 0.12);
  color: #45B575;
  margin-left: 10px;
}
.org-section-badge.incomplete {
  background: rgba(229, 165, 69, 0.12);
  color: #E5A545;
}
.org-section-badge.empty {
  background: rgba(122, 122, 122, 0.1);
  color: var(--text-secondary);
}


/* ═══════════════════════════════════════════════
   Schedule Import & Review
   ═══════════════════════════════════════════════ */

/* Upload drop zone */
.schedule-upload-area {
  border: 2px dashed var(--border);
  border-radius: var(--radius-card);
  padding: 40px 20px;
  cursor: pointer;
  transition: border-color 0.15s;
}
.schedule-upload-area:hover {
  border-color: var(--text-secondary);
}

/* Summary bar */
.schedule-summary-bar {
  display: flex;
  gap: 0;
  padding: 0;
  overflow: hidden;
}
.schedule-summary-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 16px 12px;
  border-right: 1px solid var(--border-subtle);
}
.schedule-summary-stat:last-child { border-right: none; }
.schedule-summary-value {
  font-size: 20px;
  font-weight: 600;
  color: var(--text-heading);
}
.schedule-summary-label {
  font-size: 11px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 2px;
}

/* Pipeline stages */
.schedule-stages {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.schedule-stage {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 4px;
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
}
.schedule-stage.stage-ok { color: #4ade80; border-color: rgba(34,197,94,0.2); background: rgba(34,197,94,0.06); }
.schedule-stage.stage-fail { color: #f87171; border-color: rgba(239,68,68,0.2); background: rgba(239,68,68,0.06); }
.schedule-stage.stage-warn { color: #f59e0b; border-color: rgba(245,158,11,0.2); background: rgba(245,158,11,0.06); }

/* Warnings list */
.schedule-warnings {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.schedule-warnings li {
  font-size: 12px;
  color: var(--text-secondary);
  padding: 6px 10px;
  background: rgba(255,255,255,0.02);
  border-radius: 4px;
  border-left: 3px solid var(--border);
}

/* Confidence badges */
.schedule-conf {
  font-size: 11px;
  font-weight: 500;
  padding: 2px 6px;
  border-radius: 3px;
}
.conf-high { color: #4ade80; background: rgba(34,197,94,0.08); }
.conf-med  { color: #f59e0b; background: rgba(245,158,11,0.08); }
.conf-low  { color: #f87171; background: rgba(239,68,68,0.08); }

/* Count badge */
.schedule-count-badge {
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(255,255,255,0.06);
  color: var(--text-secondary);
}

/* Review table */
.schedule-review-table {
  overflow-x: auto;
}
.schedule-review-table .data-table {
  width: 100%;
}

/* Schedule grid */
.schedule-grid-wrap {
  overflow: auto;
  max-height: 500px;
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
}
.schedule-grid {
  border-collapse: collapse;
  width: max-content;
  min-width: 100%;
  font-size: 12px;
}
.schedule-grid th,
.schedule-grid td {
  padding: 8px 12px;
  border: 1px solid var(--border-subtle);
  white-space: nowrap;
}
.schedule-grid thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--card-raised);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--text-secondary);
}
.schedule-grid-corner {
  position: sticky;
  left: 0;
  z-index: 3;
  background: var(--card-raised);
}
.schedule-grid-zone {
  text-align: center;
  min-width: 100px;
}
.schedule-grid-activity {
  position: sticky;
  left: 0;
  z-index: 1;
  background: var(--card);
  font-weight: 500;
  color: var(--text-primary);
  min-width: 180px;
  border-right: 2px solid var(--border) !important;
}

/* Grid cells */
.schedule-grid-cell {
  text-align: center;
  position: relative;
  min-width: 100px;
}
.schedule-cell-label {
  font-size: 11px;
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 120px;
}
.schedule-cell-flag {
  position: absolute;
  top: 2px;
  right: 4px;
  font-size: 10px;
  color: #f59e0b;
  font-weight: 600;
}

/* Cell status colors */
.schedule-cell-planned    { background: rgba(255,255,255,0.02); color: var(--text-secondary); }
.schedule-cell-ready      { background: rgba(168,85,247,0.08); color: #a855f7; }
.schedule-cell-in_progress { background: rgba(59,130,246,0.08); color: #60a5fa; }
.schedule-cell-complete   { background: rgba(34,197,94,0.08); color: #4ade80; }
.schedule-cell-blocked    { background: rgba(239,68,68,0.08); color: #f87171; }
.schedule-cell-delayed    { background: rgba(245,158,11,0.08); color: #f59e0b; }
.schedule-cell-na         { background: transparent; color: var(--text-secondary); opacity: 0.4; }
.schedule-cell-empty      { background: transparent; }
.schedule-cell-unverified { background: repeating-linear-gradient(135deg, transparent, transparent 3px, rgba(251,191,36,0.06) 3px, rgba(251,191,36,0.06) 6px) !important; border: 1px dashed rgba(251,191,36,0.25) !important; }
.schedule-cell-selected   { outline: 2px solid var(--text-heading); outline-offset: -2px; }

/* ── Planning screen ── */
.planning-filters {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.planning-view-toggle {
  display: flex;
  gap: 2px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-btn);
  overflow: hidden;
}
.planning-view-btn {
  background: transparent;
  border: none;
  padding: 6px 10px;
  cursor: pointer;
  color: var(--text-secondary);
  transition: background 0.15s, color 0.15s;
  position: relative;
  outline: none;
}
.planning-view-btn:hover { color: var(--text-primary); background: rgba(255,255,255,0.03); }
.planning-view-btn:focus-visible { box-shadow: 0 0 0 2px rgba(96,165,250,0.5); border-radius: 4px; }
.planning-view-btn.active {
  background: rgba(255,255,255,0.08);
  color: var(--text-heading);
}

/* Link checklist in modal */
.link-checklist {
  max-height: 160px;
  overflow-y: auto;
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 4px;
}
.link-check-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  font-size: 12px;
  color: var(--text-primary);
  cursor: pointer;
  border-radius: 4px;
}
.link-check-item:hover { background: rgba(255,255,255,0.03); }
.link-check-item input { flex-shrink: 0; }

/* ── Warning indicators on grid cells ── */
.schedule-cell-warn-dot {
  position: absolute;
  top: 3px;
  left: 4px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--text-secondary);
}
.schedule-cell-warn-critical .schedule-cell-warn-dot { background: #ef4444; }
.schedule-cell-warn-risk .schedule-cell-warn-dot     { background: #f59e0b; }
.schedule-cell-warn-watch .schedule-cell-warn-dot    { background: #60a5fa; }
.schedule-cell-warn-info .schedule-cell-warn-dot     { background: var(--text-secondary); }

/* Warning badges (list view + panel) */
.warn-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 3px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.warn-badge-critical { background: rgba(239,68,68,0.12); color: #f87171; }
.warn-badge-risk     { background: rgba(245,158,11,0.12); color: #fbbf24; }
.warn-badge-watch    { background: rgba(96,165,250,0.10); color: #60a5fa; }
.warn-badge-info     { background: rgba(255,255,255,0.06); color: var(--text-secondary); }

/* Warning items in right panel */
.plan-warning-item {
  padding: 10px 0;
  border-bottom: 1px solid var(--border-subtle);
}
.plan-warning-item:last-child { border-bottom: none; }
.plan-warning-acked { opacity: 0.5; }
.plan-warning-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}
.plan-warning-type {
  font-size: 11px;
  color: var(--text-secondary);
  text-transform: capitalize;
}
.plan-warning-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.plan-warning-summary {
  font-size: 11px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 6px;
}
.plan-warning-ack {
  font-size: 11px;
  margin-top: 2px;
}

/* Warnings-only toggle in filter bar */
.planning-toggle-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-secondary);
  cursor: pointer;
  white-space: nowrap;
}
.planning-toggle-label input {
  accent-color: #60a5fa;
}

/* ── Zone mapping status badges ── */
.zm-status {
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 4px;
  display: inline-block;
}
.zm-status-mapped   { background: rgba(34,197,94,0.1); color: #4ade80; }
.zm-status-sheet    { background: rgba(96,165,250,0.1); color: #60a5fa; }
.zm-status-unmapped { background: rgba(122,122,122,0.1); color: var(--text-secondary); }
.zm-status-review   { background: rgba(245,158,11,0.1); color: #fbbf24; }

.zm-btn-map {
  min-width: 50px;
}

/* ── Eircode copy button ── */
.eircode-copy {
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 3px;
  cursor: pointer;
  margin-left: 6px;
  vertical-align: middle;
  transition: color 0.15s, border-color 0.15s;
}
.eircode-copy:hover {
  color: var(--text-primary);
  border-color: var(--border);
}

/* ══════════════════════════════════════════════════════════════════
   Phase 04 — Timeline Planning UI
   ══════════════════════════════════════════════════════════════════ */

/* ── Timeline wrapper: left panel + chart ── */
.tl-container {
  display: flex;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  background: var(--bg-card);
}

/* ── Left structure panel ── */
.tl-left {
  width: 380px;
  min-width: 280px;
  max-width: 480px;
  flex-shrink: 0;
  overflow-y: auto;
  border-right: 1px solid var(--border-subtle);
}
.tl-left-header {
  display: grid;
  grid-template-columns: 1fr 70px 70px 70px;
  gap: 0;
  padding: 0 12px;
  height: 36px;
  align-items: center;
  border-bottom: 1px solid var(--border-subtle);
  background: rgba(255,255,255,0.02);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-secondary);
  position: sticky;
  top: 0;
  z-index: 2;
}
.tl-left-header span { padding: 0 4px; }

/* Group row (zone header) */
.tl-group {
  display: grid;
  grid-template-columns: 1fr 70px 70px 70px;
  gap: 0;
  padding: 0 12px;
  height: 32px;
  align-items: center;
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  user-select: none;
}
.tl-group:hover { background: rgba(255,255,255,0.05); }
.tl-group-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-heading);
  display: flex;
  align-items: center;
  gap: 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tl-group-arrow {
  font-size: 10px;
  color: var(--text-secondary);
  transition: transform 0.15s;
  flex-shrink: 0;
}
.tl-group.collapsed .tl-group-arrow { transform: rotate(-90deg); }
.tl-group-count {
  font-size: 10px;
  color: var(--text-secondary);
  margin-left: 4px;
}

/* Activity row */
.tl-row {
  display: grid;
  grid-template-columns: 1fr 70px 70px 70px;
  gap: 0;
  padding: 0 12px 0 28px;
  height: 32px;
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,0.02);
  cursor: pointer;
  transition: background 0.1s;
}
.tl-row:hover { background: rgba(255,255,255,0.03); }
.tl-row.selected { background: rgba(96,165,250,0.08); }
.tl-row-name {
  font-size: 12px;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tl-row-cell {
  font-size: 11px;
  color: var(--text-secondary);
  padding: 0 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Status badges in left panel */
.tl-status {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  padding: 1px 6px;
  border-radius: 3px;
  text-transform: capitalize;
}
.tl-status-planned    { background: rgba(255,255,255,0.04); color: var(--text-secondary); }
.tl-status-ready      { background: rgba(168,85,247,0.12); color: #a855f7; }
.tl-status-in_progress { background: rgba(59,130,246,0.12); color: #60a5fa; }
.tl-status-complete   { background: rgba(34,197,94,0.12); color: #4ade80; }
.tl-status-blocked    { background: rgba(239,68,68,0.12); color: #f87171; }
.tl-status-delayed    { background: rgba(245,158,11,0.12); color: #f59e0b; }

/* Unverified indicator in left panel */
.tl-row.unverified .tl-row-name::after {
  content: '?';
  font-size: 9px;
  color: #f59e0b;
  margin-left: 4px;
  opacity: 0.7;
}

/* ── Right timeline chart ── */
.tl-chart {
  flex: 1;
  overflow-x: auto;
  overflow-y: auto;
  position: relative;
}
.tl-chart-inner {
  position: relative;
  min-height: 100%;
}

/* Timeline header (date axis) */
.tl-axis {
  position: sticky;
  top: 0;
  z-index: 2;
  height: 36px;
  display: flex;
  background: rgba(255,255,255,0.02);
  border-bottom: 1px solid var(--border-subtle);
}
.tl-axis-cell {
  flex-shrink: 0;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--text-secondary);
  border-right: 1px solid rgba(255,255,255,0.03);
  box-sizing: border-box;
}
.tl-axis-cell.month-start {
  font-weight: 600;
  color: var(--text-primary);
  border-right-color: rgba(255,255,255,0.08);
}
.tl-axis-cell.weekend { background: rgba(255,255,255,0.01); }

/* Chart rows (aligned with left panel rows) */
.tl-chart-row {
  height: 32px;
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,0.02);
}
.tl-chart-group {
  height: 32px;
  background: rgba(255,255,255,0.015);
  border-bottom: 1px solid var(--border-subtle);
}

/* Today line */
.tl-today {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 2px;
  background: #ef4444;
  z-index: 3;
  pointer-events: none;
}
.tl-today::before {
  content: 'Today';
  position: absolute;
  top: 2px;
  left: 4px;
  font-size: 9px;
  color: #ef4444;
  font-weight: 600;
  white-space: nowrap;
}

/* Bars */
.tl-bar {
  position: absolute;
  height: 18px;
  top: 7px;
  border-radius: 3px;
  min-width: 12px;
  cursor: pointer;
  transition: opacity 0.15s;
  overflow: hidden;
}
.tl-bar:hover { opacity: 0.85; }
.tl-bar.live-bar-draggable { cursor: grab; }
.tl-bar.live-bar-draggable:active { cursor: grabbing; }

/* Bar status colors */
.tl-bar-planned    { background: rgba(148,163,184,0.35); border: 1px solid rgba(148,163,184,0.5); }
.tl-bar-ready      { background: rgba(168,85,247,0.35); border: 1px solid rgba(168,85,247,0.5); }
.tl-bar-in_progress { background: rgba(59,130,246,0.4); border: 1px solid rgba(59,130,246,0.6); }
.tl-bar-complete   { background: rgba(34,197,94,0.35); border: 1px solid rgba(34,197,94,0.5); }
.tl-bar-blocked    { background: rgba(239,68,68,0.3); border: 1px solid rgba(239,68,68,0.5); }
.tl-bar-delayed    { background: rgba(245,158,11,0.3); border: 1px solid rgba(245,158,11,0.5); }

/* Baseline ghost bar (thinner, behind live bar) */
.tl-bar-baseline {
  position: absolute;
  height: 6px;
  top: 24px;
  border-radius: 2px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  pointer-events: none;
}

/* Bar label */
.tl-bar-label {
  display: block;
  font-size: 9px;
  color: rgba(255,255,255,0.7);
  padding: 0 4px;
  line-height: 18px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
  pointer-events: none;
}

/* Unverified bar */
.tl-bar.unverified {
  background: repeating-linear-gradient(135deg, transparent, transparent 3px, rgba(251,191,36,0.1) 3px, rgba(251,191,36,0.1) 6px) !important;
  border-style: dashed !important;
  border-color: rgba(251,191,36,0.3) !important;
}

/* ── Timeline control bar ── */
.tl-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.tl-controls .tl-revision-badge {
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(255,255,255,0.04);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}
.tl-controls .tl-zoom-btn {
  background: transparent;
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
  padding: 4px 10px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 11px;
  transition: color 0.15s, border-color 0.15s;
}
.tl-controls .tl-zoom-btn:hover { color: var(--text-primary); border-color: var(--border); }
.tl-controls .tl-zoom-btn.active { color: var(--text-heading); background: rgba(255,255,255,0.06); }
.tl-controls .tl-separator {
  width: 1px;
  height: 20px;
  background: var(--border-subtle);
}

/* ── Empty timeline state ── */
.tl-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  color: var(--text-secondary);
  text-align: center;
}
.tl-empty h3 {
  color: var(--text-heading);
  font-size: 16px;
  margin-bottom: 8px;
}
.tl-empty p {
  font-size: 13px;
  max-width: 340px;
  line-height: 1.5;
  margin-bottom: 16px;
}

/* ── Quick action buttons ── */
.tl-quick-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.tl-qa-btn {
  font-size: 11px;
  font-weight: 500;
  padding: 6px 0;
  border-radius: 4px;
  border: 1px solid var(--border-subtle);
  background: transparent;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  color: var(--text-secondary);
}
.tl-qa-btn:hover { background: rgba(255,255,255,0.04); color: var(--text-primary); }
.tl-qa-ready:hover   { border-color: rgba(168,85,247,0.5); color: #a855f7; }
.tl-qa-progress:hover { border-color: rgba(59,130,246,0.5); color: #60a5fa; }
.tl-qa-complete:hover { border-color: rgba(34,197,94,0.5); color: #4ade80; }
.tl-qa-blocked:hover  { border-color: rgba(239,68,68,0.5); color: #f87171; }

/* ── Variance display ── */
.tl-variance {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
}
.tl-variance-badge {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 3px;
}
.tl-variance-late  { background: rgba(239,68,68,0.1); color: #f87171; }
.tl-variance-early { background: rgba(34,197,94,0.1); color: #4ade80; }
.tl-variance-on    { background: rgba(255,255,255,0.04); color: var(--text-secondary); }
.tl-variance-label {
  font-size: 11px;
  color: var(--text-secondary);
}

/* ── Reason code pill ── */
.tl-reason-pill {
  display: inline-block;
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.04);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
  text-transform: capitalize;
}

/* ══════════════════════════════════════════════════════════════════
   Phase 06 — Approvals & Audit
   ══════════════════════════════════════════════════════════════════ */

/* Approval status badges */
.tl-approval-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 3px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.tl-approval-pending  { background: rgba(245,158,11,0.12); color: #fbbf24; }
.tl-approval-approved { background: rgba(34,197,94,0.12); color: #4ade80; }
.tl-approval-rejected { background: rgba(239,68,68,0.12); color: #f87171; }

/* Pending cell treatment in timeline */
.tl-bar.pending-approval {
  border-style: dashed !important;
  opacity: 0.7;
}
.tl-bar.pending-approval::after {
  content: '\231B';
  position: absolute;
  right: 4px;
  top: 1px;
  font-size: 12px;
}

/* Approval card in drawer */
.tl-approval-card {
  padding: 10px 12px;
  border: 1px solid rgba(245,158,11,0.25);
  border-radius: 6px;
  background: rgba(245,158,11,0.04);
  margin-bottom: 8px;
}
.tl-approval-card.approved { border-color: rgba(34,197,94,0.25); background: rgba(34,197,94,0.04); }
.tl-approval-card.rejected { border-color: rgba(239,68,68,0.25); background: rgba(239,68,68,0.04); }
.tl-approval-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.tl-approval-summary {
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.5;
  margin-bottom: 6px;
}
.tl-approval-meta {
  font-size: 11px;
  color: var(--text-secondary);
  margin-bottom: 6px;
}
.tl-approval-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}
.tl-approval-actions .btn-approve {
  font-size: 11px;
  padding: 4px 12px;
  border-radius: 4px;
  border: 1px solid rgba(34,197,94,0.4);
  background: rgba(34,197,94,0.1);
  color: #4ade80;
  cursor: pointer;
}
.tl-approval-actions .btn-approve:hover { background: rgba(34,197,94,0.2); }
.modal-footer .btn-approve {
  font-size: 12px; padding: 6px 14px; border-radius: 4px;
  border: 1px solid rgba(34,197,94,0.4); background: rgba(34,197,94,0.1);
  color: #4ade80; cursor: pointer;
}
.modal-footer .btn-approve:hover { background: rgba(34,197,94,0.2); }
.modal-footer .btn-reject {
  font-size: 12px; padding: 6px 14px; border-radius: 4px;
  border: 1px solid rgba(239,68,68,0.4); background: rgba(239,68,68,0.1);
  color: #f87171; cursor: pointer;
}
.modal-footer .btn-reject:hover { background: rgba(239,68,68,0.2); }
.tl-approval-actions .btn-reject {
  font-size: 11px;
  padding: 4px 12px;
  border-radius: 4px;
  border: 1px solid rgba(239,68,68,0.4);
  background: rgba(239,68,68,0.1);
  color: #f87171;
  cursor: pointer;
}
.tl-approval-actions .btn-reject:hover { background: rgba(239,68,68,0.2); }

/* Audit history in drawer */
.tl-audit-item {
  padding: 6px 0;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  font-size: 11px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.tl-audit-item:last-child { border-bottom: none; }
.tl-audit-field { color: var(--text-primary); font-weight: 500; }
.tl-audit-value { color: var(--text-secondary); }
.tl-audit-time { font-size: 10px; opacity: 0.6; }

/* ══════════════════════════════════════════════════════════════════
   Phase 07 — Board View
   ══════════════════════════════════════════════════════════════════ */

.board-container {
  display: flex;
  gap: 12px;
  flex: 1;
  min-height: 0;
  overflow-x: auto;
  padding-bottom: 8px;
}

/* ── Column / lane ── */
.board-col {
  min-width: 240px;
  width: 260px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  max-height: 100%;
}
.board-col-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  margin-bottom: 8px;
  border-radius: 6px;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border-subtle);
}
.board-col-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-heading);
  text-transform: capitalize;
}
.board-col-count {
  font-size: 11px;
  font-weight: 500;
  color: var(--text-secondary);
  background: rgba(255,255,255,0.04);
  padding: 1px 7px;
  border-radius: 10px;
}
.board-col-body {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-right: 4px;
}
.board-col-empty {
  text-align: center;
  padding: 24px 8px;
  font-size: 11px;
  color: var(--text-secondary);
  opacity: 0.5;
}

/* Column accent stripe */
.board-col[data-col="ready"] .board-col-header       { border-left: 3px solid #a855f7; }
.board-col[data-col="in_progress"] .board-col-header  { border-left: 3px solid #3b82f6; }
.board-col[data-col="blocked"] .board-col-header      { border-left: 3px solid #ef4444; }
.board-col[data-col="approval"] .board-col-header     { border-left: 3px solid #f59e0b; }
.board-col[data-col="delayed"] .board-col-header      { border-left: 3px solid #f59e0b; }
.board-col[data-col="complete"] .board-col-header     { border-left: 3px solid #22c55e; }

/* ── Card ── */
.board-card {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 10px 12px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.board-card:hover {
  border-color: var(--border);
  background: rgba(255,255,255,0.025);
}
.board-card.selected {
  border-color: rgba(96,165,250,0.5);
  background: rgba(96,165,250,0.06);
}
.board-card.unverified {
  border-style: dashed;
  border-color: rgba(251,191,36,0.25);
}

.board-card-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
  line-height: 1.4;
  margin-bottom: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.board-card-sub {
  font-size: 11px;
  color: var(--text-secondary);
  margin-bottom: 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.board-card-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.board-card-date {
  font-size: 10px;
  color: var(--text-secondary);
}

/* Card badges */
.board-badge {
  font-size: 9px;
  font-weight: 600;
  padding: 1px 5px;
  border-radius: 3px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.board-badge-warn   { background: rgba(245,158,11,0.12); color: #fbbf24; }
.board-badge-approval { background: rgba(245,158,11,0.12); color: #fbbf24; }
.board-badge-variance { background: rgba(239,68,68,0.1); color: #f87171; }
.board-badge-unverified { background: rgba(251,191,36,0.1); color: #f59e0b; }

/* ══════════════════════════════════════════════════════════════════
   Phase 08 — Zone / Drawing Links
   ══════════════════════════════════════════════════════════════════ */

/* Zone mapping dot on timeline group headers */
.tl-zone-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.15);
  margin-right: 2px;
  flex-shrink: 0;
}
.tl-zone-dot.mapped {
  background: rgba(34,197,94,0.5);
  border-color: rgba(34,197,94,0.6);
}

/* Zone action buttons in detail drawer */
.tl-zone-action {
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 4px;
  border: 1px solid var(--border-subtle);
  background: rgba(255,255,255,0.03);
  color: var(--text-secondary);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.tl-zone-action:hover {
  color: var(--text-primary);
  border-color: var(--border);
  background: rgba(255,255,255,0.06);
}

/* ══════════════════════════════════════════════════════════════════
   Native Schedule Builder
   ══════════════════════════════════════════════════════════════════ */

/* Zone chips */
.sb-zone-list { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.sb-zone-chip {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; padding: 4px 10px; border-radius: 4px;
  background: rgba(255,255,255,0.04); border: 1px solid var(--border-subtle);
  color: var(--text-primary); cursor: default;
}
.sb-zone-chip .sb-zone-rm {
  font-size: 14px; cursor: pointer; color: var(--text-secondary);
  line-height: 1; opacity: 0.6;
}
.sb-zone-chip .sb-zone-rm:hover { opacity: 1; color: #f87171; }

/* Editable activity table */
.sb-table { width: 100%; border-collapse: collapse; }
.sb-table th {
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--text-secondary);
  padding: 8px 6px; text-align: left;
  border-bottom: 1px solid var(--border-subtle);
  background: rgba(255,255,255,0.02); position: sticky; top: 0; z-index: 1;
}
.sb-table td { padding: 4px 4px; border-bottom: 1px solid rgba(255,255,255,0.02); vertical-align: middle; }
.sb-table tr:hover td { background: rgba(255,255,255,0.015); }
.sb-table .sb-input {
  width: 100%; background: var(--input-bg, rgba(255,255,255,0.04));
  border: 1px solid var(--border-subtle); color: var(--text-primary);
  font-size: 12px; padding: 5px 6px; border-radius: 4px;
  transition: border-color 0.15s;
}
.sb-table .sb-input:hover { border-color: var(--border); }
.sb-table .sb-input:focus { border-color: #555; outline: none; box-shadow: 0 0 0 2px rgba(255,255,255,0.05); }
.sb-table .sb-select {
  width: 100%; background: var(--input-bg, rgba(255,255,255,0.04));
  border: 1px solid var(--border-subtle); color: var(--text-primary);
  font-size: 12px; padding: 5px 22px 5px 6px; border-radius: 4px;
  cursor: pointer; appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 16 16' fill='%23888'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 6px center;
  transition: border-color 0.15s;
}
.sb-table .sb-select:hover { border-color: var(--border); }
.sb-table .sb-select:focus { border-color: #555; outline: none; box-shadow: 0 0 0 2px rgba(255,255,255,0.05); }
.sb-table .sb-select option { background: var(--bg-card); color: var(--text-primary); }
.sb-row-actions { display: flex; gap: 4px; }
.sb-row-btn {
  background: transparent; border: none; color: var(--text-secondary);
  cursor: pointer; font-size: 14px; padding: 2px 4px; opacity: 0.5;
}
.sb-row-btn:hover { opacity: 1; }
.sb-row-btn.sb-rm:hover { color: #f87171; }

/* Add row button */
.sb-add-row {
  font-size: 12px; color: var(--text-secondary); background: transparent;
  border: 1px dashed var(--border-subtle); border-radius: 4px;
  padding: 8px 0; width: 100%; cursor: pointer; margin-top: 6px;
  transition: color 0.15s, border-color 0.15s;
}
.sb-add-row:hover { color: var(--text-primary); border-color: var(--border); }

/* Summary strip */
.sb-summary {
  display: flex; gap: 16px; padding: 12px 0; font-size: 12px; color: var(--text-secondary);
}
.sb-summary strong { color: var(--text-primary); margin-right: 4px; }
.sb-summary-warn { color: #f59e0b; }

/* ── Linked record cards in planning drawer ── */
.lr-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 5px 8px;
  margin-bottom: 3px;
  border-radius: 4px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.04);
}
.lr-card:hover { background: rgba(255,255,255,0.04); }
.lr-card-title {
  font-size: 11px;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}
.lr-card-status {
  font-size: 10px;
  color: var(--text-secondary);
  margin-left: 8px;
  flex-shrink: 0;
  text-transform: capitalize;
}
/* ── Dependency items in drawer ── */
.dep-item {
  display: flex; align-items: center; gap: 6px;
  padding: 4px 0; border-bottom: 1px solid rgba(255,255,255,0.03);
  font-size: 11px;
}
.dep-item:last-child { border-bottom: none; }
.dep-item-name { flex: 1; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dep-item-type { font-size: 9px; color: var(--text-secondary); background: rgba(255,255,255,0.04); padding: 1px 5px; border-radius: 3px; flex-shrink: 0; }
.dep-item-rm {
  background: none; border: none; color: var(--text-secondary); cursor: pointer;
  font-size: 14px; padding: 0 2px; opacity: 0.4; line-height: 1;
}
.dep-item-rm:hover { opacity: 1; color: #f87171; }

/* ══════════════════════════════════════════════════════════════════
   Planning Summary Dashboard
   ══════════════════════════════════════════════════════════════════ */

/* Stat strip */
.sum-stats {
  display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px;
}
.sum-stat {
  flex: 1; min-width: 90px;
  padding: 12px 14px; border-radius: 6px;
  background: var(--bg-card); border: 1px solid var(--border-subtle);
  text-align: center;
}
.sum-stat-value { display: block; font-size: 22px; font-weight: 700; color: var(--text-heading); line-height: 1.2; }
.sum-stat-label { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-secondary); margin-top: 2px; }
.sum-blue  { color: #60a5fa; }
.sum-red   { color: #f87171; }
.sum-amber { color: #fbbf24; }
.sum-green { color: #4ade80; }

/* Attention groups */
.sum-attn-group { margin-bottom: 12px; }
.sum-attn-title {
  font-size: 12px; font-weight: 600; color: var(--text-heading);
  padding: 6px 10px; margin-bottom: 4px;
  border-left: 3px solid var(--text-secondary); border-radius: 0 4px 4px 0;
  background: rgba(255,255,255,0.02);
}
.sum-attn-count { font-weight: 400; color: var(--text-secondary); margin-left: 4px; }
.sum-attn-item {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 10px; cursor: pointer;
  border-radius: 4px; transition: background 0.1s;
}
.sum-attn-item:hover { background: rgba(255,255,255,0.03); }
.sum-attn-name { flex: 1; font-size: 12px; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sum-attn-zone { font-size: 10px; color: var(--text-secondary); flex-shrink: 0; }
.sum-attn-date { font-size: 10px; color: var(--text-secondary); flex-shrink: 0; }

/* Zone breakdown bars */
.sum-zone-row { display: flex; align-items: center; gap: 8px; padding: 4px 0; }
.sum-zone-name { font-size: 11px; color: var(--text-primary); width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sum-zone-pct { font-size: 11px; color: var(--text-secondary); width: 30px; text-align: right; }
.sum-zone-bar { flex: 1; height: 6px; background: rgba(255,255,255,0.06); border-radius: 3px; overflow: hidden; }
.sum-zone-fill { height: 100%; background: #4ade80; border-radius: 3px; transition: width 0.3s; }
.sum-zone-flag { font-size: 9px; flex-shrink: 0; }

/* Warning summary rows */
.sum-warn-row { display: flex; align-items: center; gap: 8px; padding: 3px 0; }
.sum-warn-type { font-size: 11px; color: var(--text-secondary); text-transform: capitalize; }

/* ══════════════════════════════════════════════════════════════════
   Taktical Alerts
   ══════════════════════════════════════════════════════════════════ */

/* Header badge */
.tkt-alert-badge {
  position: absolute; top: -4px; right: -4px;
  font-size: 9px; font-weight: 700; min-width: 14px; height: 14px;
  display: flex; align-items: center; justify-content: center;
  background: #ef4444; color: #fff; border-radius: 7px;
  padding: 0 3px; line-height: 1;
}

/* Alert count in summary */
.tkt-alert-count { font-size: 11px; }
.tkt-crit-count { color: #f87171; font-weight: 600; }

/* Alert card */
.tkt-alert-card {
  padding: 10px 12px; border-radius: 6px; cursor: pointer;
  border: 1px solid var(--border-subtle); margin-bottom: 6px;
  background: var(--bg-card); transition: border-color 0.15s, background 0.15s;
}
.tkt-alert-card:hover { border-color: var(--border); background: rgba(255,255,255,0.03); }

/* Severity accents */
.tkt-sev-critical { border-left: 3px solid #ef4444; }
.tkt-sev-risk { border-left: 3px solid #f59e0b; }
.tkt-sev-watch { border-left: 3px solid #60a5fa; }
.tkt-sev-info { border-left: 3px solid rgba(255,255,255,0.15); }

.tkt-alert-top {
  display: flex; align-items: center; gap: 8px; margin-bottom: 4px;
}
.tkt-alert-sev {
  font-size: 9px; font-weight: 600; text-transform: uppercase;
  padding: 1px 5px; border-radius: 3px; letter-spacing: 0.03em;
}
.tkt-sev-critical .tkt-alert-sev { background: rgba(239,68,68,0.12); color: #f87171; }
.tkt-sev-risk .tkt-alert-sev { background: rgba(245,158,11,0.12); color: #fbbf24; }
.tkt-sev-watch .tkt-alert-sev { background: rgba(96,165,250,0.10); color: #60a5fa; }
.tkt-sev-info .tkt-alert-sev { background: rgba(255,255,255,0.06); color: var(--text-secondary); }

.tkt-alert-type { font-size: 10px; color: var(--text-secondary); text-transform: capitalize; }
.tkt-alert-date { font-size: 10px; color: var(--text-secondary); margin-left: auto; }
.tkt-alert-title { font-size: 12px; font-weight: 500; color: var(--text-primary); margin: 0 0 3px; line-height: 1.4; }
.tkt-alert-meta { display: flex; gap: 8px; font-size: 10px; color: var(--text-secondary); }

/* ── UX polish: disabled buttons, focus states, muted text ── */
.btn-primary:disabled, .btn-secondary:disabled, .btn-action:disabled {
  opacity: 0.4; cursor: not-allowed; pointer-events: none;
}
.btn-action:focus-visible { box-shadow: 0 0 0 2px rgba(96,165,250,0.4); border-radius: 4px; }

.lr-card-blocker {
  border-color: rgba(239,68,68,0.2);
  background: rgba(239,68,68,0.03);
}
.lr-card-procurement {
  border-color: rgba(168,85,247,0.2);
  background: rgba(168,85,247,0.02);
}

/* ── Draft canvas overlay ── */
.draft-canvas-overlay {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(0,0,0,0.75);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 16px;
}
.draft-canvas-frame {
  display: flex; flex-direction: column;
  width: 100%; max-width: 1400px; height: 100%;
  background: var(--bg-app);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  box-shadow: 0 12px 48px rgba(0,0,0,0.6);
  overflow: hidden;
}
.draft-canvas-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 20px; border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0; background: var(--bg-card);
  position: relative; z-index: 10;
  pointer-events: auto;
  border-radius: 10px 10px 0 0;
}
.draft-canvas-body {
  flex: 1; overflow: auto; position: relative; z-index: 1;
  cursor: grab; user-select: none;
  background: var(--bg-app);
}
.draft-canvas-body:active { cursor: grabbing; }
.draft-canvas-body .tl-axis { position: sticky; top: 0; z-index: 2; }

/* Draft preview (compact) */
/* Draft bar drag handles */
.draft-bar-interactive { cursor: grab; position: relative; }
.draft-bar-interactive:active { cursor: grabbing; }
.draft-bar-handle {
  position: absolute; top: 0; bottom: 0; width: 8px; z-index: 2;
}
.draft-bar-handle-left { left: 0; cursor: w-resize; border-radius: 3px 0 0 3px; }
.draft-bar-handle-right { right: 0; cursor: e-resize; border-radius: 0 3px 3px 0; }
.draft-bar-handle:hover { background: rgba(255,255,255,0.12); }
.draft-bar-dragging { opacity: 0.8; z-index: 10; }
.draft-bar-ghost {
  position: absolute; height: 18px; top: 7px; border-radius: 3px;
  border: 1px dashed rgba(255,255,255,0.3); background: rgba(255,255,255,0.04);
  pointer-events: none;
}

#draftPreview { cursor: pointer; }
#draftPreview:hover { border-color: var(--border); }
#draftPreview .tl-axis { height: 20px; }
#draftPreview .tl-axis-cell { height: 20px; font-size: 7px; }
#draftPreview .tl-chart-row { height: 16px; }
#draftPreview .tl-chart-group { height: 12px; }
#draftPreview .tl-bar { height: 10px; top: 3px; min-width: 8px; border-radius: 2px; }
#draftPreview .tl-bar-label { font-size: 6px; line-height: 10px; padding: 0 2px; }
#draftPreview .tl-today { width: 1px; }
#draftPreview .tl-today::before { display: none; }

/* Template/preset cards */
.tpl-card {
  display: flex; flex-direction: column; align-items: flex-start;
  padding: 10px 14px; border-radius: 6px; cursor: pointer;
  background: rgba(255,255,255,0.02); border: 1px solid var(--border-subtle);
  text-align: left; transition: border-color 0.15s, background 0.15s;
  min-width: 130px;
}
.tpl-card:hover { border-color: var(--border); background: rgba(255,255,255,0.04); }
.tpl-card-name { font-size: 12px; font-weight: 600; color: var(--text-primary); margin-bottom: 2px; }
.tpl-card-desc { font-size: 10px; color: var(--text-secondary); }
.tpl-card-custom { border-left: 3px solid rgba(96,165,250,0.5); }
.tpl-card-sm { padding: 6px 10px; min-width: 100px; }
.tpl-card-sm .tpl-card-name { font-size: 11px; }
.tpl-card-sm .tpl-card-desc { font-size: 9px; }

/* ── Project-context sidebar ── */
.sidebar-project-ctx {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: 4px;
}
.sidebar-project-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-heading);
  margin: 0 0 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sidebar-back-link {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--text-secondary);
  text-decoration: none;
  transition: color 0.15s;
}
.sidebar-back-link:hover { color: var(--text-primary); }

/* Breadcrumb */
.page-breadcrumb {
  font-size: 11px;
  color: var(--text-secondary);
  margin-bottom: 2px;
}
.page-breadcrumb a:hover { color: var(--text-primary); }

/* Composition action row */
.sb-compose-row { display: flex; gap: 8px; flex-wrap: wrap; }
.sb-compose-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: 5px; cursor: pointer;
  font-size: 12px; font-weight: 500; color: var(--text-primary);
  background: rgba(255,255,255,0.03); border: 1px solid var(--border-subtle);
  transition: background 0.15s, border-color 0.15s;
}
.sb-compose-btn:hover { background: rgba(255,255,255,0.06); border-color: var(--border); }
.sb-compose-icon { font-size: 14px; color: var(--text-secondary); line-height: 1; }
.sb-compose-light { opacity: 0.6; }
.sb-compose-light:hover { opacity: 1; }

/* Saved draft cards */
.sb-draft-card {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border: 1px solid var(--border-subtle);
  border-radius: 6px; margin-bottom: 6px;
  background: rgba(255,255,255,0.015);
  transition: border-color 0.15s, background 0.15s;
}
.sb-draft-card:hover { border-color: var(--border); background: rgba(255,255,255,0.03); }
.sb-draft-info { flex: 1; min-width: 0; }
.sb-draft-name { font-size: 12px; font-weight: 600; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sb-draft-meta { font-size: 10px; color: var(--text-secondary); margin-top: 2px; }
.sb-draft-actions { display: flex; gap: 4px; flex-shrink: 0; }

/* Duplicate name error highlight */
.sb-input-error { border-color: rgba(239,68,68,0.5) !important; background: rgba(239,68,68,0.04) !important; }

/* Move up/down buttons */
.sb-row-btn.sb-up, .sb-row-btn.sb-down { font-size: 10px; }

/* ══════════════════════════════════════════════════════════════════
   Schedule Viewer (Full Schedule Page)
   ══════════════════════════════════════════════════════════════════ */

/* Chart area */
.sv-chart {
  flex: 1; min-height: 0; overflow: auto;
  cursor: grab; user-select: none;
  background: var(--bg-app);
}
.sv-chart:active { cursor: grabbing; }
.sv-canvas { position: relative; }
.sv-body { position: relative; }

/* Right panel */
.sv-panel {
  width: 240px; flex-shrink: 0; overflow-y: auto;
  border-left: 1px solid var(--border-subtle);
  padding: 12px 14px; background: var(--bg-card);
}

/* Trade legend */
.sv-legend { display: flex; flex-direction: column; gap: 3px; }
.sv-legend-item { display: flex; align-items: center; gap: 8px; padding: 2px 0; }
.sv-legend-chip { width: 10px; height: 10px; border-radius: 2px; flex-shrink: 0; }
.sv-legend-label { font-size: 11px; color: var(--text-secondary); }

/* Grid lines (background layer) */
.sv-grid { position: absolute; top: 0; bottom: 0; z-index: 0; pointer-events: none; }
.sv-grid-line {
  position: absolute; top: 0; bottom: 0;
  border-right: 1px solid rgba(255,255,255,0.03);
}
.sv-grid-week { border-right-color: rgba(255,255,255,0.06); }
.sv-grid-month { border-right-color: rgba(255,255,255,0.12); }
.sv-grid-weekend { background: rgba(255,255,255,0.025); }

/* Axis hierarchy */
.sv-axis { height: 44px; }
.sv-axis .tl-axis-cell {
  height: 44px; border-right-color: rgba(255,255,255,0.04);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 2px 0; line-height: 1.2;
}
.sv-ax-day { font-size: 9px; font-weight: 500; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.03em; }
.sv-ax-num { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.sv-ax-month { font-size: 9px; font-weight: 700; color: var(--accent, #60a5fa); text-transform: uppercase; letter-spacing: 0.04em; }
.sv-axis .sv-month-start {
  border-right-color: rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.03);
}
.sv-axis .sv-week-start {
  border-right-color: rgba(255,255,255,0.08);
}
.sv-axis .sv-weekend {
  background: rgba(255,255,255,0.015);
}
.sv-axis .sv-weekend .sv-ax-day { color: rgba(255,255,255,0.25); }
.sv-axis .sv-weekend .sv-ax-num { color: rgba(255,255,255,0.3); }

/* Zone headers in chart */
.sv-zone-header {
  height: 20px; line-height: 20px; padding: 0 8px;
  font-size: 9px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--text-secondary);
  background: rgba(255,255,255,0.025);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

/* Chart rows — tighter vertical density */
.sv-row {
  height: 24px; /* was 32px via .tl-chart-row */
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,0.02);
}
.sv-row:nth-child(even) { background: rgba(255,255,255,0.008); }
.sv-row-selected { background: rgba(96,165,250,0.06) !important; }

/* Bars — taller within tighter rows */
.sv-bar {
  height: 16px !important; top: 4px !important;
  border-radius: 3px;
}
.sv-bar .tl-bar-label { line-height: 16px; }

/* Bars */
.sv-bar { cursor: grab; overflow: hidden; position: relative; }
.sv-bar:hover { opacity: 0.85; outline: 1px solid rgba(255,255,255,0.2); }
.sv-bar-selected { outline: 2px solid rgba(96,165,250,0.6) !important; z-index: 4; }

/* Drag handles — visible on hover, sized to bar */
.sv-handle {
  position: absolute; top: 0; bottom: 0; width: 6px; z-index: 2;
  opacity: 0; transition: opacity 0.15s;
}
.sv-bar:hover .sv-handle { opacity: 1; }
.sv-bar-selected .sv-handle { opacity: 1; }
.sv-handle-left { left: 0; cursor: ew-resize; border-radius: 3px 0 0 3px; background: rgba(255,255,255,0.15); }
.sv-handle-right { right: 0; cursor: ew-resize; border-radius: 0 3px 3px 0; background: rgba(255,255,255,0.15); }
.sv-handle:hover { background: rgba(255,255,255,0.25); }

/* No-dates placeholder */
.sv-no-dates {
  position: absolute; left: 8px; top: 5px;
  font-size: 9px; color: var(--text-secondary); opacity: 0.3;
}

/* Responsive */
@media (max-width: 1024px) {
  .sv-panel { width: 200px; padding: 10px; }
}
@media (max-width: 768px) {
  .sv-panel { display: none; }
  .sv-axis { height: 36px; }
  .sv-ax-day { font-size: 7px; }
  .sv-ax-num { font-size: 9px; }
}

/* ══════════════════════════════════════════════════════════════════
   Taktical Responsive / Mobile / iPad
   ══════════════════════════════════════════════════════════════════ */

/* Hamburger button — hidden on desktop */
.tkt-hamburger {
  display: none; background: none; border: none; color: var(--text-secondary);
  cursor: pointer; padding: 4px; border-radius: 4px; flex-shrink: 0;
}
.tkt-hamburger:hover { color: var(--text-primary); background: rgba(255,255,255,0.06); }

/* ── Tablet: 768px–1024px ── */
@media (max-width: 1024px) {
  /* Timeline left panel narrows */
  .tl-left { width: 280px; min-width: 220px; }
  .tl-left-header { grid-template-columns: 1fr 60px 60px 60px; }
  .tl-group, .tl-row { grid-template-columns: 1fr 60px 60px 60px; }

  /* Summary stats wrap tighter */
  .sum-stat { min-width: 70px; padding: 8px 10px; }
  .sum-stat-value { font-size: 18px; }

  /* Board columns narrower */
  .board-col { min-width: 200px; width: 220px; }

  /* Builder table scroll */
  .sb-table th, .sb-table td { padding: 4px 3px; }

  /* Composition row wraps */
  .sb-compose-row { gap: 6px; }
  .sb-compose-btn { padding: 7px 10px; font-size: 11px; }

  /* Alert cards */
  .tkt-alert-card { padding: 8px 10px; }

  /* Touch targets: min 36px */
  .planning-view-btn { padding: 8px 12px; }
  .tl-zoom-btn { padding: 6px 12px; }
  .filter-select { padding: 6px 10px; min-height: 36px; }
}

/* ── Mobile / small tablet: <768px ── */
@media (max-width: 768px) {
  /* Show hamburger */
  .tkt-hamburger { display: flex; }

  /* Sidebar becomes slide-out drawer */
  .sidebar {
    position: fixed; left: -260px; top: 0; bottom: 0;
    width: 260px; z-index: 200;
    transition: left 0.25s ease;
    box-shadow: none;
  }
  .sidebar.sidebar-open {
    left: 0;
    box-shadow: 4px 0 24px rgba(0,0,0,0.5);
  }

  /* Content goes full width */
  .app-shell { grid-template-columns: 1fr; }
  .context-panel { display: none; }

  /* Workspace header wraps */
  .workspace-header { flex-wrap: wrap; gap: 8px; padding: 12px 16px; }
  .workspace-actions { flex-wrap: wrap; gap: 6px; }

  /* View toggle smaller */
  .planning-view-toggle { gap: 1px; }
  .planning-view-btn { padding: 6px 8px; }

  /* Taktical controls wrap */
  .tl-controls { flex-wrap: wrap; gap: 6px; padding: 0 4px; }

  /* Timeline: hide left panel, chart full width */
  .tl-left { display: none; }
  .tl-container { border-radius: 4px; }

  /* Summary: stack everything */
  .sum-stats { gap: 4px; }
  .sum-stat { min-width: 60px; padding: 6px 8px; }
  .sum-stat-value { font-size: 16px; }
  .sum-stat-label { font-size: 7px; }

  /* Alert cards full width */
  .tkt-alert-card { padding: 8px 10px; }
  .tkt-alert-title { font-size: 11px; }

  /* Board: horizontal scroll, narrower columns */
  .board-container { gap: 8px; }
  .board-col { min-width: 180px; width: 200px; }
  .board-card { padding: 8px 10px; }
  .board-card-title { font-size: 11px; }

  /* Builder */
  .sb-compose-row { flex-direction: column; gap: 4px; }
  .sb-compose-btn { width: 100%; justify-content: center; }

  /* Modals: near full width */
  .modal { width: calc(100vw - 32px) !important; max-width: 440px; max-height: 90vh; }

  /* Report page */
  .pr-page { padding: 16px; }
  .pr-stats { gap: 4px; }
  .pr-stat { min-width: 60px; padding: 6px 8px; }
  .pr-table { font-size: 9px; }
  .pr-table th, .pr-table td { padding: 3px 4px; }

  /* Breadcrumb smaller */
  .page-breadcrumb { font-size: 10px; }
  .page-title { font-size: 16px; }
  .page-subtitle { font-size: 11px; }
}

/* ── Phone: <480px ── */
@media (max-width: 480px) {
  .sum-stats { flex-direction: column; }
  .sum-stat { min-width: unset; }
  .workspace-actions { width: 100%; }
  .planning-view-toggle { width: 100%; justify-content: center; }
  .tl-controls { padding: 0; }
  .board-col { min-width: 160px; width: 170px; }
  .sb-table { font-size: 10px; }
}
