/* Splash + auth */
main.splash {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

main.login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  background: var(--color-card);
}
.login-card {
  width: 100%;
  max-width: 420px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
}
.login-card h1 {
  margin: 0 0 var(--space-1);
  color: var(--color-accent);
  font-size: var(--text-2xl);
  letter-spacing: -0.01em;
}
.login-card .muted { color: var(--color-muted); margin: 0 0 var(--space-6); }
.login-card .small { font-size: var(--text-sm); }
.login-card .ok {
  background: rgba(22, 163, 74, 0.08);
  color: var(--color-success);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  margin-top: var(--space-3);
  font-size: var(--text-sm);
}

.divider {
  text-align: center;
  margin: var(--space-4) 0;
  position: relative;
  color: var(--color-muted);
  font-size: var(--text-sm);
}
.divider::before,
.divider::after {
  content: '';
  position: absolute;
  top: 50%;
  width: calc(50% - 28px);
  height: 1px;
  background: var(--color-border);
}
.divider::before { left: 0; }
.divider::after { right: 0; }
.divider span { background: var(--color-bg); padding: 0 var(--space-2); }

.magic-form { display: flex; flex-direction: column; gap: var(--space-2); }
.magic-form label {
  font-size: var(--text-sm);
  color: var(--color-muted);
  font-weight: 500;
}
.magic-form input {
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  font-family: inherit;
}
.magic-form input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(247, 147, 26, 0.15);
}

/* Authenticated shell */
.shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}
.sidebar {
  background: var(--color-fg);
  color: #f9fafb;
  padding: var(--space-6) 0;
  display: flex;
  flex-direction: column;
}
.sidebar .brand {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-6) var(--space-6);
  font-weight: 700;
}
.sidebar .brand-mark { color: var(--color-accent); font-size: 18px; }
.sidebar nav { flex: 1; display: flex; flex-direction: column; }
.sidebar .nav-item {
  padding: var(--space-3) var(--space-6);
  color: #d1d5db;
  text-decoration: none;
  font-size: var(--text-base);
  border-left: 2px solid transparent;
}
.sidebar .nav-item:hover { background: rgba(255, 255, 255, 0.04); }
.sidebar .nav-item.active {
  background: rgba(247, 147, 26, 0.12);
  color: var(--color-accent);
  border-left-color: var(--color-accent);
}
.sidebar-footer {
  padding: var(--space-4) var(--space-6) 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  margin-top: var(--space-4);
}
.user-chip { padding-bottom: var(--space-2); }
.user-name { font-weight: 600; font-size: var(--text-sm); }
.user-role {
  font-size: 11px;
  color: #9ca3af;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.sidebar .signout {
  display: block;
  margin-top: var(--space-3);
  color: #9ca3af;
  text-decoration: none;
  font-size: var(--text-sm);
}
.sidebar .signout:hover { color: var(--color-accent); }

main.content {
  padding: var(--space-8);
  max-width: 1200px;
  width: 100%;
}
.page-header { margin-bottom: var(--space-6); }
.page-header h1 {
  margin: 0 0 var(--space-1);
  font-size: var(--text-2xl);
  letter-spacing: -0.01em;
}
.page-header .muted { color: var(--color-muted); margin: 0; }

/* Cards / grid */
.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-6);
}
.stat-card .stat-label {
  font-size: var(--text-sm);
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.stat-card .stat-value {
  font-size: var(--text-2xl);
  font-weight: 600;
  margin-top: var(--space-1);
}
.stat-card .stat-foot {
  font-size: var(--text-sm);
  margin-top: var(--space-2);
}
.placeholder h2 {
  margin: 0 0 var(--space-2);
  font-size: var(--text-lg);
}
.placeholder .muted { margin: 0; }

/* Profile page */
.profile-shell {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-6);
}
.profile-nav {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-2);
}
.profile-nav ul { list-style: none; padding: 0; margin: 0; }
.profile-nav-item {
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font: inherit;
  color: var(--color-fg);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.profile-nav-item:hover { background: var(--color-bg); }
.profile-nav-item.active {
  background: var(--color-bg);
  border-left: 3px solid var(--color-accent);
  padding-left: calc(var(--space-4) - 3px);
}
.profile-nav-title { font-weight: 600; font-size: var(--text-sm); }
.profile-nav-cite { font-size: 11px; color: var(--color-muted); }

.profile-content {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-6);
}
.profile-section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-4);
  gap: var(--space-3);
}
.profile-section-head h2 { margin: 0 0 var(--space-1); font-size: var(--text-xl); }
.profile-body {
  white-space: pre-wrap;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.6;
  background: var(--color-card);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  margin: 0;
}
.profile-label {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-muted);
  margin-bottom: var(--space-3);
}
.profile-label input,
.profile-label textarea {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-fg);
  background: var(--color-bg);
  resize: vertical;
}
.profile-label textarea { line-height: 1.5; }
.profile-actions { display: flex; gap: var(--space-3); }
.profile-actions .btn { width: auto; }

@media (max-width: 768px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  main.content { padding: var(--space-4); }
  .grid-3 { grid-template-columns: 1fr; }
  .profile-shell { grid-template-columns: 1fr; }
}

/* Leads page */
.leads-controls { display: flex; align-items: center; gap: var(--space-3); }
.cost-badge {
  display: inline-flex; gap: 6px; align-items: center;
  background: var(--color-card); border: 1px solid var(--color-border);
  padding: 8px 12px; border-radius: var(--radius-md);
  font-size: var(--text-sm);
}
.cost-warn { border-color: #fb923c; color: #fb923c; }

.tabs {
  display: flex; gap: 2px; margin-top: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.tab {
  background: transparent; border: none; cursor: pointer;
  padding: var(--space-3) var(--space-4); font: inherit; color: var(--color-muted);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.tab:hover { color: var(--color-fg); }
.tab.active { color: var(--color-accent); border-bottom-color: var(--color-accent); }

.lead-list { list-style: none; padding: 0; margin: var(--space-4) 0 0; }
.lead-row {
  background: var(--color-card); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); margin-bottom: var(--space-3);
  overflow: hidden;
}
.lead-top {
  display: flex; gap: var(--space-3); padding: var(--space-4);
  align-items: center; cursor: pointer;
}
.lead-top:hover { background: var(--color-bg); }
.lead-main { flex: 1; min-width: 0; }
.lead-title {
  display: block; color: var(--color-fg); font-weight: 600;
  text-decoration: none; margin-bottom: 2px;
}
.lead-title:hover { color: var(--color-accent); }
.lead-actions { display: flex; gap: var(--space-2); flex-shrink: 0; }
.lead-detail {
  padding: var(--space-4); border-top: 1px solid var(--color-border);
  background: var(--color-bg);
}
.lead-detail h4 { margin: 0 0 var(--space-1); font-size: var(--text-sm); color: var(--color-muted); }
.lead-detail p { margin: 0 0 var(--space-3); }
.cite-list { display: flex; flex-wrap: wrap; gap: var(--space-1); margin-bottom: var(--space-3); }
.cite-list code {
  background: var(--color-card); padding: 2px 8px; border-radius: var(--radius-sm);
  font-size: 12px;
}
.breakdown { list-style: none; padding: 0; display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: var(--space-2); }
.breakdown li { background: var(--color-card); padding: var(--space-2); border-radius: var(--radius-sm); font-size: 12px; }

.badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px; padding: 0 8px;
  border-radius: var(--radius-md);
  font-weight: 700; font-size: var(--text-sm);
}
.badge-green { background: #14532d; color: #86efac; }
.badge-blue { background: #1e3a8a; color: #93c5fd; }
.badge-yellow { background: #713f12; color: #fcd34d; }
.badge-red { background: #7f1d1d; color: #fca5a5; }
.badge-muted { background: var(--color-card); color: var(--color-muted); }

.btn-ghost {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-fg);
}
.btn-ghost:hover:not(:disabled) { background: var(--color-bg); }
.btn.small { padding: 6px 12px; font-size: var(--text-sm); }

/* Applications + Library */
.actions-bar { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-top: var(--space-3); }
.state-pill {
  background: var(--color-card); padding: 2px 10px; border-radius: 10px;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
}
.q-list { list-style: decimal; padding-left: var(--space-6); margin-top: var(--space-4); }
.q-row {
  background: var(--color-card); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); padding: var(--space-4);
  margin-bottom: var(--space-3);
}
.q-prompt { margin-bottom: var(--space-3); }
.q-draft { background: var(--color-bg); padding: var(--space-3); border-radius: var(--radius-sm); margin-top: var(--space-2); }

.library-controls { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-4); }
.library-controls .search {
  width: 100%; padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  font: inherit;
}
.tag-cloud { display: flex; gap: var(--space-1); flex-wrap: wrap; }
.tag-chip {
  background: var(--color-card); border: 1px solid var(--color-border);
  padding: 4px 10px; border-radius: 12px; cursor: pointer;
  font-size: var(--text-sm); font-family: var(--font-mono);
}
.tag-chip.active { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.tag-chip:hover:not(.active) { background: var(--color-bg); }

.paragraph-list { list-style: none; padding: 0; }
.paragraph-row {
  background: var(--color-card); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); margin-bottom: var(--space-3); overflow: hidden;
}
.paragraph-meta { padding: var(--space-4); cursor: pointer; }
.paragraph-meta:hover { background: var(--color-bg); }
.paragraph-summary { margin-bottom: 4px; }
.paragraph-body { padding: var(--space-4); border-top: 1px solid var(--color-border); background: var(--color-bg); }

/* Pre-flight audit */
.audit-card { border: 1px solid var(--color-border); }
.audit-findings { list-style: none; padding: 0; margin: var(--space-4) 0 0; }
.audit-finding {
  display: flex; gap: var(--space-3); align-items: flex-start;
  padding: var(--space-3); margin-bottom: var(--space-2);
  background: var(--color-bg); border-radius: var(--radius-sm);
  border-left: 3px solid var(--color-border);
}
.audit-error { border-left-color: #ef4444; }
.audit-warn { border-left-color: #f59e0b; }
.audit-info { border-left-color: #3b82f6; }
.audit-cat {
  background: var(--color-card); padding: 2px 8px; border-radius: 6px;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  flex-shrink: 0;
}

/* Threads */
.thread-shell { display: grid; grid-template-columns: 320px 1fr; gap: var(--space-4); margin-top: var(--space-4); }
.thread-list { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-2); max-height: 70vh; overflow-y: auto; }
.thread-row { width: 100%; text-align: left; background: transparent; border: none; padding: var(--space-3); border-radius: var(--radius-sm); cursor: pointer; font: inherit; color: var(--color-fg); }
.thread-row:hover { background: var(--color-bg); }
.thread-row.active { background: var(--color-bg); border-left: 3px solid var(--color-accent); padding-left: calc(var(--space-3) - 3px); }
.thread-subject { font-weight: 600; margin-bottom: 4px; }
.thread-view { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4); }
.message { margin-bottom: var(--space-4); padding: var(--space-3); border-radius: var(--radius-sm); }
.msg-in { background: var(--color-card); }
.msg-out { background: rgba(247, 147, 26, 0.06); border-left: 3px solid var(--color-accent); padding-left: calc(var(--space-3) - 3px); }
.msg-subject { font-weight: 600; margin: 4px 0; }
.msg-body { white-space: pre-wrap; font-family: var(--font-sans); margin: 0; line-height: 1.5; }

.ai-draft-card {
  background: var(--color-bg);
  border-left: 3px solid var(--color-accent);
  padding: var(--space-4);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-3);
}

/* Topbar + notifications */
.topbar { display: flex; justify-content: flex-end; margin-bottom: var(--space-4); }
.notif-bell { position: relative; }
.notif-bell-btn { background: transparent; border: 1px solid var(--color-border); padding: 6px 12px; border-radius: var(--radius-md); cursor: pointer; font-size: 16px; }
.notif-bell-btn:hover { background: var(--color-card); }
.notif-badge {
  position: absolute; top: -6px; right: -6px;
  background: #ef4444; color: white;
  font-size: 10px; font-weight: 700;
  min-width: 18px; height: 18px; border-radius: 9px;
  display: inline-flex; align-items: center; justify-content: center; padding: 0 4px;
}
.notif-panel {
  position: absolute; top: 36px; right: 0;
  width: 380px; max-height: 480px; overflow-y: auto;
  background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); box-shadow: 0 4px 16px rgba(0,0,0,0.12);
  z-index: 50;
}
.notif-header { display: flex; justify-content: space-between; padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-border); }
.notif-list { list-style: none; padding: 0; margin: 0; }
.notif-item {
  position: relative; padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border); cursor: pointer;
}
.notif-item:hover { background: var(--color-card); }
.notif-item.read { opacity: 0.55; }
.notif-item.priority-high { border-left: 3px solid #f59e0b; padding-left: calc(var(--space-4) - 3px); }
.notif-item.priority-urgent { border-left: 3px solid #ef4444; padding-left: calc(var(--space-4) - 3px); }
.notif-title { font-weight: 600; margin-bottom: 4px; }
.notif-x {
  position: absolute; top: 8px; right: 10px;
  background: transparent; border: none; cursor: pointer;
  color: var(--color-muted); font-size: 18px; line-height: 1;
}
.btn-link { background: transparent; border: none; color: var(--color-accent); cursor: pointer; font: inherit; }

/* Kanban */
.kanban { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-3); margin-top: var(--space-4); overflow-x: auto; }
.kanban-col { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); min-width: 200px; }
.kanban-head { padding: var(--space-3); border-bottom: 1px solid var(--color-border); display: flex; justify-content: space-between; }
.kanban-cards { padding: var(--space-2); display: flex; flex-direction: column; gap: var(--space-2); min-height: 100px; }
.kanban-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: var(--space-3); }
.kanban-card-title { color: var(--color-fg); text-decoration: none; font-weight: 600; display: block; margin-bottom: 4px; }
.kanban-card-title:hover { color: var(--color-accent); }
.kanban-empty { padding: var(--space-3); }
.deadline-pill { padding: 1px 6px; border-radius: 8px; font-size: 11px; }
.deadline-pill.soon { background: rgba(245, 158, 11, 0.15); color: #f59e0b; }
.deadline-pill.urgent { background: rgba(239, 68, 68, 0.15); color: #ef4444; }
.state-select {
  width: 100%; margin-top: var(--space-2);
  padding: 4px 8px; font: inherit; font-size: var(--text-sm);
  border: 1px solid var(--color-border); border-radius: var(--radius-sm);
  background: var(--color-bg);
}

/* Awards */
.awards-shell { display: grid; grid-template-columns: 240px 1fr; gap: var(--space-4); margin-top: var(--space-4); }
.awards-list { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-2); }
.awards-row { display: block; width: 100%; text-align: left; background: transparent; border: none; padding: var(--space-3); cursor: pointer; border-radius: var(--radius-sm); font: inherit; color: var(--color-fg); }
.awards-row:hover { background: var(--color-bg); }
.awards-row.active { background: var(--color-bg); border-left: 3px solid var(--color-accent); padding-left: calc(var(--space-3) - 3px); }
.awards-amount { font-weight: 700; font-size: var(--text-lg); }
.awards-detail { min-width: 0; }
.milestone-list { list-style: none; padding: 0; margin: 0; }
.milestone { padding: var(--space-3); background: var(--color-bg); border-radius: var(--radius-sm); margin-bottom: var(--space-2); display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.milestone.done { opacity: 0.6; }
.report-row { padding: var(--space-3); background: var(--color-bg); border-radius: var(--radius-sm); margin-bottom: var(--space-2); }
