:root {
  --bg: #0b1020;
  --panel: #11182a;
  --panel-2: #162036;
  --line: rgba(255,255,255,0.08);
  --text: #edf2ff;
  --muted: #9fb0d1;
  --accent: #66a3ff;
  --accent-2: #89f0c9;
  --danger: #ff6b6b;
  --warning: #ffbd59;
  --success: #2dd4bf;
  --shadow: 0 20px 50px rgba(0,0,0,0.35);
  --radius: 18px;
  --radius-sm: 12px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; background: radial-gradient(circle at top left, #162244, #0b1020 50%); color: var(--text); font-family: var(--font); }
button, input, select, textarea { font: inherit; }
a { color: var(--accent); }

.app-shell { display: grid; grid-template-columns: 280px 1fr; min-height: 100vh; }
.sidebar {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 24px 18px;
  border-right: 1px solid var(--line);
  background: rgba(7, 12, 27, 0.82);
  backdrop-filter: blur(18px);
}
.brand { display: flex; gap: 14px; align-items: center; margin-bottom: 28px; }
.brand h1 { margin: 0; font-size: 1.1rem; }
.brand p { margin: 4px 0 0; color: var(--muted); font-size: 0.92rem; }
.brand-mark {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  font-weight: 800;
  background: linear-gradient(135deg, var(--accent), #7c5cff);
  box-shadow: var(--shadow);
}
.nav { display: grid; gap: 8px; }
.nav-item {
  border: 0;
  background: transparent;
  color: var(--muted);
  text-align: left;
  padding: 12px 14px;
  border-radius: 12px;
  cursor: pointer;
  transition: 160ms ease;
}
.nav-item:hover,
.nav-item.active {
  background: rgba(255,255,255,0.06);
  color: var(--text);
}
.sidebar-footer { display: grid; gap: 10px; }
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(45,212,191,0.15);
  color: var(--accent-2);
  border: 1px solid rgba(45,212,191,0.25);
}
.small { font-size: 0.85rem; }
.muted { color: var(--muted); }

.main-shell { display: grid; grid-template-rows: auto 1fr; min-width: 0; }
.topbar {
  padding: 24px 28px 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  border-bottom: 1px solid var(--line);
  background: rgba(10, 15, 31, 0.62);
  backdrop-filter: blur(12px);
}
.topbar h2 { margin: 0; font-size: 1.45rem; }
.topbar p { margin: 6px 0 0; color: var(--muted); }
.topbar-actions { display: flex; align-items: center; gap: 12px; }
.user-chip {
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  color: var(--text);
  border: 1px solid var(--line);
}
.content { padding: 28px; display: grid; gap: 22px; }
.view { display: none; gap: 22px; }
.view.active { display: grid; }
.metrics-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 18px; }
.metric {
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
}
.metric .label { color: var(--muted); font-size: 0.9rem; }
.metric .value { font-size: 2rem; font-weight: 750; margin: 8px 0 4px; }
.metric .meta { color: var(--muted); font-size: 0.9rem; }

.panel, .table-panel {
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
  min-width: 0;
}
.panel-header, .section-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.section-toolbar.split { flex-wrap: wrap; }
.section-title-group h3, .panel-header h3 { margin: 0; font-size: 1.1rem; }
.section-title-group p { margin: 6px 0 0; color: var(--muted); }
.toolbar-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.content-grid { display: grid; gap: 18px; }
.content-grid.two-col { grid-template-columns: repeat(2, minmax(0,1fr)); }
.candidates-layout { grid-template-columns: minmax(320px, 0.95fr) minmax(420px, 1.05fr); }
.detail-panel { position: sticky; top: 18px; align-self: start; }
.company-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; }
.card-stack { display: grid; gap: 14px; }
.card {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px;
  background: rgba(255,255,255,0.02);
}
.card:hover { border-color: rgba(102,163,255,0.45); }
.card.clickable { cursor: pointer; transition: transform 160ms ease, border-color 160ms ease, background 160ms ease; }
.card.clickable:hover { transform: translateY(-2px); background: rgba(255,255,255,0.04); }
.card-head { display: flex; align-items: start; justify-content: space-between; gap: 12px; }
.card-title { margin: 0; font-size: 1rem; }
.card-subtitle { margin: 6px 0 0; color: var(--muted); font-size: 0.92rem; }
.badge-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.badge {
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(102,163,255,0.14);
  border: 1px solid rgba(102,163,255,0.2);
  color: #cfe0ff;
  font-size: 0.82rem;
}
.badge.muted-badge { background: rgba(255,255,255,0.06); border-color: var(--line); color: var(--muted); }
.badge.success { background: rgba(45,212,191,0.18); border-color: rgba(45,212,191,0.22); color: #c6fff4; }
.badge.warning { background: rgba(255,189,89,0.15); border-color: rgba(255,189,89,0.22); color: #ffe0ab; }
.badge.danger { background: rgba(255,107,107,0.15); border-color: rgba(255,107,107,0.22); color: #ffc2c2; }

.signal-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; margin-top: 16px; }
.signal-item {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,0.03);
}
.signal-item .label { color: var(--muted); font-size: 0.85rem; }
.signal-item .value { font-size: 1.4rem; font-weight: 700; margin-top: 6px; }
.progress {
  margin-top: 8px;
  height: 8px;
  width: 100%;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
}
.progress > span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
}

.data-table { width: 100%; border-collapse: collapse; }
.data-table th, .data-table td {
  text-align: left;
  padding: 12px 10px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
.data-table th { color: var(--muted); font-size: 0.9rem; font-weight: 600; }
.data-table tr:hover td { background: rgba(255,255,255,0.02); }

.empty-state {
  display: grid;
  place-items: center;
  min-height: 320px;
  border: 1px dashed rgba(255,255,255,0.12);
  border-radius: 16px;
  color: var(--muted);
  text-align: center;
  padding: 24px;
}
.empty-state h4 { color: var(--text); margin-bottom: 8px; }

button {
  border: 0;
  border-radius: 12px;
  padding: 10px 14px;
  cursor: pointer;
  transition: 150ms ease;
}
button.primary {
  background: linear-gradient(135deg, var(--accent), #5e8dfc);
  color: white;
  box-shadow: 0 10px 24px rgba(102,163,255,0.22);
}
button.primary:hover { filter: brightness(1.05); }
button.ghost {
  background: rgba(255,255,255,0.04);
  color: var(--text);
  border: 1px solid var(--line);
}
button.ghost:hover { background: rgba(255,255,255,0.07); }
button.danger { color: #ffd0d0; border-color: rgba(255,107,107,0.22); }
button.link-button { background: transparent; padding: 0; color: var(--accent); border: 0; }
button.small { padding: 8px 10px; border-radius: 10px; font-size: 0.9rem; }

input, select, textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255,255,255,0.04);
  color: var(--text);
  padding: 11px 12px;
}
textarea { min-height: 110px; resize: vertical; }
input::placeholder { color: #7e90b6; }

.modal {
  border: 0;
  padding: 0;
  background: transparent;
}
.modal::backdrop { background: rgba(4, 6, 13, 0.7); backdrop-filter: blur(8px); }
.modal-card {
  width: min(620px, calc(100vw - 24px));
  border: 1px solid var(--line);
  border-radius: 22px;
  background: #11182a;
  color: var(--text);
  padding: 22px;
  box-shadow: var(--shadow);
}
.modal.wide .modal-card { width: min(860px, calc(100vw - 24px)); }
.modal-header h3 { margin: 0; }
.modal-header p { margin: 6px 0 18px; color: var(--muted); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.form-grid .full { grid-column: 1 / -1; }
label { display: grid; gap: 8px; }
label span { color: var(--muted); font-size: 0.92rem; }
.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}

.detail-block { display: grid; gap: 18px; }
.detail-head h3 { margin: 0; font-size: 1.3rem; }
.detail-head p { margin: 8px 0 0; color: var(--muted); }
.detail-section h4 { margin: 0 0 10px; }
.detail-section { border-top: 1px solid var(--line); padding-top: 16px; }
.inline-list { display: grid; gap: 10px; }
.inline-list .item {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,0.03);
}

.stat-line { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 10px 0; }
.stat-line strong { font-size: 0.98rem; }
.stat-line span { color: var(--muted); }

.toast-stack {
  position: fixed;
  right: 20px;
  bottom: 20px;
  display: grid;
  gap: 10px;
  z-index: 1000;
}
.toast {
  min-width: 280px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(17,24,42,0.96);
  box-shadow: var(--shadow);
}
.toast.success { border-color: rgba(45,212,191,0.26); }
.toast.error { border-color: rgba(255,107,107,0.26); }

.avatar-row { display: flex; gap: 12px; align-items: center; }
.avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.04);
}

@media (max-width: 1180px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: sticky; top: 0; z-index: 20; }
  .nav { grid-template-columns: repeat(4, minmax(0,1fr)); }
  .main-shell { min-width: 0; }
  .metrics-grid, .content-grid.two-col, .candidates-layout { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .topbar, .content { padding: 18px; }
  .nav { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .form-grid { grid-template-columns: 1fr; }
  .topbar { flex-direction: column; align-items: stretch; }
}



/* === Sticky navigation hardening === */
.sidebar,
nav,
aside,
.app-sidebar,
.shell-sidebar,
.layout-sidebar,
.left-nav,
.left-panel,
.menu-panel {
    position: sticky !important;
    top: 0 !important;
    align-self: start !important;
    height: 100vh !important;
    max-height: 100vh !important;
    overflow-y: auto !important;
}

/* Common parent layout fixes */
.layout,
.shell,
.app-shell,
.app-layout,
.main-layout,
.page-layout {
    align-items: start !important;
}

/* Prevent clipping by parent containers */
body,
main,
.app-shell,
.app-layout,
.layout,
.page-layout {
    overflow: visible !important;
}



/* === FINAL Sticky Sidebar Fix === */

/* Layout fix */
.app-shell {
    display: flex;
    align-items: flex-start;
}

/* Sidebar */
.sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
    flex-shrink: 0;
}

/* Main content scrollt */
.main-shell {
    flex: 1;
    overflow: auto;
}



/* === Table UX === */
.table-ux-toolbar {
  position: fixed;
  right: 20px;
  top: 18px;
  z-index: 2000;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

.table-ux-btn {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255,255,255,0.88);
  color: #0f172a;
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(15,23,42,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

.table-ux-btn.secondary {
  background: #f8fafc;
}

.table-ux-panel {
  width: 280px;
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 18px 50px rgba(15,23,42,0.12);
  border-radius: 16px;
  overflow: hidden;
}

.table-ux-panel.hidden {
  display: none;
}

.table-ux-panel-head,
.table-ux-panel-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.table-ux-panel-foot {
  border-bottom: 0;
  border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.table-ux-panel-body {
  max-height: 380px;
  overflow: auto;
  padding: 8px;
}

.table-ux-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: 10px;
  font-size: 13px;
  color: #0f172a;
}

.table-ux-option:hover {
  background: rgba(59, 130, 246, 0.06);
}

.table-ux-close {
  border: 0;
  background: transparent;
  font-size: 18px;
  cursor: pointer;
  color: #64748b;
}

.table-ux-empty {
  padding: 12px;
  font-size: 13px;
  color: #64748b;
}

.table-ux-th {
  position: relative;
}

.table-ux-th.dragging {
  opacity: 0.55;
}

.table-ux-resize {
  position: absolute;
  top: 0;
  right: -2px;
  width: 8px;
  height: 100%;
  cursor: col-resize;
  user-select: none;
}
\n\n
/* === Table UX Professional Polish === */
.table-ux-toolbar {
  position: fixed;
  right: 24px;
  z-index: 2200;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
}

.table-ux-btn {
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.72);
  color: #e2e8f0;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 12px 32px rgba(2, 6, 23, 0.28);
  border-radius: 14px;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.18s ease;
}

.table-ux-btn:hover {
  background: rgba(30, 41, 59, 0.88);
  border-color: rgba(96, 165, 250, 0.35);
}

.table-ux-btn.secondary {
  background: rgba(30, 41, 59, 0.9);
  color: #f8fafc;
  border-color: rgba(148, 163, 184, 0.16);
}

.table-ux-panel {
  width: 320px;
  background: rgba(15, 23, 42, 0.94);
  color: #e2e8f0;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(148, 163, 184, 0.14);
  box-shadow: 0 20px 60px rgba(2, 6, 23, 0.45);
  border-radius: 18px;
  overflow: hidden;
}

.table-ux-panel.hidden {
  display: none;
}

.table-ux-panel-head,
.table-ux-panel-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
}

.table-ux-panel-head {
  border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}

.table-ux-panel-foot {
  border-top: 1px solid rgba(148, 163, 184, 0.10);
  background: rgba(255,255,255,0.02);
}

.table-ux-panel-head strong {
  font-size: 14px;
  font-weight: 700;
  color: #f8fafc;
  letter-spacing: 0.01em;
}

.table-ux-panel-body {
  max-height: 360px;
  overflow: auto;
  padding: 8px;
}

.table-ux-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 12px;
  border-radius: 12px;
  font-size: 13px;
  color: #e2e8f0;
  transition: background 0.15s ease, transform 0.15s ease;
}

.table-ux-option:hover {
  background: rgba(59, 130, 246, 0.10);
}

.table-ux-option span {
  color: #e2e8f0;
  font-weight: 500;
  text-align: left;
  flex: 1;
}

.table-ux-option input {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  accent-color: #3b82f6;
}

.table-ux-close {
  border: 0;
  background: transparent;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  color: #94a3b8;
  padding: 0;
}

.table-ux-close:hover {
  color: #f8fafc;
}

.table-ux-empty {
  padding: 14px;
  font-size: 13px;
  color: #94a3b8;
}

.table-ux-th {
  position: relative;
}

.table-ux-th.dragging {
  opacity: 0.55;
}

.table-ux-resize {
  position: absolute;
  top: 0;
  right: -3px;
  width: 10px;
  height: 100%;
  cursor: col-resize;
  user-select: none;
}

@media (max-width: 1100px) {
  .table-ux-toolbar {
    right: 16px;
  }

  .table-ux-panel {
    width: 280px;
  }
}



/* === Table UX Position Fix === */
.table-ux-toolbar {
  position: fixed;
  right: 24px;
  top: 132px;
  z-index: 2200;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
}

@media (max-width: 1100px) {
  .table-ux-toolbar {
    right: 16px;
    top: 124px;
  }
}


/* === Disable floating table UX toolbar === */
.table-ux-toolbar {
  position: static !important;
  width: 0 !important;
  height: 0 !important;
  overflow: visible !important;
  z-index: 3000 !important;
}


/* Panel positioniert relativ zum Header */
#tableUxPanel {
  position: absolute;
  right: 24px;
  top: 72px;
  z-index: 3000;
}


/* === Header Columns Panel Fix === */
#tableUxColumnsBtn {
  display: none !important;
}

.table-ux-toolbar {
  position: static !important;
  width: 0 !important;
  height: 0 !important;
  overflow: visible !important;
  z-index: 3000 !important;
}

#tableUxPanel {
  position: fixed !important;
  z-index: 3001 !important;
}



/* === Table Filter UX === */
.table-filter-bar {
  min-width: 340px;
  max-width: 420px;
}

.table-filter-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 14px 38px rgba(15, 23, 42, 0.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 16px;
  padding: 10px;
}

.table-filter-field {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  background: rgba(248,250,252,0.85);
  border: 1px solid rgba(148,163,184,0.18);
  border-radius: 12px;
  padding: 10px 12px;
}

.table-filter-icon {
  color: #64748b;
  font-size: 14px;
  line-height: 1;
}

.table-filter-field input {
  border: 0;
  outline: 0;
  background: transparent;
  width: 100%;
  font-size: 13px;
  color: #0f172a;
}

.table-filter-field input::placeholder {
  color: #94a3b8;
}

.table-filter-clear {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
  color: #0f172a;
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}

.table-filter-clear:hover {
  background: #f8fafc;
}

@media (max-width: 1100px) {
  .table-filter-bar {
    min-width: 280px;
    max-width: 320px;
  }
}



/* === Inline Table Tools Dock === */
.table-tools-dock {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
  padding: 14px 24px 10px 24px;
  position: relative;
  z-index: 20;
}

.table-tools-dock .table-filter-bar {
  min-width: 340px;
  max-width: 460px;
}

.table-tools-dock .table-filter-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 14px 38px rgba(15, 23, 42, 0.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 16px;
  padding: 10px;
}

@media (max-width: 1100px) {
  .table-tools-dock {
    padding: 12px 16px 8px 16px;
  }

  .table-tools-dock .table-filter-bar {
    min-width: 280px;
    max-width: 100%;
    width: 100%;
  }

  .table-tools-dock {
    justify-content: stretch;
  }
}



/* === Filter Surface aligned to header buttons === */
.table-tools-dock .table-filter-bar {
  min-width: 320px;
  max-width: 420px;
}

.table-tools-dock .table-filter-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-radius: 0;
  padding: 0;
}

.table-filter-field {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 0 14px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  border-radius: 16px;
}

.table-filter-field input {
  height: 40px;
  border: 0;
  outline: 0;
  background: transparent;
  width: 100%;
  font-size: 13px;
  color: #0f172a;
}

.table-filter-clear {
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.72);
  color: #e2e8f0;
  box-shadow: 0 12px 32px rgba(2, 6, 23, 0.28);
  border-radius: 14px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.18s ease;
}

.table-filter-clear:hover {
  background: rgba(30, 41, 59, 0.88);
  border-color: rgba(96, 165, 250, 0.35);
}



/* === LIGHT EXECUTIVE THEME === */

body {
  background: #f8fafc !important;
  color: #0f172a !important;
}

/* Main Layout */
.main-shell,
.app-shell,
.content,
.page-content {
  background: transparent !important;
}

/* Sidebar */
.sidebar {
  background: #ffffff !important;
  border-right: 1px solid rgba(15, 23, 42, 0.06);
}

/* Cards / Panels */
.card,
.panel,
.table-container {
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.06);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
  border-radius: 16px;
}

/* Header */
.header,
.topbar {
  background: #ffffff !important;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

/* Buttons */
button,
.ghost,
.small {
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05);
}

button:hover {
  background: #f1f5f9 !important;
}

/* Primary Button */
button.primary {
  background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
  color: #ffffff !important;
  border: none;
}

/* Tables */
table {
  background: #ffffff;
}

th {
  background: #f8fafc;
  color: #475569;
  font-weight: 600;
}

td {
  border-top: 1px solid rgba(15, 23, 42, 0.05);
}

/* Status Pills */
.badge,
.status {
  background: rgba(59, 130, 246, 0.08);
  color: #2563eb;
}

/* Inputs */
input,
select {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  color: #0f172a;
}

input::placeholder {
  color: #94a3b8;
}

/* Filter Bar */
.table-filter-field {
  background: #ffffff !important;
}

/* Panel (Spalten) */
.table-ux-panel {
  background: #ffffff !important;
  color: #0f172a !important;
}

/* Subtle hover */
tr:hover {
  background: rgba(59, 130, 246, 0.04);
}

/* Shadows softer */
* {
  box-shadow: none;
}



/* === Compact collapsible sidebar === */
.sidebar {
  width: 220px !important;
  min-width: 220px !important;
  padding: 12px 10px 16px 10px !important;
}

.sidebar-toggle-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin: 4px 0 10px 4px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255,255,255,0.92);
  color: #0f172a;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
  cursor: pointer;
}

.sidebar-toggle-btn:hover {
  background: #f8fafc;
}

.sidebar .nav,
.sidebar nav {
  gap: 6px !important;
}

.sidebar .nav-item,
.sidebar nav a,
.sidebar .menu-item,
.sidebar .sidebar-link {
  min-height: 40px !important;
  padding: 8px 12px !important;
  border-radius: 12px !important;
  font-size: 15px !important;
}

.sidebar .brand,
.sidebar .sidebar-brand,
.sidebar .logo-block {
  margin-bottom: 10px !important;
}

.sidebar .brand-title,
.sidebar .brand-subtitle,
.sidebar .logo-text,
.sidebar .muted {
  line-height: 1.2 !important;
}

body.sidebar-collapsed .sidebar {
  width: 76px !important;
  min-width: 76px !important;
  overflow-x: hidden !important;
}
body.sidebar-collapsed .sidebar .brand-title,
body.sidebar-collapsed .sidebar .brand-subtitle,
body.sidebar-collapsed .sidebar .logo-text,
body.sidebar-collapsed .sidebar .muted,
body.sidebar-collapsed .sidebar .sidebar-item-text {
  display: none !important;
}
body.sidebar-collapsed .sidebar .nav-item,
body.sidebar-collapsed .sidebar nav a,
body.sidebar-collapsed .sidebar .menu-item,
body.sidebar-collapsed .sidebar .sidebar-link {
  justify-content: center !important;
  padding: 8px !important;
}

body.sidebar-collapsed .sidebar .brand,
body.sidebar-collapsed .sidebar .sidebar-brand,
body.sidebar-collapsed .sidebar .logo-block {
  align-items: center !important;
}

body.sidebar-collapsed .sidebar .status-badge,
body.sidebar-collapsed .sidebar .system-badge,
body.sidebar-collapsed .sidebar .badge {
  display: none !important;
}

/* Falls Demo-Hinweise per CSS-Klasse gerendert werden */
.demo-banner,
.demo-note,
.demo-credentials,
.demo-hint,
.demo-warning {
  display: none !important;
}



/* === Sidebar icons === */
.sidebar .nav-item,
.sidebar nav a,
.sidebar .menu-item,
.sidebar .sidebar-link {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.sidebar-item-icon {
  width: 20px;
  min-width: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 1;
  color: #2563eb;
  opacity: 0.95;
}

.sidebar-item-text {
  display: inline-block;
  white-space: nowrap;
}

body.sidebar-collapsed .sidebar-item-text {
  display: none !important;
}

body.sidebar-collapsed .sidebar .nav-item,
body.sidebar-collapsed .sidebar nav a,
body.sidebar-collapsed .sidebar .menu-item,
body.sidebar-collapsed .sidebar .sidebar-link {
  justify-content: center !important;
  gap: 0 !important;
}

body.sidebar-collapsed .sidebar-item-icon {
  width: 24px;
  min-width: 24px;
  font-size: 18px;
}



/* === Contrast & readability fix === */

/* Global readable text */
body,
.main-shell,
.app-shell,
.content,
.page-content,
.card,
.panel,
.table-container,
.table-ux-panel,
.table-filter-inner,
.table-filter-field,
input,
select,
textarea,
button,
th,
td,
label,
span,
div,
p,
small,
strong {
  color: #0f172a;
}

.muted,
.subtitle,
.subtle,
.secondary,
.helper,
.small-muted,
.table-ux-empty,
.table-filter-icon {
  color: #475569 !important;
}

/* Cards, tables, panels */
.card,
.panel,
.table-container,
.table-ux-panel,
.table-filter-inner {
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08) !important;
}

/* Spalten-Panel lesbar machen */
.table-ux-panel,
.table-ux-panel * {
  color: #0f172a !important;
}

.table-ux-panel-head strong {
  color: #0f172a !important;
}

.table-ux-option {
  color: #0f172a !important;
}

.table-ux-option span {
  color: #334155 !important;
  font-weight: 600 !important;
}

.table-ux-close {
  color: #0f172a !important;
}

.table-ux-close:hover {
  color: #2563eb !important;
}

.table-ux-panel-foot {
  background: #ffffff !important;
}

/* Tabellen */
table,
thead,
tbody,
tr,
th,
td {
  color: #0f172a !important;
}

th {
  color: #334155 !important;
  background: #f8fafc !important;
}

td {
  background: transparent !important;
}

/* Links und Aktionen */
a,
.link,
.action-link,
.edit-link {
  color: #2563eb !important;
}

a:hover,
.link:hover,
.action-link:hover,
.edit-link:hover {
  color: #1d4ed8 !important;
}

/* Pills / badges / score chips */
.badge,
.status,
.pill,
.score,
.score-chip {
  color: #0f172a !important;
  font-weight: 700 !important;
  border-color: rgba(15, 23, 42, 0.12) !important;
}

/* Inputs */
input,
select,
textarea {
  color: #0f172a !important;
  background: #ffffff !important;
}

input::placeholder,
textarea::placeholder {
  color: #94a3b8 !important;
}

/* Discovery / cards / profile meta */
.profile-card,
.profile-card *,
.discovery-card,
.discovery-card *,
.result-card,
.result-card *,
.company-card,
.company-card *,
.candidate-card,
.candidate-card * {
  color: #0f172a !important;
}

.profile-card .muted,
.discovery-card .muted,
.result-card .muted,
.company-card .muted,
.candidate-card .muted {
  color: #475569 !important;
}

/* Toasts / status messages / notices */
.toast,
.notice,
.alert,
.flash,
.banner,
.status-message,
.sync-status,
.snackbar {
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid rgba(15, 23, 42, 0.10) !important;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12) !important;
}

.toast *,
.notice *,
.alert *,
.flash *,
.banner *,
.status-message *,
.sync-status *,
.snackbar * {
  color: #0f172a !important;
}

/* Speziell für die Bullhorn-Sync-Meldung */
[class*="bullhorn"] .status-message,
[class*="bullhorn"] .notice,
[class*="bullhorn"] .alert,
[class*="bullhorn"] .flash,
[class*="bullhorn"] .banner {
  background: #ffffff !important;
  color: #0f172a !important;
}

/* System OK Badge unten links */
.system-badge,
.status-badge,
.badge-system {
  background: #ecfeff !important;
  color: #0f766e !important;
  border: 1px solid rgba(13, 148, 136, 0.18) !important;
  font-weight: 700 !important;
}

/* Selected / active states dürfen lesbar bleiben */
.active,
.is-active,
.selected,
.current {
  color: inherit;
}

/* Hover nicht ausbleichen */
tr:hover td,
.card:hover,
.panel:hover {
  color: #0f172a !important;
}



/* === Collapsed sidebar readability fix === */
body.sidebar-collapsed .sidebar .sidebar-item-icon {
  display: inline-flex !important;
  width: 24px !important;
  min-width: 24px !important;
  font-size: 18px !important;
  color: #2563eb !important;
  opacity: 1 !important;
}

body.sidebar-collapsed .sidebar .sidebar-item-text {
  display: none !important;
}

body.sidebar-collapsed .sidebar .nav-item,
body.sidebar-collapsed .sidebar nav a,
body.sidebar-collapsed .sidebar .menu-item,
body.sidebar-collapsed .sidebar .sidebar-link {
  justify-content: center !important;
  align-items: center !important;
  gap: 0 !important;
  padding: 10px !important;
}



/* === Global Search === */
.global-search {
  position: relative;
  min-width: 360px;
  max-width: 520px;
  width: 100%;
}

.global-search-box {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 0 14px;
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  border-radius: 16px;
}

.global-search-icon {
  color: #64748b;
  font-size: 14px;
  line-height: 1;
}

.global-search input {
  height: 40px;
  border: 0;
  outline: 0;
  background: transparent;
  width: 100%;
  font-size: 13px;
  color: #0f172a;
}

.global-search input::placeholder {
  color: #94a3b8;
}

.global-search-results {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  right: 0;
  background: rgba(255,255,255,0.98);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.12);
  border-radius: 16px;
  overflow: hidden;
  z-index: 2600;
  max-height: 460px;
  overflow-y: auto;
}

.global-search-results.hidden {
  display: none;
}

.global-search-empty {
  padding: 16px;
  font-size: 13px;
  color: #64748b;
}

.global-search-item {
  display: block;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.05);
  cursor: pointer;
  background: transparent;
}

.global-search-item:last-child {
  border-bottom: 0;
}

.global-search-item:hover {
  background: rgba(59, 130, 246, 0.06);
}

.global-search-item-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}

.global-search-title {
  font-size: 13px;
  font-weight: 700;
  color: #0f172a;
}

.global-search-type {
  font-size: 11px;
  font-weight: 700;
  color: #2563eb;
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.12);
  border-radius: 999px;
  padding: 3px 8px;
  white-space: nowrap;
}

.global-search-subtitle {
  font-size: 12px;
  color: #475569;
  margin-bottom: 2px;
}

.global-search-meta {
  font-size: 12px;
  color: #64748b;
}

@media (max-width: 1100px) {
  .global-search {
    min-width: 260px;
    max-width: 100%;
  }
}



/* === Visible Global Search UI === */
.global-search-shell {
  display: flex;
  align-items: center;
  min-width: 380px;
  max-width: 540px;
  width: 100%;
  margin-right: 16px;
}

.global-search-shell-fallback {
  padding: 16px 24px 8px 24px;
  margin-right: 0;
}

.global-search {
  position: relative;
  width: 100%;
}

.global-search-box {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 0 14px;
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  border-radius: 16px;
}

.global-search-icon {
  color: #64748b;
  font-size: 14px;
  line-height: 1;
}

.global-search input {
  height: 40px;
  border: 0;
  outline: 0;
  background: transparent;
  width: 100%;
  font-size: 13px;
  color: #0f172a;
}

.global-search input::placeholder {
  color: #94a3b8;
}

.global-search-results {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  right: 0;
  background: rgba(255,255,255,0.98);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.12);
  border-radius: 16px;
  overflow: hidden;
  z-index: 2600;
  max-height: 460px;
  overflow-y: auto;
}

.global-search-results.hidden {
  display: none;
}

.global-search-empty {
  padding: 16px;
  font-size: 13px;
  color: #64748b;
}

.global-search-item {
  display: block;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.05);
  cursor: pointer;
  background: transparent;
}

.global-search-item:last-child {
  border-bottom: 0;
}

.global-search-item:hover {
  background: rgba(59, 130, 246, 0.06);
}

.global-search-item-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}

.global-search-title {
  font-size: 13px;
  font-weight: 700;
  color: #0f172a;
}

.global-search-type {
  font-size: 11px;
  font-weight: 700;
  color: #2563eb;
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.12);
  border-radius: 999px;
  padding: 3px 8px;
  white-space: nowrap;
}

.global-search-subtitle {
  font-size: 12px;
  color: #475569;
  margin-bottom: 2px;
}

.global-search-meta {
  font-size: 12px;
  color: #64748b;
}

.header-actions .global-search-shell,
.top-actions .global-search-shell {
  flex: 1 1 420px;
}

@media (max-width: 1200px) {
  .global-search-shell {
    min-width: 280px;
    max-width: 420px;
  }
}

@media (max-width: 900px) {
  .global-search-shell {
    min-width: 0;
    max-width: 100%;
    width: 100%;
    margin-right: 0;
    margin-bottom: 10px;
  }
}



/* === Canonical Detail Drawer === */
.canonical-detail-drawer.hidden {
  display: none;
}

.canonical-detail-drawer {
  position: fixed;
  inset: 0;
  z-index: 3200;
}

.canonical-detail-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.28);
  backdrop-filter: blur(2px);
}

.canonical-detail-panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(720px, 92vw);
  height: 100%;
  background: rgba(255,255,255,0.98);
  box-shadow: -18px 0 48px rgba(15, 23, 42, 0.18);
  display: flex;
  flex-direction: column;
}

.canonical-detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 24px 18px 24px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.canonical-detail-kicker {
  font-size: 12px;
  font-weight: 700;
  color: #2563eb;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}

.canonical-detail-title {
  font-size: 24px;
  line-height: 1.2;
  font-weight: 800;
  color: #0f172a;
}

.canonical-detail-close {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
  color: #0f172a;
  border-radius: 12px;
  width: 38px;
  height: 38px;
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
}

.canonical-detail-body {
  padding: 24px;
  overflow-y: auto;
}

.canonical-detail-section {
  margin-bottom: 24px;
}

.canonical-detail-section-title {
  font-size: 13px;
  font-weight: 800;
  color: #0f172a;
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.canonical-detail-section-body {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 16px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}

.canonical-kv-row,
.canonical-list-row {
  padding: 12px 14px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.canonical-kv-row:last-child,
.canonical-list-row:last-child {
  border-bottom: 0;
}

.canonical-kv-label {
  font-size: 11px;
  font-weight: 700;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 4px;
}

.canonical-kv-value,
.canonical-list-title {
  font-size: 13px;
  font-weight: 700;
  color: #0f172a;
}

.canonical-list-meta {
  font-size: 12px;
  color: #64748b;
  margin-top: 3px;
}

.canonical-detail-empty {
  padding: 18px;
  font-size: 13px;
  color: #64748b;
}



/* === Company Detail Plus === */
.canonical-list-links {
  display: flex;
  gap: 6px;
  margin-top: 8px;
  flex-wrap: wrap;
}

.canonical-pill {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.12);
  color: #2563eb;
  font-size: 11px;
  font-weight: 700;
}



/* === Radar Mode Toggle === */
.radar-mode-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
  margin: 10px 0 14px 0;
}

.radar-mode-btn {
  border: 0;
  background: transparent;
  color: #475569;
  font-size: 12px;
  font-weight: 700;
  padding: 8px 12px;
  border-radius: 10px;
  cursor: pointer;
}

.radar-mode-btn:hover {
  background: rgba(15, 23, 42, 0.05);
}

.radar-mode-btn.active {
  background: rgba(37, 99, 235, 0.10);
  color: #2563eb;
  box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.12);
}



/* === Candidate Detail Panel === */
.candidate-detail-panel {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
  min-height: 320px;
}

.candidate-detail-empty h3,
.candidate-detail-content h3 {
  margin: 0 0 6px 0;
}

.candidate-detail-empty p,
.candidate-detail-header p,
.candidate-detail-section p {
  margin: 0;
  color: #475569;
}

.candidate-detail-content.hidden,
.candidate-detail-empty.hidden {
  display: none;
}

.candidate-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.candidate-detail-track {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.12);
  color: #2563eb;
  margin-bottom: 8px;
}

.candidate-detail-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.candidate-detail-meta-card {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 14px;
  padding: 10px 12px;
  background: #f8fafc;
}

.candidate-detail-meta-card span {
  display: block;
  font-size: 12px;
  color: #64748b;
  margin-bottom: 4px;
}

.candidate-detail-meta-card strong {
  font-size: 14px;
  color: #0f172a;
}

.candidate-detail-section {
  margin-top: 14px;
}

.candidate-detail-section h4 {
  margin: 0 0 8px 0;
  font-size: 14px;
}

.candidate-detail-links,
.candidate-detail-tags,
.candidate-detail-signals,
.candidate-detail-source-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.candidate-detail-link,
.candidate-detail-tag,
.candidate-detail-signal {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
  font-size: 12px;
  color: #0f172a;
  text-decoration: none;
}

.candidate-detail-link:hover {
  border-color: rgba(37, 99, 235, 0.28);
  color: #2563eb;
}

@media (max-width: 1100px) {
  .candidate-detail-meta-grid {
    grid-template-columns: 1fr;
  }
}



/* === Candidate Drawer Hard Fix === */
.candidate-drawer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
}

.candidate-drawer.open {
  pointer-events: auto;
}

.candidate-drawer-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.28);
  opacity: 0;
  transition: opacity 0.18s ease;
}

.candidate-drawer.open .candidate-drawer-backdrop {
  opacity: 1;
}

.candidate-drawer-sheet {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: min(520px, 92vw);
  background: #ffffff;
  box-shadow: -12px 0 40px rgba(15, 23, 42, 0.18);
  transform: translateX(100%);
  transition: transform 0.2s ease;
  padding: 20px;
  overflow-y: auto;
}

.candidate-drawer.open .candidate-drawer-sheet {
  transform: translateX(0);
}

.candidate-detail-content.hidden,
.candidate-detail-empty.hidden {
  display: none !important;
}

.candidate-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.candidate-detail-track {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.12);
  color: #2563eb;
  margin-bottom: 8px;
}

.candidate-detail-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.candidate-detail-meta-card {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 14px;
  padding: 10px 12px;
  background: #f8fafc;
}

.candidate-detail-meta-card span {
  display: block;
  font-size: 12px;
  color: #64748b;
  margin-bottom: 4px;
}

.candidate-detail-meta-card strong {
  font-size: 14px;
  color: #0f172a;
}

.candidate-detail-section {
  margin-top: 14px;
}

.candidate-detail-section h4 {
  margin: 0 0 8px 0;
  font-size: 14px;
}

.candidate-detail-links,
.candidate-detail-tags,
.candidate-detail-signals,
.candidate-detail-source-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.candidate-detail-link,
.candidate-detail-tag,
.candidate-detail-signal {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
  font-size: 12px;
  color: #0f172a;
  text-decoration: none;
}

.candidate-detail-link:hover {
  border-color: rgba(37, 99, 235, 0.28);
  color: #2563eb;
}

body.candidate-drawer-open {
  overflow: hidden;
}



/* === Candidate Drawer Force Fix === */
.candidate-drawer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
}

.candidate-drawer.open {
  pointer-events: auto;
}

.candidate-drawer-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.28);
  opacity: 0;
  transition: opacity 0.18s ease;
}

.candidate-drawer.open .candidate-drawer-backdrop {
  opacity: 1;
}

.candidate-drawer-sheet {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: min(520px, 92vw);
  background: #ffffff;
  box-shadow: -12px 0 40px rgba(15, 23, 42, 0.18);
  transform: translateX(100%);
  transition: transform 0.2s ease;
  padding: 20px;
  overflow-y: auto;
}

.candidate-drawer.open .candidate-drawer-sheet {
  transform: translateX(0);
}

.candidate-detail-content.hidden,
.candidate-detail-empty.hidden {
  display: none !important;
}

body.candidate-drawer-open {
  overflow: hidden;
}



/* === Active Candidate Card Linkage === */
.is-active-candidate {
  position: relative;
  border-color: rgba(37, 99, 235, 0.42) !important;
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.14), 0 14px 32px rgba(37, 99, 235, 0.12) !important;
  background: linear-gradient(180deg, rgba(37, 99, 235, 0.03), rgba(37, 99, 235, 0.06)) !important;
  transform: translateY(-1px);
}

.is-active-candidate::after {
  content: 'Ausgewählt';
  position: absolute;
  top: 12px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #2563eb;
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.24);
}

.candidate-detail-active-label {
  margin: 4px 0 8px 0;
  font-size: 12px;
  font-weight: 700;
  color: #2563eb;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.candidate-card,
.signal-card,
[data-candidate-id],
[data-id] {
  transition: box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}



/* === Active Candidate Card Hard Fix === */
article.card.clickable.is-active-candidate,
.card.clickable.is-active-candidate,
[data-candidate-id].is-active-candidate {
  position: relative !important;
  border: 2px solid #2563eb !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.16), 0 18px 36px rgba(37, 99, 235, 0.16) !important;
  background: linear-gradient(180deg, rgba(37, 99, 235, 0.05), rgba(37, 99, 235, 0.10)) !important;
  transform: translateY(-1px) !important;
}

article.card.clickable.is-active-candidate::after,
.card.clickable.is-active-candidate::after,
[data-candidate-id].is-active-candidate::after {
  content: 'Ausgewählt';
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #2563eb;
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.24);
}

#candidateDetailActiveLabel {
  margin: 4px 0 10px 0;
  font-size: 12px;
  font-weight: 800;
  color: #2563eb;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}



/* === Active Candidate Rendered State === */
article.card.clickable.is-active-candidate,
.card.clickable.is-active-candidate,
[data-candidate-id].is-active-candidate {
  position: relative !important;
  border: 2px solid #2563eb !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.14), 0 16px 34px rgba(37, 99, 235, 0.14) !important;
  background: linear-gradient(180deg, rgba(37, 99, 235, 0.04), rgba(37, 99, 235, 0.10)) !important;
}

.active-candidate-badge {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #2563eb;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.24);
}



.candidate-detail-raw-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin-top: 10px;
}

.candidate-detail-raw-item {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  padding: 10px 12px;
  background: #f8fafc;
}

.candidate-detail-raw-item span {
  display: block;
  font-size: 12px;
  color: #64748b;
  margin-bottom: 4px;
}

.candidate-detail-raw-item strong {
  display: block;
  font-size: 13px;
  color: #0f172a;
  word-break: break-word;
}


/* === Candidate Detail Sidebar Final Fix === */
.candidates-layout {
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 460px);
  align-items: start;
}

.candidate-detail-panel {
  position: sticky;
  top: 24px;
  align-self: start;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
}

#candidateDetailPanel {
  display: block;
}

.candidate-drawer-backdrop {
  display: none !important;
}

.hidden#candidateDetailCloseBtn,
#candidateDetailCloseBtn.hidden {
  display: none !important;
}

body.candidate-drawer-open {
  overflow: auto !important;
}

@media (max-width: 1100px) {
  .candidates-layout {
    grid-template-columns: 1fr;
  }

  .candidate-detail-panel {
    position: static;
    max-height: none;
    overflow: visible;
    margin-top: 18px;
  }
}

/* === Candidate Detail Sidebar Final === */
.candidates-layout {
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 460px);
  align-items: start;
}

.candidate-detail-panel {
  position: sticky;
  top: 24px;
  align-self: start;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
}

#candidateDetailPanel {
  display: block;
}

#candidateDetailCloseBtn.hidden,
.hidden#candidateDetailCloseBtn {
  display: none !important;
}

@media (max-width: 1100px) {
  .candidates-layout {
    grid-template-columns: 1fr;
  }

  .candidate-detail-panel {
    position: static;
    max-height: none;
    overflow: visible;
    margin-top: 18px;
  }
}

/* === Force disable legacy drawer overlay === */
.candidate-drawer,
.candidate-drawer.open,
.candidate-drawer-backdrop,
.candidate-drawer-sheet,
.candidate-drawer.open .candidate-drawer-backdrop,
.candidate-drawer.open .candidate-drawer-sheet {
  position: static !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  height: auto !important;
  width: auto !important;
  transform: none !important;
  box-shadow: none !important;
  background: transparent !important;
  pointer-events: auto !important;
  opacity: 1 !important;
  display: block !important;
}

body.candidate-drawer-open {
  overflow: auto !important;
}

/* === Candidate layout desktop override === */
.candidates-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.2fr) minmax(380px, 480px) !important;
  align-items: start !important;
  gap: 18px !important;
}

#candidateDetailPanel,
.candidate-detail-panel {
  display: block !important;
  position: sticky !important;
  top: 160px !important;
  align-self: start !important;
  max-height: calc(100vh - 48px) !important;
  overflow-y: auto !important;
}

@media (max-width: 820px) {
  .candidates-layout {
    grid-template-columns: 1fr !important;
  }

  #candidateDetailPanel,
  .candidate-detail-panel {
    position: static !important;
    max-height: none !important;
    overflow: visible !important;
    margin-top: 18px !important;
  }
}

/* === ABSOLUTE FINAL CANDIDATE LAYOUT OVERRIDE === */
@media (min-width: 821px) {
  .view[data-view="candidates"] .candidates-layout {
    display: grid !important;
    grid-template-columns: minmax(0, 1.15fr) 460px !important;
    gap: 18px !important;
    align-items: start !important;
  }

  .view[data-view="candidates"] #candidateDetailPanel,
  .view[data-view="candidates"] .candidate-detail-panel {
    display: block !important;
    position: sticky !important;
    top: 160px !important;
    align-self: start !important;
    height: auto !important;
    max-height: calc(100vh - 48px) !important;
    overflow-y: auto !important;
    margin: 0 !important;
    width: 460px !important;
    min-width: 460px !important;
  }

  .view[data-view="candidates"] #candidateCards {
    min-width: 0 !important;
  }
}

@media (max-width: 820px) {
  .view[data-view="candidates"] .candidates-layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .view[data-view="candidates"] #candidateDetailPanel,
  .view[data-view="candidates"] .candidate-detail-panel {
    position: static !important;
    width: auto !important;
    min-width: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    margin-top: 18px !important;
  }
}

/* === OPTION B: Floating Candidate Detail Panel === */
@media (min-width: 821px) {
  .view[data-view="candidates"] .candidates-layout {
    display: block !important;
  }

  .view[data-view="candidates"] #candidateCards {
    width: calc(100% - 500px) !important;
    min-width: 0 !important;
  }

  .view[data-view="candidates"] #candidateDetailPanel,
  .view[data-view="candidates"] .candidate-detail-panel {
    position: fixed !important;
    right: 20px !important;
    top: 160px !important;
    width: 460px !important;
    min-width: 460px !important;
    max-width: 460px !important;
    max-height: calc(100vh - 48px) !important;
    overflow-y: auto !important;
    z-index: 1200 !important;
    display: block !important;
    margin: 0 !important;
  }
}

@media (max-width: 820px) {
  .view[data-view="candidates"] .candidates-layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .view[data-view="candidates"] #candidateCards {
    width: auto !important;
  }

  .view[data-view="candidates"] #candidateDetailPanel,
  .view[data-view="candidates"] .candidate-detail-panel {
    position: static !important;
    right: auto !important;
    top: auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    max-height: none !important;
    overflow: visible !important;
    margin-top: 18px !important;
  }
}

/* === FINAL CANDIDATE DRAWER FINISH === */
body.candidate-drawer-open {
  overflow: hidden !important;
}

.view[data-view="candidates"] #candidateDetailPanel,
.view[data-view="candidates"] .candidate-detail-panel {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  width: min(680px, 92vw) !important;
  height: 100vh !important;
  max-height: 100vh !important;
  overflow-y: auto !important;
  z-index: 1400 !important;
  background: #ffffff !important;
  box-shadow: -20px 0 48px rgba(15, 23, 42, 0.22) !important;
  transform: translateX(100%) !important;
  transition: transform 0.22s ease !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

.view[data-view="candidates"] #candidateDetailPanel.open,
.view[data-view="candidates"] .candidate-detail-panel.open {
  transform: translateX(0) !important;
}

.view[data-view="candidates"] #candidateDetailPanel::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.28);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s ease;
  z-index: -1;
}

.view[data-view="candidates"] #candidateDetailPanel.open::before {
  opacity: 1;
  pointer-events: auto;
}

@media (max-width: 820px) {
  .view[data-view="candidates"] #candidateDetailPanel,
  .view[data-view="candidates"] .candidate-detail-panel {
    width: 100vw !important;
    max-width: 100vw !important;
  }
}

/* === Drawer polish / aligned with app UI === */
.view[data-view="candidates"] #candidateDetailPanel,
.view[data-view="candidates"] .candidate-detail-panel {
  background: rgba(255, 255, 255, 0.88) !important;
  backdrop-filter: blur(14px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(14px) saturate(140%) !important;
  border-left: 1px solid rgba(15, 23, 42, 0.08) !important;
  box-shadow: -24px 0 48px rgba(15, 23, 42, 0.14) !important;
  padding: 24px 20px 28px 20px !important;
}

.view[data-view="candidates"] #candidateDetailPanel::before {
  background: rgba(15, 23, 42, 0.16) !important;
}

#candidateDetailPanel .candidate-detail-meta-card {
  background: rgba(248, 250, 252, 0.82) !important;
  border: 1px solid rgba(15, 23, 42, 0.06) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.35);
}

#candidateDetailPanel .candidate-detail-link,
#candidateDetailPanel .candidate-detail-tag,
#candidateDetailPanel .candidate-detail-signal {
  background: rgba(255,255,255,0.82) !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  transition: all 0.16s ease !important;
}

#candidateDetailPanel .candidate-detail-link:hover {
  transform: translateY(-1px);
  border-color: rgba(37, 99, 235, 0.28) !important;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.10);
}

#candidateDetailPanel .candidate-detail-header {
  position: sticky;
  top: -24px;
  z-index: 3;
  padding-top: 8px;
  padding-bottom: 12px;
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0.96),
    rgba(255,255,255,0.86)
  ) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

#candidateDetailCloseBtn {
  border-radius: 12px !important;
}

/* === UX fix: keep page scrollable while drawer is open === */
body.candidate-drawer-open {
  overflow: auto !important;
}

/* === UX fix: remove explicit 'Ausgewählt' labels; blue outline is enough === */
#candidateDetailActiveLabel {
  display: none !important;
}

.active-candidate-badge {
  display: none !important;
}

.is-active-candidate::after,
article.card.clickable.is-active-candidate::after,
.card.clickable.is-active-candidate::after,
[data-candidate-id].is-active-candidate::after {
  content: none !important;
  display: none !important;
}

/* === Step 1: candidate drawer header meta === */
#candidateDetailPanel .candidate-detail-header-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

#candidateDetailPanel .candidate-detail-header-meta .candidate-detail-tag {
  background: rgba(255,255,255,0.78) !important;
}

/* === Prio A: Kontakt & Profile === */
#candidateDetailPrimaryLinks {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

#candidateDetailPrimaryLinks .candidate-detail-link {
  background: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(37, 99, 235, 0.10) !important;
  font-weight: 600;
}

/* === Prio B: Header aufräumen === */
#candidateDetailPanel .candidate-detail-header {
  margin-bottom: 10px !important;
}

#candidateDetailPanel .candidate-detail-track {
  margin-bottom: 10px !important;
}

#candidateDetailPanel #candidateDetailHeadline {
  margin-bottom: 6px !important;
  color: #475569 !important;
}

#candidateDetailPanel .candidate-detail-header-meta {
  margin-top: 8px !important;
  gap: 8px !important;
}

#candidateDetailPanel .candidate-detail-header-meta .candidate-detail-tag {
  background: rgba(255,255,255,0.78) !important;
  font-size: 12px !important;
}

/* === Drawer compact mode === */
#candidateDetailPanel,
.candidate-detail-panel {
  padding: 16px 14px 18px 14px !important;
}

#candidateDetailPanel .candidate-detail-header {
  margin-bottom: 8px !important;
  padding-top: 4px !important;
  padding-bottom: 8px !important;
}

#candidateDetailPanel .candidate-detail-track {
  margin-bottom: 6px !important;
  padding: 3px 8px !important;
  font-size: 11px !important;
}

#candidateDetailPanel h3 {
  margin: 0 0 2px 0 !important;
  font-size: 18px !important;
  line-height: 1.15 !important;
}

#candidateDetailPanel #candidateDetailHeadline {
  margin: 0 0 4px 0 !important;
  font-size: 13px !important;
  line-height: 1.3 !important;
}

#candidateDetailPanel .candidate-detail-header-meta {
  gap: 6px !important;
  margin-top: 6px !important;
}

#candidateDetailPanel .candidate-detail-section {
  margin-top: 10px !important;
}

#candidateDetailPanel .candidate-detail-section h4 {
  margin: 0 0 6px 0 !important;
  font-size: 13px !important;
}

#candidateDetailPanel .candidate-detail-meta-grid {
  gap: 8px !important;
  margin-bottom: 10px !important;
}

#candidateDetailPanel .candidate-detail-meta-card {
  padding: 8px 10px !important;
  border-radius: 12px !important;
  min-height: auto !important;
}

#candidateDetailPanel .candidate-detail-meta-card span {
  font-size: 11px !important;
  margin-bottom: 2px !important;
}

#candidateDetailPanel .candidate-detail-meta-card strong {
  font-size: 13px !important;
  line-height: 1.2 !important;
}

#candidateDetailPanel .candidate-detail-links,
#candidateDetailPanel .candidate-detail-tags,
#candidateDetailPanel .candidate-detail-signals,
#candidateDetailPanel .candidate-detail-source-meta,
#candidateDetailPanel #candidateDetailPrimaryLinks {
  gap: 6px !important;
}

#candidateDetailPanel .candidate-detail-link,
#candidateDetailPanel .candidate-detail-tag,
#candidateDetailPanel .candidate-detail-signal {
  padding: 4px 8px !important;
  font-size: 11px !important;
  border-radius: 999px !important;
}

#candidateDetailPanel p {
  line-height: 1.35 !important;
}

#candidateDetailPanel .candidate-detail-raw-grid {
  gap: 6px !important;
  margin-top: 8px !important;
}

#candidateDetailPanel .candidate-detail-raw-item {
  padding: 8px 10px !important;
}

#candidateDetailPanel .candidate-detail-raw-item span {
  font-size: 11px !important;
  margin-bottom: 2px !important;
}

#candidateDetailPanel .candidate-detail-raw-item strong {
  font-size: 12px !important;
  line-height: 1.3 !important;
}

/* === Summary as real assessment === */
#candidateDetailSummary {
  font-size: 14px !important;
  line-height: 1.45 !important;
  color: #334155 !important;
}

#candidateDetailUsability .candidate-detail-tag {
  font-weight: 600;
}

#candidateDetailHistoricalSources .candidate-detail-tag,
#candidateDetailHistoricalSources .candidate-detail-link {
  opacity: 0.72;
}

#candidateDetailActions {
  margin-top: 10px;
  display: flex;
  gap: 8px;
}

#candidateDetailActions .primary.small {
  border-radius: 12px;
}

#candidateDetailUsability .candidate-detail-tag {
  font-weight: 600;
}

#candidateDetailSummary {
  max-width: 62ch;
}

.privacy-warning {
  border-color: rgba(220, 38, 38, 0.24) !important;
  background: rgba(220, 38, 38, 0.08) !important;
  color: #991b1b !important;
}

#candidateDetailActionsSection {
  display: block !important;
}

#candidateDetailActions {
  display: flex !important;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

#candidateDetailActions .primary.small,
#candidateDetailActions .ghost.small {
  border-radius: 12px;
}

#candidateDetailResearchPanel.hidden {
  display: none !important;
}

.candidate-detail-helper {
  margin: 0 0 8px 0;
  color: #475569;
  font-size: 12px;
  line-height: 1.35;
}

.candidate-research-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin-top: 8px;
}

.candidate-research-link {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 9px 11px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: rgba(255, 255, 255, 0.78);
  text-decoration: none;
  color: #0f172a;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05);
}

.candidate-research-link:hover {
  border-color: rgba(37, 99, 235, 0.35);
  background: rgba(255, 255, 255, 0.96);
}

.candidate-research-link strong {
  font-size: 13px;
  color: #0f172a;
}

.candidate-research-link span {
  font-size: 11px;
  color: #64748b;
}

.candidate-research-note {
  margin-top: 8px;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.04);
  color: #475569;
  font-size: 11px;
  line-height: 1.35;
}

#candidateDetailEnrichBtn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.candidate-source-readiness {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.source-readiness-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 11px;
  font-weight: 650;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: rgba(255, 255, 255, 0.74);
  color: #334155;
}

.source-readiness-active,
.source-readiness-hint {
  border-color: rgba(22, 163, 74, 0.24);
  background: rgba(22, 163, 74, 0.08);
  color: #166534;
}

.source-readiness-historical {
  border-color: rgba(245, 158, 11, 0.30);
  background: rgba(245, 158, 11, 0.10);
  color: #92400e;
}

.source-readiness-recommended {
  border-color: rgba(37, 99, 235, 0.26);
  background: rgba(37, 99, 235, 0.08);
  color: #1d4ed8;
}

.source-readiness-missing,
.source-readiness-optional {
  border-color: rgba(100, 116, 139, 0.18);
  background: rgba(248, 250, 252, 0.70);
  color: #475569;
}

.candidate-manual-source-form {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.60);
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.candidate-manual-source-form label {
  display: grid;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  color: #334155;
}

.candidate-manual-source-form input,
.candidate-manual-source-form select,
.candidate-manual-source-form textarea {
  width: 100%;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 10px;
  padding: 8px 9px;
  font-size: 12px;
  color: #0f172a;
  background: rgba(255, 255, 255, 0.90);
  box-sizing: border-box;
}

.candidate-manual-source-form textarea {
  resize: vertical;
}

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

.candidate-decision-item {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.72);
}

.candidate-decision-item span {
  display: block;
  font-size: 11px;
  color: #64748b;
  margin-bottom: 3px;
}

.candidate-decision-item strong {
  display: block;
  font-size: 13px;
  color: #0f172a;
  text-transform: capitalize;
}

.candidate-next-action-card {
  margin-top: 10px;
  border-radius: 14px;
  padding: 10px 12px;
  border: 1px solid rgba(37, 99, 235, 0.18);
  background: rgba(37, 99, 235, 0.07);
  color: #1e3a8a;
}

.candidate-next-action-card strong {
  display: block;
  font-size: 14px;
  margin-bottom: 4px;
}

.candidate-next-action-card span {
  display: block;
  font-size: 12px;
  line-height: 1.35;
}

.candidate-next-action-strong {
  border-color: rgba(22, 163, 74, 0.22);
  background: rgba(22, 163, 74, 0.08);
  color: #166534;
}

.candidate-next-action-warning {
  border-color: rgba(245, 158, 11, 0.30);
  background: rgba(245, 158, 11, 0.10);
  color: #92400e;
}

.candidate-next-action-danger {
  border-color: rgba(220, 38, 38, 0.24);
  background: rgba(220, 38, 38, 0.08);
  color: #991b1b;
}

@media (max-width: 520px) {
  .candidate-decision-grid {
    grid-template-columns: 1fr;
  }
}

.candidate-next-action-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.candidate-next-action-btn {
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 12px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.82);
  color: #0f172a;
}

.candidate-next-action-btn.primary {
  border-color: rgba(37, 99, 235, 0.22);
  background: rgba(37, 99, 235, 0.10);
  color: #1d4ed8;
}

.candidate-next-action-btn.secondary {
  border-color: rgba(15, 23, 42, 0.12);
  background: rgba(248, 250, 252, 0.88);
  color: #334155;
}

.candidate-next-action-btn.danger {
  border-color: rgba(220, 38, 38, 0.24);
  background: rgba(220, 38, 38, 0.08);
  color: #991b1b;
}

.candidate-next-action-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.candidate-next-action-feedback {
  display: block;
  margin-top: 8px;
  font-size: 11px;
  line-height: 1.35;
  color: #475569;
  font-style: normal;
}

.candidate-shortlist-form {
  display: none;
  gap: 8px;
  margin-top: 10px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.candidate-shortlist-form label {
  display: grid;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  color: #334155;
}

.candidate-shortlist-form select,
.candidate-shortlist-form textarea {
  width: 100%;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 10px;
  padding: 8px 9px;
  font-size: 12px;
  color: #0f172a;
  background: rgba(255, 255, 255, 0.92);
  box-sizing: border-box;
}

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

.candidate-shortlist-status {
  display: grid;
  gap: 4px;
  margin-top: 10px;
  padding: 9px 10px;
  border-radius: 12px;
  border: 1px solid rgba(22, 163, 74, 0.18);
  background: rgba(22, 163, 74, 0.07);
  color: #166534;
}

.candidate-shortlist-status strong {
  font-size: 12px;
}

.candidate-shortlist-status span {
  font-size: 11px;
  line-height: 1.35;
}

.candidate-shortlist-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
}

.candidate-shortlist-remove {
  border: 1px solid rgba(220, 38, 38, 0.22);
  background: rgba(220, 38, 38, 0.07);
  color: #991b1b;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
}

.candidate-shortlist-remove:hover {
  background: rgba(220, 38, 38, 0.12);
}

.candidate-shortlist-fit-hint {
  border-radius: 12px;
  padding: 8px 10px;
  font-size: 11px;
  line-height: 1.35;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: rgba(248, 250, 252, 0.85);
  color: #475569;
}

.candidate-shortlist-fit-ok {
  border-color: rgba(22, 163, 74, 0.20);
  background: rgba(22, 163, 74, 0.07);
  color: #166534;
}

.candidate-shortlist-fit-warning {
  border-color: rgba(245, 158, 11, 0.30);
  background: rgba(245, 158, 11, 0.10);
  color: #92400e;
}

.candidate-doc-consent-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.candidate-doc-consent-item {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.72);
}

.candidate-doc-consent-item span {
  display: block;
  font-size: 11px;
  color: #64748b;
  margin-bottom: 3px;
}

.candidate-doc-consent-item strong {
  display: block;
  font-size: 13px;
  color: #0f172a;
}

.doc-status-available,
.doc-status-granted,
.doc-status-usable {
  border-color: rgba(22, 163, 74, 0.22);
  background: rgba(22, 163, 74, 0.08);
}

.doc-status-missing,
.doc-status-needs_cv,
.doc-status-needs_consent {
  border-color: rgba(245, 158, 11, 0.28);
  background: rgba(245, 158, 11, 0.10);
}

.doc-status-withdrawn,
.doc-status-restricted,
.doc-status-blocked,
.doc-status-deleted {
  border-color: rgba(220, 38, 38, 0.24);
  background: rgba(220, 38, 38, 0.08);
}

.candidate-doc-consent-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.candidate-doc-consent-form {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.candidate-doc-consent-form.hidden {
  display: none !important;
}

.candidate-doc-consent-form label {
  display: grid;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  color: #334155;
}

.candidate-doc-consent-form input,
.candidate-doc-consent-form select,
.candidate-doc-consent-form textarea {
  width: 100%;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 10px;
  padding: 8px 9px;
  font-size: 12px;
  color: #0f172a;
  background: rgba(255, 255, 255, 0.92);
  box-sizing: border-box;
}

.candidate-doc-consent-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* Candidate Focus Mode
   Kandidatenliste wird Navigation, rechter Bereich wird Arbeitsfläche.
*/

body.candidate-focus-mode .candidate-focus-list {
  flex: 0 0 32% !important;
  max-width: 420px !important;
  min-width: 300px !important;
}

body.candidate-focus-mode .candidate-focus-workspace {
  flex: 1 1 68% !important;
  max-width: none !important;
  min-width: 620px !important;
}

body.candidate-focus-mode .candidate-detail-drawer,
body.candidate-focus-mode aside.candidate-focus-workspace,
body.candidate-focus-mode .detail-panel.candidate-focus-workspace {
  max-width: none !important;
}

/* Häufige Grid-/Layout-Container im Radar breiter zugunsten des Workspaces steuern */
body.candidate-focus-mode .radar-layout,
body.candidate-focus-mode .candidate-layout,
body.candidate-focus-mode .workspace-layout,
body.candidate-focus-mode .main-grid {
  grid-template-columns: minmax(300px, 34%) minmax(620px, 66%) !important;
}

/* Im breiteren Workspace wichtige Cards kompakter nebeneinander darstellen */
body.candidate-focus-mode .candidate-decision-grid,
body.candidate-focus-mode .candidate-doc-consent-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Drawer-Inhalte besser ausnutzen */
body.candidate-focus-mode .candidate-detail-section {
  scroll-margin-top: 16px;
}

@media (max-width: 1100px) {
  body.candidate-focus-mode .candidate-focus-list,
  body.candidate-focus-mode .candidate-focus-workspace {
    max-width: none !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }

  body.candidate-focus-mode .radar-layout,
  body.candidate-focus-mode .candidate-layout,
  body.candidate-focus-mode .workspace-layout,
  body.candidate-focus-mode .main-grid {
    grid-template-columns: 1fr !important;
  }
}

/* HOTFIX: Candidate Focus Mode neutralisieren.
   Der erste Focus-Mode-Patch trifft aktuell nicht die korrekte DOM-Struktur
   und erzeugt eine leere Hauptfläche. Bis zur gezielten Workspace-Umstellung
   bleibt der bestehende Layoutfluss stabil.
*/

body.candidate-focus-mode .candidate-focus-list,
body.candidate-focus-mode .candidate-focus-workspace {
  flex: initial !important;
  max-width: initial !important;
  min-width: initial !important;
}

body.candidate-focus-mode .radar-layout,
body.candidate-focus-mode .candidate-layout,
body.candidate-focus-mode .workspace-layout,
body.candidate-focus-mode .main-grid {
  grid-template-columns: initial !important;
}

body.candidate-focus-mode .candidate-detail-drawer,
body.candidate-focus-mode aside.candidate-focus-workspace,
body.candidate-focus-mode .detail-panel.candidate-focus-workspace {
  max-width: initial !important;
}

/* TARGETED Candidate Workspace Focus Mode
   Echte DOM-Struktur:
   .candidates-layout
     > article.panel:first-child = Kandidatenliste
     > #candidateDetailPanel     = rechter Workspace
*/

/* alte generische Focus-Regeln konsequent entschärfen */
body.candidate-focus-mode .radar-layout,
body.candidate-focus-mode .candidate-layout,
body.candidate-focus-mode .workspace-layout,
body.candidate-focus-mode .main-grid {
  grid-template-columns: unset !important;
}

body.candidate-focus-mode .candidate-detail-drawer,
body.candidate-focus-mode aside.candidate-focus-workspace,
body.candidate-focus-mode .detail-panel.candidate-focus-workspace {
  max-width: unset !important;
  min-width: unset !important;
}

/* echte Candidate-Ansicht steuern */
body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
  display: grid !important;
  grid-template-columns: minmax(360px, 42%) minmax(520px, 58%) !important;
  gap: 18px !important;
  align-items: start !important;
}

body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel.candidate-focus-list {
  min-width: 0 !important;
  max-width: none !important;
  overflow: visible !important;
}

body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
  position: sticky !important;
  top: 18px !important;
  min-width: 0 !important;
  max-width: none !important;
  width: auto !important;
  height: calc(100vh - 36px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

/* auf sehr breiten Screens mehr Workspace */
@media (min-width: 1500px) {
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(360px, 38%) minmax(640px, 62%) !important;
  }
}

/* auf kleineren Screens lieber stabil bleiben */
@media (max-width: 1180px) {
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: 1fr !important;
  }

  body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
    position: relative !important;
    top: auto !important;
    height: auto !important;
  }
}

/* =========================================================
   Candidate Workspace Layout Quality Pass
   Ziel: professioneller ATS-/CRM-Workspace statt gequetschter Drawer.
   ========================================================= */

/* Kandidatenansicht: ausgewogeneres Verhältnis Liste / Workspace */
.content-grid.candidates-layout,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
  display: grid !important;
  grid-template-columns: minmax(460px, 44%) minmax(620px, 56%) !important;
  gap: 22px !important;
  align-items: start !important;
}

/* Linke Kandidatenliste darf nicht wie eine Mini-Spalte kollabieren */
.content-grid.candidates-layout > article.panel:first-child,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel.candidate-focus-list {
  min-width: 460px !important;
  max-width: none !important;
  overflow: visible !important;
}

/* Rechter Workspace als echtes Arbeitsfenster */
#candidateDetailPanel,
body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
  min-width: 620px !important;
  max-width: none !important;
  width: auto !important;
  background: #f6f7fb !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.08) !important;
  border-radius: 22px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

/* Im Detailbereich weniger graue Wand, mehr Card-Charakter */
#candidateDetailContent {
  background: transparent !important;
  padding: 18px !important;
}

/* Header klarer und hochwertiger */
.candidate-detail-header {
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  border-radius: 18px !important;
  padding: 18px !important;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06) !important;
  margin-bottom: 14px !important;
}

.candidate-detail-header h3,
#candidateDetailName {
  font-size: 22px !important;
  line-height: 1.15 !important;
  letter-spacing: -0.02em !important;
}

#candidateDetailHeadline {
  font-size: 14px !important;
  line-height: 1.35 !important;
  color: #475569 !important;
}

/* Detail-Sektionen als klare Karten */
.candidate-detail-section {
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  border-radius: 18px !important;
  padding: 16px !important;
  margin-bottom: 14px !important;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.045) !important;
}

.candidate-detail-section h4 {
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
  color: #0f172a !important;
  margin-bottom: 10px !important;
}

/* Meta-Karten und Decision Grid im Workspace besser nutzen */
.candidate-detail-meta-grid,
.candidate-decision-grid,
.candidate-doc-consent-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.candidate-detail-meta-card,
.candidate-decision-card,
.candidate-doc-consent-card {
  background: #f8fafc !important;
  border: 1px solid rgba(15, 23, 42, 0.06) !important;
  border-radius: 14px !important;
  padding: 12px !important;
}

/* Nächste Aktion hervorheben, aber nicht schreien lassen */
.candidate-next-action,
.candidate-action-recommendation,
#candidateDetailNextAction {
  border-radius: 16px !important;
}

/* Linke Cards wieder lesbar machen */
.candidate-card,
.signal-card,
.radar-card {
  border-radius: 20px !important;
  padding: 18px !important;
}

/* Bei sehr schmalen Cards Textbruch vermeiden */
.candidate-card h4,
.signal-card h4,
.radar-card h4 {
  font-size: 16px !important;
  line-height: 1.2 !important;
}

.candidate-card .candidate-title,
.signal-card .candidate-title,
.radar-card .candidate-title {
  line-height: 1.25 !important;
}

/* Tags lesbarer */
.candidate-detail-tags,
.candidate-card-tags,
.signal-card-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.candidate-detail-tags span,
.candidate-card-tags span,
.signal-card-tags span,
.tag,
.badge {
  border-radius: 999px !important;
}

/* Auf großen Screens leicht mehr Detailfläche, aber Liste bleibt brauchbar */
@media (min-width: 1600px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(500px, 42%) minmax(760px, 58%) !important;
  }

  .content-grid.candidates-layout > article.panel:first-child {
    min-width: 500px !important;
  }

  #candidateDetailPanel {
    min-width: 760px !important;
  }
}

/* Auf kleineren Screens stabil bleiben */
@media (max-width: 1180px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: 1fr !important;
  }

  .content-grid.candidates-layout > article.panel:first-child,
  #candidateDetailPanel {
    min-width: 0 !important;
  }
}

/* =========================================================
   Product Layout Pass v2
   Ziel: weniger Leerraum, echte Arbeitsfläche, produktreife Dichte.
   ========================================================= */

/* Gesamtansicht: Liste und Workspace harmonischer ausbalancieren */
.content-grid.candidates-layout,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
  display: grid !important;
  grid-template-columns: minmax(620px, 48%) minmax(680px, 52%) !important;
  gap: 20px !important;
  align-items: start !important;
}

/* Linker Panel-Container darf seine Fläche wirklich nutzen */
.content-grid.candidates-layout > article.panel:first-child,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel.candidate-focus-list {
  min-width: 620px !important;
  max-width: none !important;
  width: 100% !important;
  overflow: visible !important;
  padding: 16px !important;
}

/* Der Kandidatenlisten-Container: aus schmaler Einspalte wird responsives Card-Grid */
#candidateList,
#candidateCards,
#canonicalCandidateList,
.candidate-list,
.candidate-cards,
.signal-card-list,
.radar-card-list {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(260px, 1fr)) !important;
  gap: 14px !important;
  align-items: stretch !important;
}

/* Einzelne Candidate Cards füllen die Grid-Zelle */
#candidateList > *,
#candidateCards > *,
#canonicalCandidateList > *,
.candidate-list > *,
.candidate-cards > *,
.signal-card-list > *,
.radar-card-list > * {
  width: 100% !important;
  max-width: none !important;
}

/* Falls die App generische Card-Klassen nutzt */
.candidate-card,
.signal-card,
.radar-card,
.canonical-candidate-card {
  width: 100% !important;
  max-width: none !important;
  min-height: 260px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  padding: 16px !important;
  border-radius: 18px !important;
}

/* Card-Header kompakter und lesbarer */
.candidate-card h4,
.signal-card h4,
.radar-card h4,
.canonical-candidate-card h4 {
  font-size: 15px !important;
  line-height: 1.2 !important;
  margin-bottom: 4px !important;
}

.candidate-card .muted,
.signal-card .muted,
.radar-card .muted,
.canonical-candidate-card .muted {
  font-size: 12px !important;
  line-height: 1.25 !important;
}

/* Score-Bereiche kompakter, damit Cards nicht unnötig hoch werden */
.candidate-card .score-grid,
.signal-card .score-grid,
.radar-card .score-grid,
.canonical-candidate-card .score-grid,
.candidate-card .signal-grid,
.signal-card .signal-grid,
.radar-card .signal-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px 14px !important;
  margin-top: 12px !important;
}

.candidate-card .stat-line,
.signal-card .stat-line,
.radar-card .stat-line {
  margin: 6px 0 !important;
}

/* Tags in Cards weniger platzfressend */
.candidate-card .tag,
.signal-card .tag,
.radar-card .tag,
.canonical-candidate-card .tag,
.candidate-card .badge,
.signal-card .badge,
.radar-card .badge {
  font-size: 11px !important;
  padding: 5px 8px !important;
}

/* Rechter Workspace: weniger graue Wand, mehr ruhige Produktfläche */
#candidateDetailPanel,
body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
  min-width: 680px !important;
  background: #f8fafc !important;
  border-radius: 22px !important;
  padding: 14px !important;
}

/* Detailinhalt dichter */
#candidateDetailContent {
  padding: 0 !important;
  display: grid !important;
  gap: 12px !important;
}

/* Header nimmt volle Breite, aber nicht zu viel Höhe */
.candidate-detail-header {
  margin-bottom: 0 !important;
  padding: 16px !important;
  border-radius: 18px !important;
}

/* Meta direkt unter Header kompakter */
.candidate-detail-meta-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.candidate-detail-meta-card {
  min-height: 58px !important;
  padding: 10px !important;
}

/* Detailsections dichter und weniger riesige Leerboxen */
.candidate-detail-section {
  margin-bottom: 0 !important;
  padding: 14px !important;
  border-radius: 16px !important;
}

/* Leere Sektionen visuell minimieren */
.candidate-detail-section:has(.candidate-detail-source-meta:empty),
.candidate-detail-section:has(.candidate-detail-signals:empty),
.candidate-detail-section:has(.candidate-detail-links:empty) {
  min-height: 0 !important;
  padding-block: 10px !important;
}

/* Summary darf kompakt bleiben */
#candidateDetailSummary,
.candidate-detail-summary {
  line-height: 1.45 !important;
  font-size: 13px !important;
}

/* Verwertbarkeit: Cards dichter im Grid */
.candidate-decision-grid,
.candidate-doc-consent-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

.candidate-decision-card,
.candidate-doc-consent-card {
  padding: 10px !important;
  min-height: 58px !important;
}

/* Wenn der Workspace breit genug ist, bestimmte Bereiche als 2-Spalten-Layout */
@media (min-width: 1400px) {
  #candidateDetailContent {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .candidate-detail-header,
  .candidate-detail-meta-grid,
  #candidateDetailDecisionSection,
  #candidateDetailDocumentsConsentSection,
  #candidateDetailActionsSection,
  #candidateDetailResearchPanel,
  #candidateDetailBullhornSection {
    grid-column: 1 / -1 !important;
  }

  /* Summary, Quellen, Evidenzen, Tags/Signale können nebeneinander laufen */
  .candidate-detail-section {
    align-self: start !important;
  }
}

/* Sehr breite Screens: etwas mehr Liste, damit kein weißer See links entsteht */
@media (min-width: 1600px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(720px, 50%) minmax(760px, 50%) !important;
  }

  .content-grid.candidates-layout > article.panel:first-child {
    min-width: 720px !important;
  }

  #candidateDetailPanel {
    min-width: 760px !important;
  }
}

/* Mittlere Screens: Liste bleibt zweispaltig, bis es wirklich eng wird */
@media (max-width: 1350px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(520px, 46%) minmax(620px, 54%) !important;
  }

  .content-grid.candidates-layout > article.panel:first-child {
    min-width: 520px !important;
  }

  #candidateList,
  #candidateCards,
  #canonicalCandidateList,
  .candidate-list,
  .candidate-cards,
  .signal-card-list,
  .radar-card-list {
    grid-template-columns: 1fr !important;
  }
}

/* Mobile/kleine Fenster: sauber stapeln */
@media (max-width: 1180px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: 1fr !important;
  }

  .content-grid.candidates-layout > article.panel:first-child,
  #candidateDetailPanel {
    min-width: 0 !important;
  }

  #candidateList,
  #candidateCards,
  #canonicalCandidateList,
  .candidate-list,
  .candidate-cards,
  .signal-card-list,
  .radar-card-list {
    grid-template-columns: 1fr !important;
  }

  #candidateDetailContent {
    grid-template-columns: 1fr !important;
  }

  .candidate-detail-meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* =========================================================
   Candidate Split View Fix
   Linke Liste scrollt, rechter Workspace bleibt sichtbar.
   ========================================================= */

/* Kandidatenbereich auf Viewport-Höhe begrenzen */
.content-grid.candidates-layout,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
  height: calc(100vh - 210px) !important;
  min-height: 640px !important;
  overflow: hidden !important;
  align-items: stretch !important;
}

/* Linke Liste wird eigener Scrollbereich */
.content-grid.candidates-layout > article.panel:first-child,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel.candidate-focus-list {
  height: 100% !important;
  max-height: calc(100vh - 210px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
  scrollbar-gutter: stable !important;
}

/* Rechter Workspace bleibt im sichtbaren Bereich */
#candidateDetailPanel,
body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
  position: sticky !important;
  top: 18px !important;
  height: calc(100vh - 210px) !important;
  max-height: calc(100vh - 210px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
  scrollbar-gutter: stable !important;
  align-self: start !important;
}

/* Wenn links eine Card fokussiert wird, nicht die ganze Seite springen lassen */
.candidate-card,
.signal-card,
.radar-card,
.canonical-candidate-card {
  scroll-margin-top: 18px !important;
}

/* Detailinhalt bleibt kompakt innerhalb des rechten Scrollcontainers */
#candidateDetailContent {
  min-height: auto !important;
}

/* Auf kleineren Screens wieder normales Stacking */
@media (max-width: 1180px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  .content-grid.candidates-layout > article.panel:first-child,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel.candidate-focus-list,
  #candidateDetailPanel,
  body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
    position: relative !important;
    top: auto !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }
}

/* =========================================================
   Candidate List: Single Row Cards
   Ziel: eine breite Kandidatenkachel je Zeile statt 2-Spalten-Grid.
   ========================================================= */

/* Listencontainer immer einspaltig, aber volle Breite */
#candidateList,
#candidateCards,
#canonicalCandidateList,
.candidate-list,
.candidate-cards,
.signal-card-list,
.radar-card-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
  align-items: stretch !important;
  width: 100% !important;
}

/* Cards füllen die gesamte Listenbreite */
#candidateList > *,
#candidateCards > *,
#canonicalCandidateList > *,
.candidate-list > *,
.candidate-cards > *,
.signal-card-list > *,
.radar-card-list > *,
.candidate-card,
.signal-card,
.radar-card,
.canonical-candidate-card {
  width: 100% !important;
  max-width: none !important;
}

/* Breite Kandidatenkarte horizontaler strukturieren */
.candidate-card,
.signal-card,
.radar-card,
.canonical-candidate-card {
  min-height: 190px !important;
  padding: 18px !important;
  display: grid !important;
  grid-template-columns: minmax(220px, 1.05fr) minmax(280px, 1.35fr) !important;
  grid-template-rows: auto auto !important;
  column-gap: 22px !important;
  row-gap: 12px !important;
  align-items: start !important;
}

/* Header/Identität links */
.candidate-card > :first-child,
.signal-card > :first-child,
.radar-card > :first-child,
.canonical-candidate-card > :first-child {
  min-width: 0 !important;
}

/* Score-/Signalbereich rechts breiter nutzen */
.candidate-card .score-grid,
.signal-card .score-grid,
.radar-card .score-grid,
.canonical-candidate-card .score-grid,
.candidate-card .signal-grid,
.signal-card .signal-grid,
.radar-card .signal-grid {
  grid-column: 2 !important;
  grid-row: 1 / span 2 !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px 18px !important;
  margin-top: 0 !important;
}

/* Tags links unten platzieren */
.candidate-card .candidate-card-tags,
.signal-card .candidate-card-tags,
.radar-card .candidate-card-tags,
.canonical-candidate-card .candidate-card-tags,
.candidate-card .signal-card-tags,
.signal-card .signal-card-tags,
.radar-card .signal-card-tags,
.candidate-card .tags,
.signal-card .tags,
.radar-card .tags {
  grid-column: 1 !important;
  align-self: end !important;
}

/* Falls Cards intern keine eindeutigen Container haben: Text nicht unnötig umbrechen */
.candidate-card h4,
.signal-card h4,
.radar-card h4,
.canonical-candidate-card h4 {
  font-size: 16px !important;
  line-height: 1.18 !important;
  max-width: 100% !important;
}

.candidate-card .muted,
.signal-card .muted,
.radar-card .muted,
.canonical-candidate-card .muted {
  font-size: 13px !important;
  line-height: 1.3 !important;
}

/* Listenpanel kann etwas schmaler werden, weil Cards nun effizienter sind */
.content-grid.candidates-layout,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
  grid-template-columns: minmax(560px, 43%) minmax(720px, 57%) !important;
}

.content-grid.candidates-layout > article.panel:first-child,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel.candidate-focus-list {
  min-width: 560px !important;
}

/* Sehr breite Screens: rechter Workspace bekommt mehr Platz */
@media (min-width: 1600px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(620px, 42%) minmax(820px, 58%) !important;
  }

  .content-grid.candidates-layout > article.panel:first-child {
    min-width: 620px !important;
  }

  #candidateDetailPanel {
    min-width: 820px !important;
  }
}

/* Mittlere Screens: Card bleibt einspaltig, aber intern horizontal */
@media (max-width: 1350px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(520px, 45%) minmax(620px, 55%) !important;
  }

  .content-grid.candidates-layout > article.panel:first-child {
    min-width: 520px !important;
  }
}

/* Kleine Screens: Card wieder vertikal */
@media (max-width: 1180px) {
  .candidate-card,
  .signal-card,
  .radar-card,
  .canonical-candidate-card {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
  }

  .candidate-card .score-grid,
  .signal-card .score-grid,
  .radar-card .score-grid,
  .canonical-candidate-card .score-grid,
  .candidate-card .signal-grid,
  .signal-card .signal-grid,
  .radar-card .signal-grid {
    grid-column: auto !important;
    grid-row: auto !important;
  }
}

/* =========================================================
   Wide Detail Workspace Fix
   Ziel: weißen Leerraum reduzieren, rechten Workspace deutlich verbreitern.
   ========================================================= */

/* Master-Detail-Verhältnis: linke Liste kompakter, rechter Workspace dominant */
.content-grid.candidates-layout,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
  grid-template-columns: minmax(430px, 34%) minmax(860px, 66%) !important;
  gap: 18px !important;
  width: 100% !important;
}

/* Linkes Panel nicht unnötig breit halten */
.content-grid.candidates-layout > article.panel:first-child,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel.candidate-focus-list {
  min-width: 430px !important;
  max-width: none !important;
  width: 100% !important;
  padding: 14px !important;
}

/* Rechter Workspace deutlich breiter */
#candidateDetailPanel,
body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
  min-width: 860px !important;
  width: 100% !important;
  max-width: none !important;
}

/* Kandidatenkarten im linken Panel erzwingen: volle Panelbreite */
.content-grid.candidates-layout > article.panel:first-child .candidate-card,
.content-grid.candidates-layout > article.panel:first-child .signal-card,
.content-grid.candidates-layout > article.panel:first-child .radar-card,
.content-grid.candidates-layout > article.panel:first-child .canonical-candidate-card,
.content-grid.candidates-layout > article.panel:first-child [data-candidate-id],
.content-grid.candidates-layout > article.panel:first-child [data-id] {
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
}

/* Listencontainer im linken Panel ebenfalls auf volle Breite */
.content-grid.candidates-layout > article.panel:first-child > div,
.content-grid.candidates-layout > article.panel:first-child section,
.content-grid.candidates-layout > article.panel:first-child .candidate-list,
.content-grid.candidates-layout > article.panel:first-child .candidate-cards,
.content-grid.candidates-layout > article.panel:first-child .signal-card-list,
.content-grid.candidates-layout > article.panel:first-child .radar-card-list {
  width: 100% !important;
  max-width: none !important;
}

/* Weißen Innenraum im linken Panel minimieren */
.content-grid.candidates-layout > article.panel:first-child {
  background: #ffffff !important;
}

/* Bei sehr breiten Screens noch stärker Detail-first */
@media (min-width: 1500px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(440px, 32%) minmax(980px, 68%) !important;
  }

  .content-grid.candidates-layout > article.panel:first-child {
    min-width: 440px !important;
  }

  #candidateDetailPanel,
  body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
    min-width: 980px !important;
  }
}

/* Auf mittleren Screens stabil bleiben */
@media (max-width: 1350px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(420px, 38%) minmax(650px, 62%) !important;
  }

  #candidateDetailPanel,
  body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
    min-width: 650px !important;
  }
}

@media (max-width: 1180px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: 1fr !important;
  }

  .content-grid.candidates-layout > article.panel:first-child,
  #candidateDetailPanel {
    min-width: 0 !important;
  }
}

/* Safety: Broken Action Overlay bleibt deaktiviert */
#candidateActionOverlay,
.candidate-action-overlay {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  opacity: 0 !important;
}

/* =========================================================
   Canonical Radar Visible Close Fix
   Ziel:
   - rechter Detailbereich darf nicht nach rechts auslaufen
   - Schließen-Button bleibt sichtbar
   - linke Canonical Cards nutzen ihre Breite sauber
   ========================================================= */

/* Master-Detail darf nie breiter als der verfügbare Content werden */
.content-grid.candidates-layout,
body.candidate-focus-mode .content-grid.candidates-layout,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
  width: 100% !important;
  max-width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(420px, 34%) minmax(0, 66%) !important;
  gap: 18px !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

/* Linke Liste: kompakt, aber Kacheln volle Breite */
.content-grid.candidates-layout > article.panel:first-child,
body.candidate-focus-mode .content-grid.candidates-layout > article.panel:first-child,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel:first-child,
body.candidate-focus-mode .candidates-layout.candidate-focus-layout > article.panel.candidate-focus-list {
  min-width: 420px !important;
  max-width: none !important;
  width: 100% !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  box-sizing: border-box !important;
}

/* Alle Cards links volle Panelbreite */
.content-grid.candidates-layout > article.panel:first-child .candidate-card,
.content-grid.candidates-layout > article.panel:first-child .signal-card,
.content-grid.candidates-layout > article.panel:first-child .radar-card,
.content-grid.candidates-layout > article.panel:first-child .canonical-candidate-card,
.content-grid.candidates-layout > article.panel:first-child [data-candidate-id],
.content-grid.candidates-layout > article.panel:first-child [data-canonical-id] {
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
}

/* Rechter Detailbereich: keine harte Mindestbreite mehr */
#candidateDetailPanel,
.content-grid.candidates-layout > aside#candidateDetailPanel,
.content-grid.candidates-layout > aside.panel.candidate-detail-panel,
body.candidate-focus-mode #candidateDetailPanel,
body.candidate-focus-mode #candidateDetailPanel.candidate-focus-workspace {
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  box-sizing: border-box !important;
  padding: 14px !important;
}

/* Detailcontent darf nicht horizontal überlaufen */
#candidateDetailContent,
.candidate-detail-content {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
  box-sizing: border-box !important;
}

/* Header sauber mit sichtbarem Schließen-Button */
.candidate-detail-header {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  box-sizing: border-box !important;
}

#candidateDetailCloseBtn {
  display: inline-flex !important;
  flex: 0 0 auto !important;
  position: sticky !important;
  top: 8px !important;
  right: 8px !important;
  z-index: 30 !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Falls hidden-Klasse am Close-Button hängen bleibt, aber Detail offen ist */
#candidateDetailContent:not(.hidden) #candidateDetailCloseBtn,
#candidateDetailPanel:has(#candidateDetailContent:not(.hidden)) #candidateDetailCloseBtn {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Meta-/Decision-Grids dürfen nicht überlaufen */
.candidate-detail-meta-grid,
.candidate-decision-grid,
.candidate-doc-consent-grid {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

.candidate-detail-meta-card,
.candidate-decision-card,
.candidate-doc-consent-card,
.candidate-detail-section {
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* Breite Screens: Detail etwas stärker, aber ohne Overflow */
@media (min-width: 1500px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: minmax(460px, 34%) minmax(0, 66%) !important;
  }

  .content-grid.candidates-layout > article.panel:first-child,
  body.candidate-focus-mode .content-grid.candidates-layout > article.panel:first-child {
    min-width: 460px !important;
  }
}

/* Kleinere Screens */
@media (max-width: 1180px) {
  .content-grid.candidates-layout,
  body.candidate-focus-mode .content-grid.candidates-layout,
  body.candidate-focus-mode .candidates-layout.candidate-focus-layout {
    grid-template-columns: 1fr !important;
    overflow: visible !important;
  }

  .content-grid.candidates-layout > article.panel:first-child,
  #candidateDetailPanel {
    min-width: 0 !important;
    max-width: 100% !important;
  }
}

/* Minimal Fix: Schließen-Button im Candidate Detail sichtbar halten */
#candidateDetailPanel {
  overflow-x: hidden !important;
}

.candidate-detail-header {
  position: relative !important;
  padding-right: 96px !important;
}

#candidateDetailCloseBtn {
  display: inline-flex !important;
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  z-index: 80 !important;
  visibility: visible !important;
  opacity: 1 !important;
  white-space: nowrap !important;
}

/* =========================================================
   Real Candidate Card Width Fix
   Echter Renderer: <article class="card clickable" data-candidate-id="...">
   Keine globalen Candidate-Wildcards.
   ========================================================= */

/* Linke Liste: Panelbreite nutzbar machen */
.content-grid.candidates-layout > article.panel:first-child {
  box-sizing: border-box !important;
}

/* Echter Kartencontainer */
.content-grid.candidates-layout > article.panel:first-child article.card.clickable[data-candidate-id],
.content-grid.candidates-layout > article.panel:first-child .card.clickable[data-candidate-id] {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* Wenn Detail geöffnet ist: linke Karten weiterhin volle linke Spalte */
body.candidate-focus-mode .content-grid.candidates-layout > article.panel:first-child article.card.clickable[data-candidate-id],
body.candidate-focus-mode .content-grid.candidates-layout > article.panel:first-child .card.clickable[data-candidate-id],
.candidates-layout.candidate-focus-layout > article.panel:first-child article.card.clickable[data-candidate-id],
.candidates-layout.candidate-focus-layout > article.panel:first-child .card.clickable[data-candidate-id] {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
}

/* Die Karte darf intern sauber umbrechen, aber nicht kollabieren */
article.card.clickable[data-candidate-id] h4,
article.card.clickable[data-candidate-id] .muted,
article.card.clickable[data-candidate-id] .tag,
article.card.clickable[data-candidate-id] .badge {
  overflow-wrap: anywhere !important;
}

/* Score-/Signalbereiche nicht quetschen */
article.card.clickable[data-candidate-id] .score-grid,
article.card.clickable[data-candidate-id] .signal-grid {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* =========================================================
   Candidate Cards Real Parent Width Fix
   Diagnose:
   - left panel: 1007px
   - #candidateCards.card-stack: 462px
   - article.card.clickable: 462px
   Daher nur den echten Parent #candidateCards.card-stack korrigieren.
   ========================================================= */

.content-grid.candidates-layout > article.panel:first-child #candidateCards.card-stack {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
  box-sizing: border-box !important;
  align-items: stretch !important;
}

/* echte Card im echten Parent */
.content-grid.candidates-layout > article.panel:first-child #candidateCards.card-stack > article.card.clickable[data-candidate-id] {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* falls active state eigene Breite bekommt */
.content-grid.candidates-layout > article.panel:first-child #candidateCards.card-stack > article.card.clickable.is-active-candidate[data-candidate-id] {
  width: 100% !important;
  max-width: none !important;
}

/* =========================================================
   Action Center v2 - Phase 1/2
   Scoped Workspace Overlay. Keine globalen Candidate-Selektoren.
   ========================================================= */

#candidateDetailPanel {
  position: sticky !important;
  isolation: isolate !important;
}

#candidateActionCenter.hidden {
  display: none !important;
}

#candidateActionCenter.candidate-action-center {
  position: absolute !important;
  inset: 0 !important;
  z-index: 120 !important;
  display: grid !important;
  place-items: center !important;
  padding: 24px !important;
  box-sizing: border-box !important;
}

#candidateActionCenter .candidate-action-center-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, 0.32) !important;
  backdrop-filter: blur(8px) !important;
  border-radius: 22px !important;
}

#candidateActionCenter .candidate-action-center-card {
  position: relative !important;
  z-index: 1 !important;
  width: min(760px, calc(100% - 24px)) !important;
  max-width: 760px !important;
  max-height: min(760px, calc(100vh - 260px)) !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  overflow: hidden !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.12) !important;
  border-radius: 24px !important;
  box-shadow: 0 30px 90px rgba(15, 23, 42, 0.26) !important;
  box-sizing: border-box !important;
}

#candidateActionCenter .candidate-action-center-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 16px !important;
  padding: 20px 22px !important;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08) !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
}

#candidateActionCenter .candidate-action-center-kicker {
  font-size: 11px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: #2563eb !important;
  margin-bottom: 4px !important;
}

#candidateActionCenter #candidateActionCenterTitle {
  margin: 0 !important;
  font-size: 20px !important;
  line-height: 1.2 !important;
  letter-spacing: -0.02em !important;
  color: #0f172a !important;
}

#candidateActionCenter .candidate-action-center-body {
  padding: 20px 22px !important;
  overflow-y: auto !important;
  background: #ffffff !important;
}

#candidateActionCenter .candidate-action-center-footer {
  display: flex !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  padding: 16px 22px !important;
  border-top: 1px solid rgba(15, 23, 42, 0.08) !important;
  background: #f8fafc !important;
}

#candidateActionCenter .candidate-action-center-placeholder {
  display: grid !important;
  gap: 12px !important;
}

#candidateActionCenter .candidate-action-center-hint {
  font-size: 13px !important;
  line-height: 1.45 !important;
  color: #475569 !important;
  background: #f8fafc !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  border-radius: 16px !important;
  padding: 14px !important;
}

#candidateActionCenter .candidate-action-center-actions {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

#candidateActionCenter .candidate-action-center-mode-card {
  border: 1px solid rgba(15, 23, 42, 0.10) !important;
  border-radius: 16px !important;
  padding: 14px !important;
  background: #ffffff !important;
}

#candidateActionCenter .candidate-action-center-mode-card strong {
  display: block !important;
  font-size: 13px !important;
  color: #0f172a !important;
  margin-bottom: 4px !important;
}

#candidateActionCenter .candidate-action-center-mode-card span {
  display: block !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  color: #64748b !important;
}

@media (max-width: 1180px) {
  #candidateActionCenter.candidate-action-center {
    position: fixed !important;
    inset: 0 !important;
    padding: 18px !important;
  }

  #candidateActionCenter .candidate-action-center-backdrop {
    border-radius: 0 !important;
  }

  #candidateActionCenter .candidate-action-center-card {
    width: min(720px, 100%) !important;
    max-height: calc(100vh - 36px) !important;
  }

  #candidateActionCenter .candidate-action-center-actions {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   Action Center v2 Hidden Fix
   Muss nach allen Action-Center-Regeln stehen.
   Verhindert leeres Overlay bei Default-State.
   ========================================================= */

#candidateActionCenter.hidden,
#candidateActionCenter.candidate-action-center.hidden {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* =========================================================
   Action Center v2 - Phase 3 CV Form
   ========================================================= */

#candidateActionCenter .candidate-action-center-form {
  display: grid !important;
  gap: 14px !important;
}

#candidateActionCenter .candidate-action-center-form label {
  display: grid !important;
  gap: 6px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #334155 !important;
}

#candidateActionCenter .candidate-action-center-form input,
#candidateActionCenter .candidate-action-center-form select,
#candidateActionCenter .candidate-action-center-form textarea {
  width: 100% !important;
  border: 1px solid rgba(15, 23, 42, 0.14) !important;
  border-radius: 14px !important;
  padding: 11px 12px !important;
  font-size: 14px !important;
  background: #ffffff !important;
  color: #0f172a !important;
  box-sizing: border-box !important;
}

#candidateActionCenter .candidate-action-center-form input:focus,
#candidateActionCenter .candidate-action-center-form select:focus,
#candidateActionCenter .candidate-action-center-form textarea:focus {
  outline: 2px solid rgba(37, 99, 235, 0.22) !important;
  border-color: rgba(37, 99, 235, 0.55) !important;
}

#candidateActionCenter .candidate-action-center-feedback {
  font-size: 12px !important;
  line-height: 1.45 !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
  background: #ecfdf5 !important;
  border: 1px solid rgba(16, 185, 129, 0.24) !important;
  color: #065f46 !important;
}

#candidateActionCenter .candidate-action-center-feedback.error {
  background: #fef2f2 !important;
  border-color: rgba(239, 68, 68, 0.24) !important;
  color: #991b1b !important;
}

#candidateActionCenter .candidate-action-center-feedback.hidden {
  display: none !important;
}

/* CV File Picker UX */
#candidateActionCenter .candidate-cv-file-picker {
  display: grid !important;
  gap: 10px !important;
  border: 1px dashed rgba(37, 99, 235, 0.35) !important;
  border-radius: 18px !important;
  padding: 14px !important;
  background: #eff6ff !important;
}

#candidateActionCenter .candidate-cv-file-picker-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
}

#candidateActionCenter .candidate-cv-file-picker-head strong {
  display: block !important;
  color: #0f172a !important;
  font-size: 14px !important;
}

#candidateActionCenter .candidate-cv-file-picker-head span,
#candidateActionCenter .candidate-cv-file-selected {
  display: block !important;
  color: #475569 !important;
  font-size: 12px !important;
  line-height: 1.4 !important;
}

#candidateActionCenter .candidate-cv-file-picker-btn {
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
  border-radius: 999px !important;
  padding: 9px 14px !important;
  background: #2563eb !important;
  color: #ffffff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

#candidateActionCenter .candidate-cv-file-picker-btn input {
  display: none !important;
}

#candidateActionCenter .candidate-action-center-advanced {
  border: 1px solid rgba(15, 23, 42, 0.10) !important;
  border-radius: 16px !important;
  padding: 12px !important;
  background: #f8fafc !important;
}

#candidateActionCenter .candidate-action-center-advanced summary {
  cursor: pointer !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  color: #334155 !important;
}

/* =========================================================
   Action Center v2 - Phase 4 Consent Form
   ========================================================= */

#candidateActionCenter .candidate-consent-warning {
  font-size: 12px !important;
  line-height: 1.45 !important;
  border-radius: 14px !important;
  padding: 12px 14px !important;
  background: #fff7ed !important;
  border: 1px solid rgba(249, 115, 22, 0.28) !important;
  color: #9a3412 !important;
  font-weight: 700 !important;
}

#candidateActionCenter .candidate-action-center-form textarea {
  resize: vertical !important;
  min-height: 92px !important;
  font-family: inherit !important;
}

/* =========================================================
   Action Center v2 - Phase 5 Shortlist Form
   ========================================================= */

#candidateActionCenter #candidateShortlistMandateId {
  font-weight: 800 !important;
  letter-spacing: 0.01em !important;
}

#candidateActionCenter #candidateShortlistNote {
  resize: vertical !important;
  min-height: 96px !important;
  font-family: inherit !important;
}

/* Phase 5 Mandatsauswahl */
#candidateActionCenter #candidateShortlistMandateSelect {
  font-weight: 800 !important;
}

#candidateActionCenter #candidateShortlistManualMandateDetails {
  margin-top: -4px !important;
}

/* =========================================================
   Action Center v2 - Height / Candidate Workspace Fit
   Ziel:
   - Anzeige bleibt im rechten Kandidatenbereich
   - Modal läuft nicht über die sichtbare Höhe hinaus
   - Formularinhalt scrollt innerhalb der Karte
   ========================================================= */

#candidateDetailPanel {
  position: relative !important;
  min-height: 520px !important;
}

#candidateActionCenter.candidate-action-center {
  align-items: start !important;
  padding-top: 28px !important;
  padding-bottom: 28px !important;
  overflow: hidden !important;
}

#candidateActionCenter .candidate-action-center-card {
  height: auto !important;
  max-height: calc(100vh - 180px) !important;
  min-height: 0 !important;
}

#candidateActionCenter .candidate-action-center-body {
  min-height: 0 !important;
  max-height: calc(100vh - 330px) !important;
  overflow-y: auto !important;
  overscroll-behavior: contain !important;
}

#candidateActionCenter .candidate-action-center-footer {
  flex-shrink: 0 !important;
}

/* In der engen Master-Detail-Ansicht: Modal bleibt sauber nutzbar */
@media (max-height: 850px) {
  #candidateActionCenter.candidate-action-center {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
  }

  #candidateActionCenter .candidate-action-center-card {
    max-height: calc(100vh - 120px) !important;
  }

  #candidateActionCenter .candidate-action-center-body {
    max-height: calc(100vh - 270px) !important;
  }
}

/* Kleine Screens / Browser mit DevTools offen */
@media (max-height: 700px) {
  #candidateActionCenter.candidate-action-center {
    place-items: start center !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }

  #candidateActionCenter .candidate-action-center-card {
    max-height: calc(100vh - 72px) !important;
  }

  #candidateActionCenter .candidate-action-center-body {
    max-height: calc(100vh - 220px) !important;
  }
}

/* =========================================================
   Action Center v2 - Phase 6 Remove Shortlist
   ========================================================= */

#candidateActionCenter .candidate-remove-shortlist-card {
  display: grid !important;
  gap: 4px !important;
  border: 1px solid rgba(15, 23, 42, 0.10) !important;
  border-radius: 16px !important;
  padding: 14px !important;
  background: #f8fafc !important;
}

#candidateActionCenter .candidate-remove-shortlist-label {
  font-size: 11px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: #64748b !important;
}

#candidateActionCenter .candidate-remove-shortlist-title {
  font-size: 14px !important;
  font-weight: 800 !important;
  color: #0f172a !important;
}

#candidateActionCenter .candidate-remove-shortlist-meta {
  font-size: 12px !important;
  color: #64748b !important;
}

#candidateActionCenter .danger.small,
#candidateActionCenter button.danger.small {
  background: #dc2626 !important;
  color: #ffffff !important;
  border-color: #dc2626 !important;
}

#candidateActionCenter .danger.small:hover,
#candidateActionCenter button.danger.small:hover {
  background: #b91c1c !important;
  border-color: #b91c1c !important;
}

/* Action Center v2 - Phase 6 Remove Shortlist */
#candidateActionCenter .candidate-remove-shortlist-card {
  display: grid !important;
  gap: 4px !important;
  border: 1px solid rgba(15, 23, 42, 0.10) !important;
  border-radius: 16px !important;
  padding: 14px !important;
  background: #f8fafc !important;
}

#candidateActionCenter .candidate-remove-shortlist-label {
  font-size: 11px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: #64748b !important;
}

#candidateActionCenter .candidate-remove-shortlist-title {
  font-size: 14px !important;
  font-weight: 800 !important;
  color: #0f172a !important;
}

#candidateActionCenter .candidate-remove-shortlist-meta {
  font-size: 12px !important;
  color: #64748b !important;
}

#candidateActionCenter .danger.small,
#candidateActionCenter button.danger.small {
  background: #dc2626 !important;
  color: #ffffff !important;
  border-color: #dc2626 !important;
}

#candidateActionCenter .danger.small:hover,
#candidateActionCenter button.danger.small:hover {
  background: #b91c1c !important;
  border-color: #b91c1c !important;
}

/* =========================================================
   Bullhorn Sync Hub - UI Final Fix
   Isoliert Bullhorn-Kacheln von Candidate/Card-Regeln.
   ========================================================= */

#bullhornSection,
#bullhornPage,
[data-section="bullhorn"],
body:has([data-view="bullhorn"]) {
  --bullhorn-card-radius: 20px;
}

/* Hauptlayout Bullhorn */
#bullhornSection .content-grid,
#bullhornPage .content-grid,
[data-section="bullhorn"] .content-grid {
  display: grid !important;
  grid-template-columns: minmax(420px, 1fr) minmax(420px, 1fr) !important;
  gap: 24px !important;
  align-items: start !important;
}

/* Statuspanel nicht quetschen */
#bullhornSection .panel,
#bullhornPage .panel,
[data-section="bullhorn"] .panel {
  min-width: 0 !important;
  overflow: visible !important;
}

/* Statuskarten */
#bullhornSection .metric-grid,
#bullhornPage .metric-grid,
[data-section="bullhorn"] .metric-grid,
#bullhornSection .status-grid,
#bullhornPage .status-grid,
[data-section="bullhorn"] .status-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(92px, 1fr)) !important;
  gap: 16px !important;
  align-items: stretch !important;
}

/* Einzelne Kachel */
#bullhornSection .metric-card,
#bullhornPage .metric-card,
[data-section="bullhorn"] .metric-card,
#bullhornSection .status-card,
#bullhornPage .status-card,
[data-section="bullhorn"] .status-card {
  min-width: 0 !important;
  width: auto !important;
  max-width: none !important;
  min-height: 150px !important;
  padding: 18px 16px !important;
  border-radius: var(--bullhorn-card-radius) !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  display: grid !important;
  align-content: start !important;
  gap: 8px !important;
}

/* Text sauber umbrechen */
#bullhornSection .metric-card *,
#bullhornPage .metric-card *,
[data-section="bullhorn"] .metric-card *,
#bullhornSection .status-card *,
#bullhornPage .status-card *,
[data-section="bullhorn"] .status-card * {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  max-width: 100% !important;
}

/* Label */
#bullhornSection .metric-card span,
#bullhornPage .metric-card span,
[data-section="bullhorn"] .metric-card span,
#bullhornSection .status-card span,
#bullhornPage .status-card span,
[data-section="bullhorn"] .status-card span {
  display: block !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  color: #94a3b8 !important;
}

/* Große Werte */
#bullhornSection .metric-card strong,
#bullhornPage .metric-card strong,
[data-section="bullhorn"] .metric-card strong,
#bullhornSection .status-card strong,
#bullhornPage .status-card strong,
[data-section="bullhorn"] .status-card strong {
  display: block !important;
  font-size: clamp(20px, 2vw, 30px) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.04em !important;
  color: #0f172a !important;
}

/* Entity Checkbox Pills */
#bullhornSection .chip,
#bullhornPage .chip,
[data-section="bullhorn"] .chip,
#bullhornSection label,
#bullhornPage label,
[data-section="bullhorn"] label {
  max-width: 100% !important;
}

/* Mirror Store Cards */
#bullhornSection .mirror-card,
#bullhornPage .mirror-card,
[data-section="bullhorn"] .mirror-card,
#bullhornSection .entity-card,
#bullhornPage .entity-card,
[data-section="bullhorn"] .entity-card {
  min-width: 0 !important;
  overflow: hidden !important;
}

/* Kleinere Viewports */
@media (max-width: 1280px) {
  #bullhornSection .content-grid,
  #bullhornPage .content-grid,
  [data-section="bullhorn"] .content-grid {
    grid-template-columns: 1fr !important;
  }

  #bullhornSection .metric-grid,
  #bullhornPage .metric-grid,
  [data-section="bullhorn"] .metric-grid,
  #bullhornSection .status-grid,
  #bullhornPage .status-grid,
  [data-section="bullhorn"] .status-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* Bullhorn Re-Authorize Button */
#bullhornReauthorizeBtn {
  margin-left: 10px !important;
  border-radius: 14px !important;
  font-weight: 800 !important;
}

#bullhornReauthorizeBtn:disabled {
  opacity: 0.65 !important;
  cursor: wait !important;
}

/* =========================================================
   Phase B2 - Native Outreach Board
   ========================================================= */

.outreach-status {
  border: 1px solid rgba(59, 130, 246, 0.18);
  background: #eff6ff;
  color: #1e3a8a;
  border-radius: 16px;
  padding: 12px 14px;
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 16px;
}

.outreach-status.error {
  border-color: rgba(220, 38, 38, 0.22);
  background: #fef2f2;
  color: #991b1b;
}

.outreach-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(160px, 1fr));
  gap: 16px;
  margin-bottom: 20px;
}

.outreach-kpi-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 20px;
  padding: 18px;
  box-shadow: 0 14px 40px rgba(15, 23, 42, 0.06);
  display: grid;
  gap: 8px;
}

.outreach-kpi-card span {
  font-size: 12px;
  font-weight: 800;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.outreach-kpi-card strong {
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1;
  letter-spacing: -0.05em;
  color: #0f172a;
}

.outreach-layout {
  align-items: start;
}

.outreach-panel,
.outreach-detail-panel {
  min-width: 0;
}

.outreach-company-list {
  display: grid;
  gap: 12px;
}

.outreach-company-card {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
  border-radius: 18px;
  padding: 16px;
  display: grid;
  gap: 12px;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.outreach-company-card:hover {
  transform: translateY(-1px);
  border-color: rgba(37, 99, 235, 0.24);
  box-shadow: 0 16px 44px rgba(15, 23, 42, 0.08);
}

.outreach-company-main {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.outreach-company-main h4 {
  margin: 0;
  font-size: 15px;
  color: #0f172a;
}

.outreach-company-main p,
.outreach-company-meta {
  margin: 4px 0 0;
  font-size: 12px;
  color: #64748b;
  line-height: 1.4;
}

.outreach-status-pill {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 6px 10px;
  background: #f1f5f9;
  color: #334155;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.outreach-empty {
  border: 1px dashed rgba(100, 116, 139, 0.35);
  background: #f8fafc;
  border-radius: 18px;
  padding: 26px;
  display: grid;
  gap: 8px;
  color: #475569;
}

.outreach-empty strong {
  color: #0f172a;
  font-size: 15px;
}

.outreach-next-actions {
  display: grid;
  gap: 12px;
}

.outreach-action-card {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #f8fafc;
  border-radius: 18px;
  padding: 14px;
  display: grid;
  gap: 5px;
}

.outreach-action-card strong {
  color: #0f172a;
}

.outreach-action-card span {
  color: #64748b;
  font-size: 12px;
  line-height: 1.4;
}

@media (max-width: 1180px) {
  .outreach-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .outreach-kpi-grid {
    grid-template-columns: 1fr;
  }

  .outreach-company-main {
    display: grid;
  }
}

/* =========================================================
   Phase B3.2 - Outreach Company Modal
   ========================================================= */

.outreach-modal.hidden {
  display: none !important;
}

.outreach-modal {
  position: fixed;
  inset: 0;
  z-index: 9500;
  display: grid;
  place-items: center;
  padding: 24px;
}

.outreach-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.42);
  backdrop-filter: blur(6px);
}

.outreach-modal-card {
  position: relative;
  width: min(720px, 100%);
  max-height: min(820px, calc(100vh - 48px));
  overflow: auto;
  background: #ffffff;
  border-radius: 24px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 28px 90px rgba(15, 23, 42, 0.25);
  padding: 24px;
}

.outreach-modal-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.outreach-modal-header h3 {
  margin: 4px 0 6px;
}

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

.outreach-company-form label {
  display: grid;
  gap: 7px;
  font-size: 13px;
  font-weight: 800;
  color: #334155;
}

.outreach-company-form input,
.outreach-company-form select,
.outreach-company-form textarea {
  width: 100%;
  border: 1px solid rgba(100, 116, 139, 0.24);
  border-radius: 14px;
  padding: 11px 12px;
  font: inherit;
  color: #0f172a;
  background: #ffffff;
}

.outreach-company-form textarea {
  resize: vertical;
}

.outreach-modal-feedback {
  border-radius: 14px;
  padding: 11px 12px;
  background: #eff6ff;
  color: #1e3a8a;
  font-size: 13px;
  font-weight: 700;
}

.outreach-modal-feedback.error {
  background: #fef2f2;
  color: #991b1b;
}

.outreach-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 8px;
}

@media (max-width: 720px) {
  .outreach-modal {
    padding: 12px;
  }

  .outreach-modal-card {
    border-radius: 18px;
    padding: 18px;
  }

  .outreach-modal-header {
    display: grid;
  }

  .outreach-modal-footer {
    display: grid;
  }
}

/* Outreach Empty State Fix */
.outreach-empty.hidden {
  display: none !important;
}

/* =========================================================
   Phase B3.3 - Outreach Company Detail Drawer
   ========================================================= */

.outreach-detail-drawer.hidden {
  display: none !important;
}

.outreach-detail-drawer {
  position: fixed;
  inset: 0;
  z-index: 9600;
  display: grid;
  justify-content: end;
}

.outreach-detail-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.36);
  backdrop-filter: blur(5px);
}

.outreach-detail-card {
  position: relative;
  width: min(620px, 100vw);
  height: 100vh;
  background: #ffffff;
  border-left: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: -24px 0 80px rgba(15, 23, 42, 0.22);
  display: grid;
  grid-template-rows: auto 1fr auto;
  z-index: 1;
}

.outreach-detail-header,
.outreach-detail-footer {
  padding: 22px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.outreach-detail-footer {
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  border-bottom: 0;
  justify-content: flex-end;
}

.outreach-detail-header h3 {
  margin: 4px 0 6px;
  font-size: 24px;
  letter-spacing: -0.03em;
}

.outreach-detail-body {
  overflow: auto;
  padding: 22px;
  display: grid;
  gap: 18px;
  align-content: start;
}

.outreach-detail-section {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
  border-radius: 18px;
  padding: 16px;
  display: grid;
  gap: 14px;
}

.outreach-detail-section h4 {
  margin: 0;
  color: #0f172a;
  font-size: 14px;
}

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

.outreach-detail-kv {
  background: #f8fafc;
  border-radius: 14px;
  padding: 12px;
  display: grid;
  gap: 4px;
}

.outreach-detail-kv span {
  color: #64748b;
  font-size: 11px;
  text-transform: uppercase;
  font-weight: 800;
  letter-spacing: 0.06em;
}

.outreach-detail-kv strong {
  color: #0f172a;
  font-size: 13px;
  overflow-wrap: anywhere;
}

.outreach-transition-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.outreach-transition-list span {
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 800;
}

.outreach-detail-note,
.outreach-detail-muted,
.outreach-detail-loading,
.outreach-detail-error {
  background: #f8fafc;
  border-radius: 14px;
  padding: 13px;
  color: #475569;
  font-size: 13px;
  line-height: 1.5;
}

.outreach-detail-error {
  background: #fef2f2;
  color: #991b1b;
}

.outreach-company-card {
  cursor: pointer;
}

@media (max-width: 720px) {
  .outreach-detail-card {
    width: 100vw;
  }

  .outreach-detail-grid {
    grid-template-columns: 1fr;
  }

  .outreach-detail-header,
  .outreach-detail-footer,
  .outreach-detail-body {
    padding: 16px;
  }
}

/* Phase B3.4 - Outreach Status Buttons */
.outreach-transition-btn {
  border: 0;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
  transition: transform 150ms ease, box-shadow 150ms ease, background 150ms ease;
}

.outreach-transition-btn:hover {
  transform: translateY(-1px);
  background: #dbeafe;
  box-shadow: 0 10px 24px rgba(37, 99, 235, 0.18);
}

/* =========================================================
   Phase B3.5 - Outreach Contacts UI
   ========================================================= */

.outreach-detail-section-title-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.outreach-contact-list {
  display: grid;
  gap: 10px;
}

.outreach-contact-card {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #f8fafc;
  border-radius: 16px;
  padding: 13px;
  display: grid;
  gap: 10px;
}

.outreach-contact-main {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.outreach-contact-main strong {
  display: block;
  color: #0f172a;
  font-size: 14px;
}

.outreach-contact-main span {
  display: block;
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
}

.outreach-contact-main em {
  flex: 0 0 auto;
  border-radius: 999px;
  background: #dcfce7;
  color: #166534;
  padding: 6px 9px;
  font-style: normal;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.outreach-contact-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
}

.outreach-contact-meta a,
.outreach-contact-meta span {
  border-radius: 999px;
  background: #ffffff;
  color: #334155;
  border: 1px solid rgba(100, 116, 139, 0.18);
  padding: 6px 9px;
  text-decoration: none;
  font-weight: 700;
}

.outreach-contact-meta a:hover {
  color: #1d4ed8;
  border-color: rgba(37, 99, 235, 0.3);
}

.outreach-contact-empty {
  background: #f8fafc;
  border: 1px dashed rgba(100, 116, 139, 0.35);
  border-radius: 16px;
  padding: 14px;
  color: #64748b;
  font-size: 13px;
}

.outreach-checkbox-row {
  display: flex !important;
  grid-template-columns: none !important;
  flex-direction: row;
  gap: 10px !important;
  align-items: center;
}

.outreach-checkbox-row input {
  width: auto !important;
}

@media (max-width: 720px) {
  .outreach-detail-section-title-row,
  .outreach-contact-main {
    display: grid;
  }
}

/* =========================================================
   Phase B4.1 - Warm Intro Preview
   ========================================================= */

.outreach-warm-result {
  display: grid;
  gap: 10px;
}

.outreach-warm-empty {
  background: #f8fafc;
  border: 1px dashed rgba(100, 116, 139, 0.35);
  border-radius: 16px;
  padding: 14px;
  display: grid;
  gap: 6px;
  color: #64748b;
  font-size: 13px;
}

.outreach-warm-empty strong {
  color: #0f172a;
}

.outreach-warm-list {
  display: grid;
  gap: 10px;
}

.outreach-warm-path-card {
  border: 1px solid rgba(37, 99, 235, 0.16);
  background: #eff6ff;
  border-radius: 16px;
  padding: 14px;
  display: grid;
  gap: 7px;
}

.outreach-warm-path-card strong {
  color: #1e3a8a;
  font-size: 14px;
}

.outreach-warm-path-card span {
  color: #475569;
  font-size: 12px;
  line-height: 1.45;
}

.outreach-warm-steps {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.outreach-warm-steps em {
  font-style: normal;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid rgba(37, 99, 235, 0.18);
  color: #1d4ed8;
  padding: 6px 9px;
  font-size: 11px;
  font-weight: 800;
}

/* =========================================================
   Phase B4.2 - Relationship UI
   ========================================================= */

#outreachAddRelationshipBtn {
  margin-right: 8px;
}

.outreach-detail-section-title-row {
  flex-wrap: wrap;
}

/* Fix: Modals opened from Outreach drawer must appear above the drawer */
.outreach-modal {
  z-index: 9800;
}

/* UX Fix - highlight status section when footer CTA is used */
.outreach-section-focus-pulse {
  animation: outreachFocusPulse 1.4s ease;
}

@keyframes outreachFocusPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(37, 99, 235, 0.35);
    border-color: rgba(37, 99, 235, 0.45);
  }
  60% {
    box-shadow: 0 0 0 8px rgba(37, 99, 235, 0.08);
    border-color: rgba(37, 99, 235, 0.28);
  }
  100% {
    box-shadow: none;
  }
}

/* =========================================================
   Phase B4.3 - Sequence Preview UI
   ========================================================= */

.outreach-sequence-result {
  display: grid;
  gap: 12px;
}

.outreach-sequence-summary,
.outreach-sequence-empty {
  border: 1px solid rgba(37, 99, 235, 0.16);
  background: #eff6ff;
  border-radius: 16px;
  padding: 14px;
  display: grid;
  gap: 6px;
}

.outreach-sequence-summary strong,
.outreach-sequence-empty strong {
  color: #1e3a8a;
  font-size: 14px;
}

.outreach-sequence-summary span,
.outreach-sequence-empty span {
  color: #475569;
  font-size: 12px;
  line-height: 1.45;
}

.outreach-sequence-steps {
  display: grid;
  gap: 10px;
}

.outreach-sequence-step {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #f8fafc;
  border-radius: 16px;
  padding: 13px;
  display: grid;
  gap: 10px;
}

.outreach-sequence-step.due {
  border-color: rgba(37, 99, 235, 0.28);
  background: #eff6ff;
}

.outreach-sequence-step-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.outreach-sequence-step-head strong {
  display: block;
  color: #0f172a;
  font-size: 13px;
}

.outreach-sequence-step-head span {
  display: block;
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
}

.outreach-sequence-step-head em {
  flex: 0 0 auto;
  border-radius: 999px;
  background: #dbeafe;
  color: #1d4ed8;
  padding: 6px 9px;
  font-style: normal;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.outreach-sequence-step pre {
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  margin: 0;
  background: #ffffff;
  border-radius: 12px;
  padding: 11px;
  color: #334155;
  font: inherit;
  font-size: 12px;
  line-height: 1.45;
}

.outreach-sequence-actions,
.outreach-sequence-start {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: end;
}

.outreach-sequence-start label {
  display: grid;
  gap: 6px;
  min-width: 220px;
  flex: 1;
  font-size: 12px;
  font-weight: 800;
  color: #334155;
}

.outreach-sequence-start select {
  border: 1px solid rgba(100, 116, 139, 0.24);
  border-radius: 12px;
  padding: 9px 10px;
  font: inherit;
}

.outreach-sequence-template-list {
  display: grid;
  gap: 8px;
}

.outreach-sequence-template {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
  border-radius: 14px;
  padding: 12px;
  display: grid;
  gap: 4px;
}

.outreach-sequence-template strong {
  color: #0f172a;
  font-size: 13px;
}

.outreach-sequence-template span {
  color: #64748b;
  font-size: 12px;
}

@media (max-width: 720px) {
  .outreach-sequence-step-head,
  .outreach-sequence-actions,
  .outreach-sequence-start {
    display: grid;
  }
}

/* =========================================================
   Phase B4.4 - Due Sequence Step Actions
   ========================================================= */

.outreach-due-step-section {
  display: grid;
  gap: 12px;
  margin-bottom: 12px;
}

.outreach-due-step-box,
.outreach-due-step-empty {
  border: 1px solid rgba(37, 99, 235, 0.18);
  background: #eff6ff;
  border-radius: 18px;
  padding: 14px;
  display: grid;
  gap: 12px;
}

.outreach-due-step-empty strong {
  color: #1e3a8a;
}

.outreach-due-step-empty span {
  color: #475569;
  font-size: 12px;
}

.outreach-due-step-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.outreach-due-step-head strong {
  display: block;
  color: #1e3a8a;
  font-size: 14px;
}

.outreach-due-step-head span {
  display: block;
  margin-top: 3px;
  color: #475569;
  font-size: 12px;
}

.outreach-due-step-head em {
  flex: 0 0 auto;
  border-radius: 999px;
  background: #dbeafe;
  color: #1d4ed8;
  padding: 6px 9px;
  font-style: normal;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.outreach-due-step-field {
  background: #ffffff;
  border-radius: 13px;
  padding: 10px;
  display: grid;
  gap: 4px;
}

.outreach-due-step-field span {
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.outreach-due-step-field strong {
  color: #0f172a;
  font-size: 13px;
  overflow-wrap: anywhere;
}

.outreach-due-step-body {
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  margin: 0;
  background: #ffffff;
  border-radius: 13px;
  padding: 12px;
  color: #334155;
  font: inherit;
  font-size: 12px;
  line-height: 1.5;
  max-height: 260px;
  overflow: auto;
}

.outreach-due-step-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

@media (max-width: 720px) {
  .outreach-due-step-head,
  .outreach-due-step-actions {
    display: grid;
  }
}

/* Batch 1 - Outreach Ops */
#outreachEditCompanyBtn {
  align-self: flex-start;
}

.outreach-due-step-actions .ghost[data-outreach-mark-step-sent] {
  border-color: rgba(22, 163, 74, 0.28);
  color: #166534;
  background: #f0fdf4;
}

.outreach-due-step-actions .ghost[data-outreach-mark-step-sent]:hover {
  background: #dcfce7;
}

/* Batch 2 - Outreach Admin */
.outreach-admin-list,
.outreach-timeline-list {
  display: grid;
  gap: 10px;
}

.outreach-admin-card {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #f8fafc;
  border-radius: 16px;
  padding: 12px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.outreach-admin-card strong,
.outreach-timeline-item strong {
  display: block;
  color: #0f172a;
  font-size: 13px;
}

.outreach-admin-card span,
.outreach-admin-card small,
.outreach-timeline-item span,
.outreach-timeline-item small {
  display: block;
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
}

.danger-soft {
  color: #991b1b !important;
  background: #fef2f2 !important;
  border-color: rgba(153, 27, 27, 0.18) !important;
}

.outreach-timeline-item {
  border-left: 3px solid rgba(37, 99, 235, 0.35);
  background: #f8fafc;
  border-radius: 14px;
  padding: 12px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
}

.outreach-timeline-item em {
  font-style: normal;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  padding: 6px 9px;
  font-size: 11px;
  font-weight: 900;
  height: fit-content;
}

@media (max-width: 720px) {
  .outreach-admin-card,
  .outreach-timeline-item {
    display: grid;
  }
}
